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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? somnet.cpp

?? 一個可以運行的som神經(jīng)網(wǎng)絡程序
?? CPP
字號:
// Somnet.cpp: implementation of the CSomnet class.
//
//////////////////////////////////////////////////////////////////////

#include "stdafx.h"
#include "Somnet.h"
#include <fstream.h>
#include <iomanip.h>
#include <stdio.h>
#include <stdlib.h>
#include <math.h>


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

CSomnet::CSomnet()
{
	current_iteration_num=0;
	 min_distance=1000.0;
	 study_efficiency=efficiency;
	 neighbor_width=OutputLayerColumn;
     neighbor_height=OutputLayerRow;
	 winner_row=OutputLayerRow/2;
	 winner_column=OutputLayerColumn/2;

}

CSomnet::~CSomnet()
{

}

int CSomnet::getcurrentnum()
{
	return current_iteration_num;
}

long double CSomnet::getmindistance()
{
	return min_distance;
}
/****************************************************************/
//該函數(shù)初始化輸入數(shù)組
/****************************************************************/
CSomnet::CSomnet(int layer,int nd)
{
	int i;
	layernumber=layer;
	/*midianumber=midia;*/
	ndnumber=nd;
	inputMode=new double*[layernumber];
	for(i=0;i<layernumber;i++)
	{
		*(inputMode+i)=new double[ndnumber];
	}
//     for(i=0;i<layernumber;i++)
// 		for(j=0;j<midianumber;j++)
// 	{
//       *(*(inputMode+i)+j)=new int[ndnumber];	
// 	}
	InputLayerNum=ndnumber;
	weight=new double*[OutputLayerColumn*OutputLayerRow];
	for(i=0;i<OutputLayerRow*OutputLayerColumn;i++)
	{
		weight[i]=new double[InputLayerNum];
	}
}

/****************************************************************/
//該函數(shù)初始化距離變量為0,初始化保存勝出節(jié)點的位置的變量
/****************************************************************/
void CSomnet::init_distance()
{
	for(int i=0;i<OutputLayerRow;i++)
	for(int j=0;j<OutputLayerColumn;j++)
	distance[i*OutputLayerColumn+j]=0.0;        
 }

/****************************************************************/
//該函數(shù)用于計算歐氏距離,并找到獲勝神經(jīng)元
/****************************************************************/
void CSomnet::eula_distance(int z)
{
	int i,j,n;
	int ttLow,ttUp,ppLow,ppUp;
	ttLow=winner_column-neighbor_width/2;
	ttUp=winner_column+neighbor_width/2;
	ppLow=winner_row-neighbor_height/2;
	ppUp=winner_row+neighbor_height/2;
	if(ttLow<0)
		ttLow=0;
	if(ttUp>=OutputLayerColumn)
		ttUp=OutputLayerColumn-1;
	if(ppLow<0)
		ppLow=0;
	if(ppUp>=OutputLayerRow)
		ppUp=OutputLayerRow-1;
	for( i=ppLow;i<=ppUp;i++)
	for( j=ttLow;j<=ttUp;j++)
	{
		if(!(flag[i][j]==100))                       //用一個變化的外部變量控制循環(huán)的方法
		{
			/*for(m=0;m<midianumber;m++)*/
			for(n=0;n<ndnumber;n++)
				distance[i*OutputLayerColumn+j]+=
				pow((inputMode[z][n]-weight[i*OutputLayerColumn+j][n]),2);
			if(distance[i*OutputLayerColumn+j]<min_distance)
			{
				min_distance=distance[i*OutputLayerColumn+j];
				temp_row=i;
				temp_column=j;
			}
		}
		
	}
	if(current_iteration_num>0)
	{
		if(min_distance<=error_limit)                     
		{
			row[temp_row]=temp_row;
			column[temp_column]=temp_column;
			flag[temp_row][temp_column]=100;
		}
		
	}
}

