亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? annbp.cpp

?? 車牌識別系統
?? CPP
字號:
// AnnBP.cpp: implementation of the CAnnBP class.
//
//////////////////////////////////////////////////////////////////////
#include "StdAfx.h"
#include "AnnBP.h"
#include "math.h"




//////////////////////////////////////////////////////////////////////
// Construction/Destruction
//////////////////////////////////////////////////////////////////////

CAnnBP::CAnnBP()
{
	eta1=0.3;
	momentum1=0.3;

}

CAnnBP::~CAnnBP()
{

}


double CAnnBP::drnd()
{
	return ((double) rand() / (double) BIGRND);
}


/*** 返回-1.0到1.0之間的雙精度隨機數 ***/
double CAnnBP::dpn1()
{
	return (double) (rand())/(32767/2)-1;
}

/*** 作用函數,目前是S型函數 ***/
double CAnnBP::squash(double x)
{
	return (1.0 / (1.0 + exp(-x)));
}


/*** 申請1維雙精度實數數組 ***/
double* CAnnBP::alloc_1d_dbl(int n)
{
	double *new1;

	new1 = (double *) malloc ((unsigned) (n * sizeof (double)));
	if (new1 == NULL) {
		AfxMessageBox("ALLOC_1D_DBL: Couldn't allocate array of doubles\n");
		return (NULL);
	}
	return (new1);
}

