资源简介
VisualC数字图像模式识别技术及工程实践.zip

代码片段和文件信息
//Download by http://www.NewXing.com
/*
******************************************************************
* backprop.cpp
******************************************************************
*/
#include “StdAfx.h“
#include
#include “backprop.h“
#include
#include
#define ABS(x) (((x) > 0.0) ? (x) : (-(x)))
/* 宏定义:快速拷贝 */
#define fastcopy(tofromlen)\
{\
register char *_to*_from;\
register int _i_l;\
_to = (char *)(to);\
_from = (char *)(from);\
_l = (len);\
for (_i = 0; _i < _l; _i++) *_to++ = *_from++;\
}
/*** 返回0-1的双精度随机数 ***/
double drnd()
{
return ((double) rand() / (double) BIGRND);
}
/*** 返回-1.0到1.0之间的双精度随机数 ***/
double dpn1()
{
return ((drnd() * 2.0) - 1.0);
}
/*** 作用函数,目前是S型函数 ***/
double squash(double x)
{
return (1.0 / (1.0 + exp(-x)));
}
/*** 申请1维双精度实数数组 ***/
double *alloc_1d_dbl(int n)
{
double *new1;
new1 = (double *) malloc ((unsigned) (n * sizeof (double)));
if (new1 == NULL) {
printf(“ALLOC_1D_DBL: Couldn‘t allocate array of doubles\n“);
return (NULL);
}
return (new1);
}
/*** 申请2维双精度实数数组 ***/
double **alloc_2d_dbl(int m int n)
{
int i;
double **new1;
new1 = (double **) malloc ((unsigned) (m * sizeof (double *)));
if (new1 == NULL) {
printf(“ALLOC_2D_DBL: Couldn‘t allocate array of dbl ptrs\n“);
return (NULL);
}
for (i = 0; i < m; i++) {
new1[i] = alloc_1d_dbl(n);
}
return (new1);
}
/*** 随机初始化权值 ***/
void bpnn_randomize_weights(double **w int m int n)
{
int i j;
for (i = 0; i <= m; i++) {
for (j = 0; j <= n; j++) {
w[i][j] = dpn1();
}
}
}
/*** 0初始化权值 ***/
void bpnn_zero_weights(double **w int m int n)
{
int i j;
for (i = 0; i <= m; i++) {
for (j = 0; j <= n; j++) {
w[i][j] = 0.0;
}
}
}
/*** 设置随机数种子 ***/
void bpnn_initialize(int seed)
{
printf(“Random number generator seed: %d\n“ seed);
srand(seed);
}
/*** 创建BP网络 ***/
BPNN *bpnn_internal_create(int n_in int n_hidden int n_out)
{
BPNN *newnet;
newnet = (BPNN *) malloc (sizeof (BPNN));
if (newnet == NULL) {
printf(“BPNN_CREATE: Couldn‘t allocate neural network\n“);
return (NULL);
}
newnet->input_n = n_in;
newnet->hidden_n = n_hidden;
newnet->output_n = n_out;
newnet->input_units = alloc_1d_dbl(n_in + 1);
newnet->hidden_units = alloc_1d_dbl(n_hidden + 1);
newnet->output_units = alloc_1d_dbl(n_out + 1);
newnet->hidden_delta = alloc_1d_dbl(n_hidden + 1);
newnet->output_delta = alloc_1d_dbl(n_out + 1);
newnet->target = alloc_1d_dbl(n_out + 1);
newnet->input_weights = alloc_2d_dbl(n_in + 1 n_hidden + 1);
newnet->hidden_weights = alloc_2d_dbl(n_hidden + 1 n_out + 1);
newnet->input_prev_weights = alloc_2d_dbl(n_in + 1 n_hidden + 1);
newnet->hidden_prev_weights = alloc_2d_dbl(n_hidden + 1 n_out + 1);
return (newnet);
}
/* 释放BP网络所占地内存空间 */
void bpnn_free(BPNN *net)
{
int n1 n2 i;
n1 = net->input_n;
n2 = net->hidden_n;
free((char *) net->input_units);
free((char *) net->hidden_units);
free((char *) net->output_units);
fre
属性 大小 日期 时间 名称
----------- --------- ---------- ----- ----
文件 5537 2007-11-07 11:01 Visual C++数字图像模式识别技术及工程实践 - 目录.txt
文件 5780042 2018-05-28 11:43 Visual C++数字图像模式识别技术及工程实践(第二版).pdf
目录 0 2008-10-09 20:56 源代码\
目录 0 2008-10-09 20:56 源代码\第03章 常用的模型和算法介绍\
目录 0 2008-10-09 20:56 源代码\第03章 常用的模型和算法介绍\BP神经网络的C语言实现\
文件 9601 2013-12-02 03:42 源代码\第03章 常用的模型和算法介绍\BP神经网络的C语言实现\backprop.cpp
文件 1702 2013-12-02 03:42 源代码\第03章 常用的模型和算法介绍\BP神经网络的C语言实现\backprop.h
目录 0 2008-10-09 20:56 源代码\第03章 常用的模型和算法介绍\BP神经网络解决异或问题\
文件 3403 1999-08-21 14:33 源代码\第03章 常用的模型和算法介绍\BP神经网络解决异或问题\BPNet.001
文件 3440 2002-11-19 08:52 源代码\第03章 常用的模型和算法介绍\BP神经网络解决异或问题\BPNet.dsp
文件 535 2002-11-19 08:52 源代码\第03章 常用的模型和算法介绍\BP神经网络解决异或问题\BPNet.dsw
文件 2420 2013-12-02 03:42 源代码\第03章 常用的模型和算法介绍\BP神经网络解决异或问题\bpnet.h
文件 41984 2003-01-07 07:04 源代码\第03章 常用的模型和算法介绍\BP神经网络解决异或问题\BPNet.ncb
文件 53760 2003-01-07 07:04 源代码\第03章 常用的模型和算法介绍\BP神经网络解决异或问题\BPNet.opt
文件 1078 2002-11-19 09:11 源代码\第03章 常用的模型和算法介绍\BP神经网络解决异或问题\BPNet.plg
文件 464 2013-12-02 03:42 源代码\第03章 常用的模型和算法介绍\BP神经网络解决异或问题\main.cpp
目录 0 2008-10-09 20:56 源代码\第03章 常用的模型和算法介绍\BP神经网络解决异或问题\Release\
文件 49152 2002-11-19 09:11 源代码\第03章 常用的模型和算法介绍\BP神经网络解决异或问题\Release\BPNet.exe
文件 5371 2002-11-19 09:11 源代码\第03章 常用的模型和算法介绍\BP神经网络解决异或问题\Release\main.obj
文件 33792 2003-01-07 07:03 源代码\第03章 常用的模型和算法介绍\BP神经网络解决异或问题\Release\vc60.idb
目录 0 2008-10-09 20:56 源代码\第03章 常用的模型和算法介绍\HMM的C语言实现\
文件 1957 2013-12-02 03:42 源代码\第03章 常用的模型和算法介绍\HMM的C语言实现\backward.cpp
文件 4083 2013-12-02 03:42 源代码\第03章 常用的模型和算法介绍\HMM的C语言实现\baum.cpp
文件 2318 2013-12-02 03:42 源代码\第03章 常用的模型和算法介绍\HMM的C语言实现\hmm.h
文件 472 2013-12-02 03:42 源代码\第03章 常用的模型和算法介绍\HMM的C语言实现\hmmrand.cpp
文件 4117 2013-12-02 03:42 源代码\第03章 常用的模型和算法介绍\HMM的C语言实现\hmmutils.cpp
文件 10859 2013-12-02 03:42 源代码\第03章 常用的模型和算法介绍\HMM的C语言实现\nrutil.cpp
文件 1486 2013-12-02 03:42 源代码\第03章 常用的模型和算法介绍\HMM的C语言实现\nrutil.h
文件 3058 2013-12-02 03:42 源代码\第03章 常用的模型和算法介绍\HMM的C语言实现\viterbi.cpp
目录 0 2008-10-09 20:56 源代码\第03章 常用的模型和算法介绍\矢量量化的C语言实现\
文件 11870 2013-12-02 03:42 源代码\第03章 常用的模型和算法介绍\矢量量化的C语言实现\Clustering.cpp
............此处省略391个文件信息
相关资源
- vspd7.2.308.zip
- 价值2k的H漫画小说系统
- Pythonamp;课堂amp;笔记(高淇amp;400;集第
- ddos压力测试工具99657
- UML建模大全
- 开源1A锂电池充电板TP4056原理图+PCB
- m1卡 ic卡可选择扇区初始化加密软件
- TSCC.exe
- FTP课程设计(服务端+客户端)
- 计算机图形学 边填充算法实现代码
- 电力系统潮流计算程序集合
- oracle数据迁移项目实施方案
- Web Api 通过文件流 文件到本地
- Visio图标-最新最全的网络通信图标库
- Spire API文档
- OpenGL参考手册
- Python中Numpy库最新教程
- SPD博士V5.3.exe
- 直流无刷电机方波驱动 stm32 例程代码
- layui后台管理模板
- 仿知乎界面小程序源代码
- 云平台-阿里云详细介绍
- photoshop经典1000例
- scratch垃圾分类源码(最终版本).sb
- IAR ARM 7.8破解
- TI CCS V5.4 安装步骤及破解文件
- 松下plc FP-XH的驱动
- 局域网硬件信息收集工具
- 加快Windows XP操作系统开机速度
- 联想启天M4350 BIOS升级文件
评论
共有 条评论