/****************************************************************/
//調(diào)整權(quán)值
/****************************************************************/
void CSomnet::weight_change(int z)
{
	int i,j,n;
	int ttLow,ttUp,ppLow,ppUp;
	winner_row=temp_row;
	winner_column=temp_column;
	ttLow=winner_column-neighbor_width/2;
	ttUp=winner_column+neighbor_width/2;
	ppLow=winner_row-neighbor_height/2;
	ppUp=winner_row+neighbor_height/2;
	if(ttLow<0)
		ttLow=0;
	if(ttUp>=OutputLayerColumn)
		ttUp=OutputLayerColumn-1;
	if(ppLow<0)
		ppLow=0;
	if(ppUp>=OutputLayerRow)
		ppUp=OutputLayerRow-1;
	for(i=ppLow;i<=ppUp;i++)
	for(j=ttLow;j<=ttUp;j++)
	{
		if(!(flag[i][j]==100))
		{
/*			for(m=0;m<midianumber;m++)*/
			for(n=0;n<ndnumber;n++)
			weight[i*OutputLayerColumn+j][n]=
			weight[i*OutputLayerColumn+j][n]+
			study_efficiency*(inputMode[z][n]-weight[i*OutputLayerColumn+j][n]);
		}
		
	}
	
}
/****************************************************************/
//調(diào)整學習效率以及獲勝節(jié)點的鄰域大小
/****************************************************************/
void CSomnet::paraChange()
{
	
	study_efficiency=
		study_efficiency*(1.0-((double)current_iteration_num)/total_iteration_Num);
	neighbor_width=
		int(neighbor_width*(1.0-((double)current_iteration_num)/total_iteration_Num));
	neighbor_height=
		int(neighbor_height*(1.0-((double)current_iteration_num)/total_iteration_Num));
}
/*****************************************************************/
//該函數(shù)用于將所有輸入模式從文件中讀入,并存放到數(shù)組inputMode中;
//同時進行權(quán)值的初始化,采用隨機賦值的方法;
/*****************************************************************/
void CSomnet::initialize()
{
	int i,j,k;
	for(i=0;i<OutputLayerRow;i++)
		row[i]=100;
	for(j=0;j<OutputLayerColumn;j++)
		column[j]=100;
	for(i=0;i<OutputLayerRow;i++)
	for(j=0;j<OutputLayerColumn;j++)
		flag[i][j]=0;
	//從文件中將所有輸入模式讀入,并存放到數(shù)組inputMode中
	FILE *pf=fopen("相關(guān)數(shù)據(jù)\\輸入數(shù)據(jù)\\input.txt","a+");
	if(pf==NULL)
	{
		cout<<"Can not open input file!\n";
		exit(0);
	}
	
	for(i=0;i<layernumber;i++)
/*	for(j=0;j<midianumber;j++)*/
	for(k=0;k<ndnumber;k++)
	fscanf(pf,"%lf",&inputMode[i][k]);
	/////////////////////////////////////////////////////
	//用于測試是否能夠正確讀入輸入模式
	char  character[26];
	for(i=0;i<26;i++)
		character[i]=(65+i);
	ofstream mode ("相關(guān)數(shù)據(jù)\\輸出數(shù)據(jù)\\向量模式.txt",ios::out) ;
	for(i=0;i<layernumber;i++)
	{
		mode<<character[i]<<"\n"<<endl;
/*		for(j=0;j<midianumber;j++)*/
			for(k=0;k<ndnumber;k++)
				mode<<inputMode[i][k]<<" ";
			mode<<"\n";
		mode<<"\n\n\n";
	}
	////////////////////////////////////////////////////
	//權(quán)值初始化,采用隨機賦值的方法
	for(i=0;i<OutputLayerRow;i++)
	for(j=0;j<OutputLayerColumn;j++)
	for(k=0;k<InputLayerNum;k++)
		weight[i*OutputLayerColumn+j][k]=(double(rand()%101))/100.0;
	/////////////////////////////////////////////////////
	//用于測試是否能夠正確初始化權(quán)值
	ofstream quan ("相關(guān)數(shù)據(jù)\\輸出數(shù)據(jù)\\初始的權(quán)值.txt",ios::out) ;
	for(i=0;i<OutputLayerRow;i++)
	for(j=0;j<OutputLayerColumn;j++)
		{
			quan<<"\n\n\n"<<"Node["<<i+1<<"]["<<j+1<<"]"<<"\n";
			for(k=0;k<InputLayerNum;k++)
			{
				if(k%5==0)
					quan<<"\n";
				quan<<setprecision(6)<<setiosflags(ios::fixed)<<weight[i*OutputLayerColumn+j][k]<<"      ";
			}
			quan<<"\n\n\n";
		}
	////////////////////////////////////////////////////
}
/*****************************************************************/
//對網(wǎng)絡進行訓練
/*****************************************************************/