/*** 申請2維雙精度實數數組 ***/
double** CAnnBP::alloc_2d_dbl(int m, int n)
{
	int i;
	double **new1;

	new1 = (double **) malloc ((unsigned) (m * sizeof (double *)));
	if (new1 == NULL) {
		AfxMessageBox("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 CAnnBP::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 CAnnBP::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 CAnnBP::bpnn_initialize(int seed)
{
	CString msg,s;
	msg="Random number generator seed:";
	s.Format("%d",seed);
	AfxMessageBox(msg+s);
	srand(seed);
}

/*** 創建BP網絡 ***/
BPNN* CAnnBP::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 CAnnBP::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);

	free((char *) net->hidden_delta);
	free((char *) net->output_delta);
	free((char *) net->target);

	for (i = 0; i <= n1; i++) {
		free((char *) net->input_weights[i]);
		free((char *) net->input_prev_weights[i]);
	}
	free((char *) net->input_weights);
	free((char *) net->input_prev_weights);

	for (i = 0; i <= n2; i++) {
		free((char *) net->hidden_weights[i]);
		free((char *) net->hidden_prev_weights[i]);
	}
	free((char *) net->hidden_weights);
	free((char *) net->hidden_prev_weights);

	free((char *) net);
}


/*** 創建一個BP網絡,并初始化權值***/
BPNN* CAnnBP::bpnn_create(int n_in, int n_hidden, int n_out)
{
	BPNN *newnet;

	newnet = bpnn_internal_create(n_in, n_hidden, n_out);

#ifdef INITZERO
	bpnn_zero_weights(newnet->input_weights, n_in, n_hidden);
#else
	bpnn_randomize_weights(newnet->input_weights, n_in, n_hidden);
#endif
	bpnn_randomize_weights(newnet->hidden_weights, n_hidden, n_out);
	bpnn_zero_weights(newnet->input_prev_weights, n_in, n_hidden);
	bpnn_zero_weights(newnet->hidden_prev_weights, n_hidden, n_out);

	return (newnet);

}



void CAnnBP::bpnn_layerforward(double *l1, double *l2, double **conn, int n1, int n2)
{
	double sum;
	int j, k;

	/*** 設置閾值 ***/
	l1[0] = 1.0;

	/*** 對于第二層的每個神經元 ***/
	for (j = 1; j <= n2; j++) {

		/*** 計算輸入的加權總和 ***/
		sum = 0.0;
		for (k = 0; k <= n1; k++) {
			sum += conn[k][j] * l1[k];
		}
		l2[j] = squash(sum);
	}
}

/* 輸出誤差 */
void CAnnBP::bpnn_output_error(double *delta, double *target, double *output, int nj, double *err)
{
	int j;
	double o, t, errsum;

	errsum = 0.0;
	for (j = 1; j <= nj; j++) {
		o = output[j];
		t = target[j];
		delta[j] = o * (1.0 - o) * (t - o);
		errsum += ABS(delta[j]);
	}
	*err = errsum;

}

/* 隱含層誤差 */
void CAnnBP::bpnn_hidden_error(double *delta_h, int nh, double *delta_o, int no, double **who, double *hidden, double *err)
{
	int j, k;
	double h, sum, errsum;

	errsum = 0.0;
	for (j = 1; j <= nh; j++) {
		h = hidden[j];
		sum = 0.0;
		for (k = 1; k <= no; k++) {
			sum += delta_o[k] * who[j][k];
		}
		delta_h[j] = h * (1.0 - h) * sum;
		errsum += ABS(delta_h[j]);
	}
	*err = errsum;
}

/* 調整權值 */
void CAnnBP::bpnn_adjust_weights(double *delta, int ndelta, double *ly, int nly, double **w, double **oldw, double eta, double momentum)
{
	double new_dw;
	int k, j;

	ly[0] = 1.0;
	for (j = 1; j <= ndelta; j++) {
		for (k = 0; k <= nly; k++) {
			new_dw = ((eta * delta[j] * ly[k]) + (momentum * oldw[k][j]));
			w[k][j] += new_dw;
			oldw[k][j] = new_dw;
		}
	}

}

/* 進行前向運算 */
void CAnnBP::bpnn_feedforward(BPNN *net)
{
	int in, hid, out;

	in = net->input_n;
	hid = net->hidden_n;
	out = net->output_n;

	/*** Feed forward input activations. ***/
	bpnn_layerforward(net->input_units, net->hidden_units,
		net->input_weights, in, hid);
	bpnn_layerforward(net->hidden_units, net->output_units,
		net->hidden_weights, hid, out);

}

/* 訓練BP網絡 */
void CAnnBP::bpnn_train(BPNN *net, double eta, double momentum, double *eo, double *eh)
{
	int in, hid, out;
	double out_err, hid_err;

	in = net->input_n;
	hid = net->hidden_n;
	out = net->output_n;

	/*** 前向輸入激活 ***/
	bpnn_layerforward(net->input_units, net->hidden_units,
		net->input_weights, in, hid);
	bpnn_layerforward(net->hidden_units, net->output_units,
		net->hidden_weights, hid, out);

	/*** 計算隱含層和輸出層誤差 ***/
	bpnn_output_error(net->output_delta, net->target, net->output_units,
		out, &out_err);
	bpnn_hidden_error(net->hidden_delta, hid, net->output_delta, out,
		net->hidden_weights, net->hidden_units, &hid_err);
	*eo = out_err;
	*eh = hid_err;

	/*** 調整輸入層和隱含層權值 ***/
	bpnn_adjust_weights(net->output_delta, out, net->hidden_units, hid,
		net->hidden_weights, net->hidden_prev_weights, eta, momentum);
	bpnn_adjust_weights(net->hidden_delta, hid, net->input_units, in,
		net->input_weights, net->input_prev_weights, eta, momentum);
}

/* 保存BP網絡 */
void CAnnBP::bpnn_save(BPNN *net, char *filename)
{
CFile file;
	char *mem;
	int n1, n2, n3, i, j, memcnt;
	double dvalue, **w;
	n1 = net->input_n;  n2 = net->hidden_n;  n3 = net->output_n;
	printf("Saving %dx%dx%d network to '%s'\n", n1, n2, n3, filename);
	try
	{
		file.Open(filename,CFile::modeWrite|CFile::modeCreate|CFile::modeNoTruncate);
	}
	catch(CFileException* e)
	{
		e->ReportError();
		e->Delete();
	}
	
	file.Write(&n1,sizeof(int));
	file.Write(&n2,sizeof(int));
	file.Write(&n3,sizeof(int));
	
	memcnt = 0;
	w = net->input_weights;
	mem = (char *) malloc ((unsigned) ((n1+1) * (n2+1) * sizeof(double)));
//	mem = (char *) malloc (((n1+1) * (n2+1) * sizeof(double)));
	for (i = 0; i <= n1; i++) {
		for (j = 0; j <= n2; j++) {
			dvalue = w[i][j];
			//fastcopy(&mem[memcnt], &dvalue, sizeof(double));
			fastcopy(&mem[memcnt], &dvalue, sizeof(double));
			memcnt += sizeof(double);
		
		}
	}

	file.Write(mem,sizeof(double)*(n1+1)*(n2+1));
	free(mem);

	memcnt = 0;
	w = net->hidden_weights;
	mem = (char *) malloc ((unsigned) ((n2+1) * (n3+1) * sizeof(double)));
//	mem = (char *) malloc (((n2+1) * (n3+1) * sizeof(double)));
	for (i = 0; i <= n2; i++) {
		for (j = 0; j <= n3; j++) {
			dvalue = w[i][j];
			fastcopy(&mem[memcnt], &dvalue, sizeof(double));
//			fastcopy(&mem[memcnt], &dvalue, sizeof(double));
			memcnt += sizeof(double);
		}
	}

	file.Write(mem, (n2+1) * (n3+1) * sizeof(double));
//	free(mem);

	file.Close();
	return;
}

/* 從文件中讀取BP網絡 */
BPNN* CAnnBP::bpnn_read(char *filename)
{
	char *mem;
	BPNN *new1;
	int n1, n2, n3, i, j, memcnt;
	CFile file;

	try
	{
		file.Open(filename,CFile::modeRead|CFile::modeCreate|CFile::modeNoTruncate);
	}
	catch(CFileException* e)
	{
		e->ReportError();
		e->Delete();
	}

	
//	printf("Reading '%s'\n", filename);// fflush(stdout);

	file.Read(&n1, sizeof(int));
	file.Read(&n2, sizeof(int));
	file.Read(&n3, sizeof(int));
	

	new1 = bpnn_internal_create(n1, n2, n3);

//	printf("'%s' contains a %dx%dx%d network\n", filename, n1, n2, n3);
//	printf("Reading input weights..."); // fflush(stdout);


	memcnt = 0;
	mem = (char *) malloc (((n1+1) * (n2+1) * sizeof(double)));

	file.Read(mem, ((n1+1)*(n2+1))*sizeof(double));
	for (i = 0; i <= n1; i++) {
		for (j = 0; j <= n2; j++) {
			//fastcopy(&(new1->input_weights[i][j]), &mem[memcnt], sizeof(double));
			fastcopy(&(new1->input_weights[i][j]), &mem[memcnt], sizeof(double));
			memcnt += sizeof(double);
		}
	}
	free(mem);

//	printf("Done\nReading hidden weights...");  //fflush(stdout);

	memcnt = 0;
	mem = (char *) malloc (((n2+1) * (n3+1) * sizeof(double)));

	file.Read(mem, (n2+1) * (n3+1) * sizeof(double));
	for (i = 0; i <= n2; i++) {
	
		for (j = 0; j <= n3; j++) {
			//fastcopy(&(new1->hidden_weights[i][j]), &mem[memcnt], sizeof(double));
			fastcopy(&(new1->hidden_weights[i][j]), &mem[memcnt], sizeof(double));
			memcnt += sizeof(double);
			
		}
	}
	free(mem);
	file.Close();

	printf("Done\n");  //fflush(stdout);

	bpnn_zero_weights(new1->input_prev_weights, n1, n2);
	bpnn_zero_weights(new1->hidden_prev_weights, n2, n3);

	return (new1);
}

void CAnnBP::CreateBP(int n_in, int n_hidden, int n_out)
{
	net=bpnn_create(n_in,n_hidden,n_out);
}

void CAnnBP::FreeBP()
{
	bpnn_free(net);

}

void CAnnBP::Train(double *input_unit,int input_num, double *target,int target_num, double *eo, double *eh)
{
	for(int i=1;i<=input_num;i++)
	{
		net->input_units[i]=input_unit[i-1];
	}

	for(int j=1;j<=target_num;j++)
	{
		net->target[j]=target[j-1];
	}
	bpnn_train(net,eta1,momentum1,eo,eh);

}

void CAnnBP::Identify(double *input_unit,int input_num,double *target,int target_num)
{
	for(int i=1;i<=input_num;i++)
	{
		net->input_units[i]=input_unit[i-1];
	}
	bpnn_feedforward(net);
	for(int j=1;j<=target_num;j++)
	{
		target[j-1]=net->output_units[j];
	}
}

void CAnnBP::Save(char *filename)
{
	bpnn_save(net,filename);

}

void CAnnBP::Read(char *filename)
{
	net=bpnn_read(filename);
}

void CAnnBP::SetBParm(double eta, double momentum)
{
	eta1=eta;
	momentum1=momentum;

}

void CAnnBP::Initialize(int seed)
{
	bpnn_initialize(seed);

}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
粗大黑人巨茎大战欧美成人| 国产美女精品在线| 精品一区二区三区欧美| 成人国产在线观看| 91精品国产综合久久久久久久久久| 国产欧美日韩亚州综合| 婷婷六月综合网| 91婷婷韩国欧美一区二区| 日韩欧美国产午夜精品| 一区二区在线免费| 成人看片黄a免费看在线| 欧美美女一区二区三区| 亚洲男人都懂的| 国产成a人无v码亚洲福利| 日韩一级黄色大片| 亚洲国产乱码最新视频| 不卡一区二区三区四区| 精品国产精品网麻豆系列| 天天操天天干天天综合网| 99国产欧美久久久精品| 中文一区在线播放| 国产一区二区按摩在线观看| 欧美唯美清纯偷拍| 日韩视频在线你懂得| 亚洲第一在线综合网站| 不卡一区二区三区四区| 精品国产制服丝袜高跟| 亚洲午夜在线观看视频在线| 成+人+亚洲+综合天堂| 精品国产一区二区三区忘忧草 | 欧美一区二区三区在线观看| 久久久久成人黄色影片| 天堂午夜影视日韩欧美一区二区| caoporm超碰国产精品| 日韩一区二区三区免费观看| 亚洲人精品一区| 高清在线不卡av| 26uuu精品一区二区三区四区在线| 午夜精品在线视频一区| 色吊一区二区三区| 日本一区二区不卡视频| 国产精品一区二区你懂的| 欧美一区二区免费视频| 亚洲成人综合网站| 欧美三日本三级三级在线播放| 日本一区二区三区视频视频| 久久99精品久久久久久国产越南| 欧美美女直播网站| 亚洲电影一级片| 欧美最新大片在线看| 亚洲欧美另类图片小说| av电影在线观看完整版一区二区| 国产亚洲婷婷免费| 国产一区二区三区蝌蚪| 欧美精品一区二区三区高清aⅴ| 午夜精彩视频在线观看不卡| 欧洲精品一区二区三区在线观看| 天天亚洲美女在线视频| 91精品国产色综合久久不卡蜜臀 | 久久精品一区二区三区不卡 | 亚洲激情av在线| 91成人网在线| 亚洲成人三级小说| 7777精品伊人久久久大香线蕉的 | 最新国产成人在线观看| 成人午夜免费电影| 最新日韩av在线| 欧美日韩精品欧美日韩精品一 | 6080午夜不卡| 精品一区精品二区高清| 国产欧美一区二区在线观看| 国产成人av一区| 亚洲免费在线电影| 欧美性色黄大片手机版| 青青草视频一区| 国产日产欧美一区| 91久久精品一区二区| 五月天精品一区二区三区| 精品久久久网站| 国产宾馆实践打屁股91| 亚洲色图清纯唯美| 欧美裸体一区二区三区| 九九精品视频在线看| 中文字幕一区二区三区四区不卡 | 色综合一个色综合| 天堂蜜桃一区二区三区| 久久精品网站免费观看| 在线亚洲欧美专区二区| 老司机午夜精品99久久| 国产精品不卡在线| 欧美一区二区精品在线| 99天天综合性| 蜜桃视频在线观看一区| 亚洲欧美综合在线精品| 91精品国产91综合久久蜜臀| 国产成人午夜精品5599| 亚洲国产精品久久久男人的天堂| 精品国产亚洲在线| 色综合欧美在线视频区| 国产一区二区三区最好精华液| 中文字幕亚洲在| 欧美一区二区福利视频| 国产.欧美.日韩| 一区二区三区在线视频观看 | 天天综合网 天天综合色| 久久精品视频在线看| 欧美绝品在线观看成人午夜影视| 99亚偷拍自图区亚洲| 久久99精品国产麻豆婷婷| 亚洲高清视频的网址| 国产精品每日更新在线播放网址 | 69成人精品免费视频| 99riav久久精品riav| 国产一区亚洲一区| 日韩精品91亚洲二区在线观看| 国产精品国产三级国产aⅴ入口 | 在线观看一区日韩| 成人免费毛片aaaaa**| 蜜桃精品视频在线| 天天亚洲美女在线视频| 亚洲欧美另类在线| 18成人在线视频| 国产精品乱码一区二区三区软件 | 日韩在线播放一区二区| 亚洲丝袜自拍清纯另类| 日本一区二区三区国色天香 | 一区二区三区四区高清精品免费观看| 精品国产免费一区二区三区香蕉| 欧美亚洲禁片免费| 色94色欧美sute亚洲线路一ni | 一区二区三区免费观看| 欧美国产日韩一二三区| 国产午夜精品福利| 日本一区二区三区国色天香| 国产蜜臀av在线一区二区三区| 久久只精品国产| 精品国产露脸精彩对白| 日韩精品一区国产麻豆| 欧美成人aa大片| 337p日本欧洲亚洲大胆色噜噜| 欧美一区二区三区思思人| 日韩一级免费观看| 久久久精品影视| 欧美激情综合在线| 欧美韩日一区二区三区四区| 国产校园另类小说区| 久久精品视频在线看| 国产精品―色哟哟| 中文字幕中文字幕中文字幕亚洲无线| 日韩一区在线播放| 亚洲人亚洲人成电影网站色| 亚洲人成伊人成综合网小说| 亚洲国产成人av网| 日韩和欧美一区二区| 久久99热国产| 99久久夜色精品国产网站| 欧洲一区二区三区免费视频| 欧美一区二区三区系列电影| 精品久久久久久久一区二区蜜臀| 久久影院视频免费| 国产精品电影一区二区| 亚洲综合男人的天堂| 日韩av在线发布| 成人精品高清在线| 在线看一区二区| 日韩欧美成人一区| 亚洲欧洲av色图| 人妖欧美一区二区| 成人蜜臀av电影| 91精品麻豆日日躁夜夜躁| 国产亚洲午夜高清国产拍精品| 亚洲一级二级在线| 亚洲bdsm女犯bdsm网站| 理论片日本一区| 在线精品国精品国产尤物884a| 精品久久久久一区二区国产| 亚洲欧美偷拍卡通变态| 蜜桃一区二区三区在线观看| 99久久综合国产精品| 欧美一级日韩免费不卡| 国产精品免费久久| 精品一区二区三区在线观看 | 国产精品网站导航| 日本亚洲天堂网| 99国产一区二区三精品乱码| 日韩精品一区二| 亚洲国产精品一区二区久久| 粉嫩一区二区三区在线看| 欧美一区二区三区的| 亚洲自拍都市欧美小说| 岛国一区二区三区| 日韩免费看网站| 天涯成人国产亚洲精品一区av| 色综合中文字幕国产 | 热久久免费视频| 日本精品裸体写真集在线观看| 久久精品男人天堂av| 日本不卡一二三| 欧美老肥妇做.爰bbww| 亚洲精品国产无天堂网2021|