void  CSomnet::Treatnet()
{
	int l,i,j,k;
	int iteration_numbers[26];
	int total_num=0;
	char  character[26];
		for(l=0;l<layernumber;l++)
	{
		iteration_numbers[l]=0;
		character[l]=(65+l);     //65的ASC碼為'a',character數(shù)組中儲存了26個英文字母
	}
	initialize();
	for(l=0;l<layernumber;l++)     //26是指26個英文字母
	{
		winner_row=OutputLayerRow/2;
		winner_column=OutputLayerColumn/2;
		while(current_iteration_num<total_iteration_Num)
		{
			init_distance();
			eula_distance(l);
			weight_change(l);
			if(min_distance<=error_limit)
				break;
			++current_iteration_num;
			paraChange();
		};
		iteration_numbers[l]=current_iteration_num+1;
		neighbor_width=OutputLayerColumn;
		neighbor_height=OutputLayerRow;
		study_efficiency=efficiency;
		current_iteration_num=0;
		min_distance=1000.0;
	}
	for(l=0;l<layernumber;l++)
		total_num+=iteration_numbers[l];
	ofstream iteration_num("相關(guān)數(shù)據(jù)\\輸出數(shù)據(jù)\\迭代次數(shù).txt",ios::out);
	for(l=0;l<layernumber;l++)
	{
		iteration_num<<character[l]<<" 迭代"<<iteration_numbers[l]<<"次!\n"<<endl;
		if(l==(layernumber-1))
		iteration_num<<"整個訓練過程共迭代"<<total_num<<"次!\n"<<endl;
	}
	ofstream all_weight("相關(guān)數(shù)據(jù)\\輸出數(shù)據(jù)\\訓練后所有權(quán)值.txt",ios::out ) ;
	ofstream winner_weight("相關(guān)數(shù)據(jù)\\輸出數(shù)據(jù)\\訓練后勝出權(quán)值.txt",ios::out) ;
	for(i=0;i<OutputLayerRow;i++)
	for(j=0;j<OutputLayerColumn;j++)
	{
		printf("\n\n\n");
		all_weight<<"\n\n\n"<<"Node["<<i+1<<"]["<<j+1<<"]"<<"\n";
		for(k=0;k<InputLayerNum;k++)
		{
			if(k%5==0)
			{
				printf("\n");
				all_weight<<"\n";
			}
		/*	/////////////////////////////////////////////////
			if(weight[i*OutputLayerColumn+j][k]>0.9999999)
				weight[i*OutputLayerColumn+j][k]=1.0;
			if(weight[i*OutputLayerColumn+j][k]<0.0000001)
				weight[i*OutputLayerColumn+j][k]=0.0;
		*/	/////////////////////////////////////////////////
			printf("%f   ",weight[i*OutputLayerColumn+j][k]);
			all_weight<<setprecision(8)<<setiosflags(ios::fixed)<<weight[i*OutputLayerColumn+j][k]<<"      ";
		}
	}
	ofstream winner_node("相關(guān)數(shù)據(jù)\\輸出數(shù)據(jù)\\獲勝節(jié)點.txt",ios::out) ;
	for(i=0;i<OutputLayerRow;i++)
	for(j=0;j<OutputLayerColumn;j++)
	{
		if(flag[i][j]==100)
		{
			printf("\n\n\n");
			winner_weight<<"\n\n\n"<<"Node["<<i+1<<"]["<<j+1<<"]"<<"\n";
			for(k=0;k<InputLayerNum;k++)
			{
				if(k%5==0)
				{	
					printf("\n");
					winner_weight<<"\n";
				}
			/*	/////////////////////////////////////////////////
				if(weight[i*OutputLayerColumn+j][k]>0.9999999)
				weight[i*OutputLayerColumn+j][k]=1.0;
				if(weight[i*OutputLayerColumn+j][k]<0.0000001)
				weight[i*OutputLayerColumn+j][k]=0.0;
			*/	/////////////////////////////////////////////////
				printf("%f   ",weight[i*OutputLayerColumn+j][k]);
				winner_weight<<setprecision(8)<<setiosflags(ios::fixed)<<weight[i*OutputLayerColumn+j][k]<<"      ";
			}
			winner_node<<"Node["<<i+1<<"]["<<j+1<<"]"<<endl;
		}
		
	}
	printf("\n");
}

/************************************************************/
//利用標準數(shù)據(jù)測試訓練后的網(wǎng)絡
/************************************************************/
void CSomnet::test_netWork_1()
{
	int i,j,l,n;
	ofstream   test1("相關(guān)數(shù)據(jù)\\輸出數(shù)據(jù)\\標準測試.txt",ios::out);
	char  character[26];
	for(i=0;i<26;i++)
		character[i]=(65+i);
	for(l=0;l<layernumber;l++)
	{
		for(i=0;i<OutputLayerRow;i++)
		for(j=0;j<OutputLayerColumn;j++)
		distance[i*OutputLayerColumn+j]=0.0;
		min_distance=1000;
		for(i=0;i<OutputLayerRow;i++)
		for(j=0;j<OutputLayerColumn;j++)
		{
		/*	for(m=0;m<midianumber;m++)*/
			for(n=0;n<ndnumber;n++)
				distance[i*OutputLayerColumn+j]+=(long double)
				pow(((long double)inputMode[l][n]-(long double)weight[i*OutputLayerColumn+j][n]),2);
			if(distance[i*OutputLayerColumn+j]<min_distance)
			{
				min_distance=distance[i*OutputLayerColumn+j];
				temp_row=i;
				temp_column=j;
			}
		}
		test1<<character[l]<<"'s winner is Node["<<temp_row+1<<"]["<<temp_column+1<<"]"<<endl<<endl;
	}
}
/************************************************************/
//利用非標準數(shù)據(jù)測試訓練后的網(wǎng)絡
/************************************************************/
void CSomnet::test_netWork_2()
{
	int i,j,k,l,n;
	ofstream   test2("相關(guān)數(shù)據(jù)\\輸出數(shù)據(jù)\\非標準測試.txt",ios::out);
	char  character[26];
	if(inputMode!=NULL)
		delete []inputMode;
	inputMode=new double*[layernumber];
	for(i=0;i<layernumber;i++)
		*(inputMode+i)=new double[ndnumber];
	if(inputMode!=NULL)
	{
			FILE *pf1=fopen("相關(guān)數(shù)據(jù)\\輸入數(shù)據(jù)\\非標準數(shù)據(jù)測試.txt","a+");
	if(pf1==NULL)
	{
		cout<<"Can not open input file!\n";
		exit(0);
	}
	for(i=0;i<layernumber;i++)
/*	for(j=0;j<midianumber;j++)*/
	for(k=0;k<ndnumber;k++)
	fscanf(pf1,"%lf",&inputMode[i][k]);
	for(i=0;i<26;i++)
		character[i]=(65+i);
// 	char  character[26];
// 	for(i=0;i<26;i++)
// 		character[i]=(65+i);
	ofstream mode1 ("相關(guān)數(shù)據(jù)\\輸出數(shù)據(jù)\\非標準向量模式.txt",ios::out) ;
	for(i=0;i<layernumber;i++)
	{
		mode1<<character[i]<<"\n"<<endl;
/*		for(j=0;j<midianumber;j++)*/
			for(k=0;k<ndnumber;k++)
				mode1<<inputMode[i][k]<<" ";
			mode1<<"\n";
		mode1<<"\n\n\n";
	}
	for(l=0;l<layernumber;l++)
	{
		for(i=0;i<OutputLayerRow;i++)
		for(j=0;j<OutputLayerColumn;j++)
		distance[i*OutputLayerColumn+j]=0.0;
		min_distance=1000;
		for(i=0;i<OutputLayerRow;i++)
		for(j=0;j<OutputLayerColumn;j++)
		{
		/*	for(m=0;m<midianumber;m++)*/
			for(n=0;n<ndnumber;n++)
				distance[i*OutputLayerColumn+j]+=(long double)
				pow(((long double)inputMode[l][n]-(long double)weight[i*OutputLayerColumn+j][n]),2);
			if(distance[i*OutputLayerColumn+j]<min_distance)
			{
				min_distance=distance[i*OutputLayerColumn+j];
				temp_row=i;
				temp_column=j;
			}
		}
		test2<<character[l]<<"'s winner is Node["<<temp_row+1<<"]["<<temp_column+1<<"]"<<endl<<endl;
	}

	}

}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲尤物在线视频观看| 国产最新精品免费| 久久久久国产一区二区三区四区 | 欧美日韩精品欧美日韩精品一综合| 久久精品国产第一区二区三区| 中文字幕日韩一区二区| 欧美一二三区在线观看| 日本韩国精品在线| 成人国产精品免费观看动漫| 天堂资源在线中文精品| 亚洲日本丝袜连裤袜办公室| 欧美国产国产综合| 久久亚洲影视婷婷| 日韩午夜激情免费电影| 欧美亚洲一区二区在线| 91小视频在线免费看| 国产成人在线视频网站| 国产自产v一区二区三区c| 五月天丁香久久| 亚洲高清免费视频| 一区二区在线观看不卡| 国产精品久久三区| 国产日韩欧美电影| 精品福利av导航| 日韩欧美在线网站| 欧美一区二区三区免费大片| 欧美日韩一区三区四区| 欧美亚洲国产一区二区三区| 91久久香蕉国产日韩欧美9色| 99久久综合国产精品| 成人激情电影免费在线观看| 国产精品77777竹菊影视小说| 韩日精品视频一区| 国产麻豆一精品一av一免费| 国产老妇另类xxxxx| 狠狠色丁香久久婷婷综合丁香| 麻豆国产精品视频| 麻豆91小视频| 理论电影国产精品| 精品一区二区三区不卡| 国产在线播放一区三区四| 国产麻豆精品久久一二三| 国产成人超碰人人澡人人澡| 国产不卡在线一区| 99热99精品| 色爱区综合激月婷婷| 欧美午夜理伦三级在线观看| 精品1区2区3区| 91超碰这里只有精品国产| 日韩视频一区二区三区在线播放| 欧美一级生活片| 久久女同互慰一区二区三区| 国产视频在线观看一区二区三区| 中文字幕成人av| 一区二区在线观看免费| 日本成人中文字幕| 国产成人丝袜美腿| 99久久国产综合色|国产精品| 欧美丝袜丝交足nylons| 日韩午夜电影在线观看| 久久精品视频免费| 亚洲愉拍自拍另类高清精品| 美女被吸乳得到大胸91| 国产成人在线视频网站| 在线免费观看不卡av| 91精品国产日韩91久久久久久| 欧美xxxx老人做受| 中文字幕不卡在线| 亚洲chinese男男1069| 久久国产福利国产秒拍| eeuss国产一区二区三区| 欧美视频三区在线播放| 久久影视一区二区| 亚洲欧美日韩国产成人精品影院 | 日韩一区二区三区免费观看| 2021中文字幕一区亚洲| 综合色中文字幕| 日韩国产欧美在线播放| 成人免费视频国产在线观看| 欧美午夜电影网| 国产日产精品一区| 亚洲成人福利片| 国产91丝袜在线播放| 欧美夫妻性生活| 亚洲欧美日韩国产综合在线| 精品制服美女久久| 91在线免费看| 精品久久一二三区| 一区二区三区欧美日韩| 国产精品资源在线| 欧美另类高清zo欧美| 亚洲欧洲精品一区二区三区| 免费的成人av| 91精品1区2区| 国产精品乱码久久久久久| 日韩av一区二区三区| 91伊人久久大香线蕉| 久久青草国产手机看片福利盒子 | 91在线观看视频| 精品免费视频一区二区| 亚洲电影一级黄| 99精品视频在线观看免费| 久久久精品中文字幕麻豆发布| 亚洲成人tv网| 91视频免费看| 欧美国产精品专区| 国产尤物一区二区| 欧美成人乱码一区二区三区| 一区二区三区产品免费精品久久75| 国产精品一区在线观看乱码| 欧美一区二区啪啪| 亚洲第一av色| 欧美性感一区二区三区| 亚洲精品视频免费看| 成人免费毛片a| 欧美国产丝袜视频| 国产精品88av| 国产欧美在线观看一区| 精品无码三级在线观看视频| 欧美一二三区在线| 日韩成人一区二区| 欧美人妇做爰xxxⅹ性高电影| 亚洲青青青在线视频| 不卡的电影网站| 国产精品久久久久7777按摩| 国产成人三级在线观看| 国产日韩欧美麻豆| 国产成人综合网| 国产清纯白嫩初高生在线观看91| 精品一区精品二区高清| 日韩欧美国产综合一区 | 亚洲美女一区二区三区| 91在线无精精品入口| 亚洲欧美日韩在线不卡| 91精品1区2区| 午夜精品一区二区三区免费视频| 欧美日韩高清一区二区三区| 天堂av在线一区| 欧美一区二区精美| 精品一区二区三区蜜桃| 国产亚洲精品7777| 大桥未久av一区二区三区中文| 国产精品传媒视频| 色综合欧美在线| 亚洲国产视频在线| 91精品国产色综合久久久蜜香臀| 日韩国产欧美在线播放| 精品日韩在线观看| 国产精品影视在线观看| 国产精品污污网站在线观看| 波多野结衣在线一区| 一区二区三区精品在线观看| 欧美精品一卡二卡| 精品中文字幕一区二区小辣椒| 久久久精品蜜桃| 99久久精品免费看| 五月天一区二区| 久久这里只有精品视频网| 成人黄色在线看| 亚洲国产精品一区二区www| 欧美一区二区三区视频免费| 国产一区二区不卡在线 | 午夜精品久久久久久久| 日韩欧美国产麻豆| 成年人国产精品| 亚洲大片免费看| 久久久精品国产99久久精品芒果| 99精品视频免费在线观看| 亚洲一区二区综合| 精品国产一区二区三区不卡| 成人av电影观看| 丝瓜av网站精品一区二区| 国产亚洲欧洲997久久综合| 色欧美片视频在线观看在线视频| 午夜视频一区二区| 日本一区二区三区免费乱视频| 欧美色中文字幕| 国产精品一色哟哟哟| 亚洲亚洲人成综合网络| 国产区在线观看成人精品| 欧美日韩国产综合久久| 丰满放荡岳乱妇91ww| 日韩电影一区二区三区四区| 日韩一区中文字幕| 精品国产乱码久久久久久夜甘婷婷 | 在线综合+亚洲+欧美中文字幕| 国产一本一道久久香蕉| 香蕉av福利精品导航| 国产清纯美女被跳蛋高潮一区二区久久w| 欧美亚洲综合久久| 成人久久18免费网站麻豆 | 亚洲一二三区视频在线观看| 久久久久久影视| 欧美高清视频www夜色资源网| 成人美女在线观看| 九九**精品视频免费播放| 亚洲亚洲精品在线观看| 中文字幕一区二区三区在线不卡| 欧美成人一区二区三区片免费| 在线免费观看日本欧美|