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

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

?? neuralnetwork.cpp

?? 人工神經網絡分類實現
?? CPP
字號:
// NeuralNetwork.cpp : 定義控制臺應用程序的入口點。
//
/************************************************************************
* 版權所有 (C)2008, HITSZ 
* 
* 文件名稱:// NeuralNetwork.cpp
* 文件標識:// 
* 內容摘要:// 利用反向傳播算法進行音軌分類
* 其它說明:
* 當前版本:// 1.0版
* 作    者:// 李江濤,哈爾濱工業大學深圳研究生院智能計算研究中心 
* 完成日期:// 2008年12月14日
* 
* 修改記錄1:
*    修改日期:
*    版 本 號:
*    修 改 人:
*    修改內容:          
************************************************************************/

#include "stdafx.h"
#include <iostream>
#include <fstream>
#include <cmath>
#include <cstring>
#include <string>
#include <ctime>

#include "GlobalVal.h"
using namespace std;

/************************************************************************
* 函數名稱:// StrToInt
* 功能描述:// string到int的轉換
* 訪問的表:// 
* 修改的表://
* 輸入參數:// string
* 輸出參數:// int
* 返 回 值:// 
* 其它說明:// 
* 修改日期       版本號     修改人               修改內容
* -----------------------------------------------------------------------
* 2008/12/14     v1.0       李江濤               建立該函數
************************************************************************/

int StrToInt(string& str)
{
	int i, len = (int)str.size(), num = 0;
	i = 0;
	while (i < len)
	{
		num = num * 10 + (int)(str[i] - '0');
		++i;
	}
	return num;
}

/************************************************************************/
/*                           函數原型                                   */
/************************************************************************/
bool startTraining(void); 
bool startTesting(void); 
void initialWeight(void);

/************************************************************************/
/*                         主函數                                       */
/************************************************************************/
int _tmain(int argc, _TCHAR* argv[])
{
	int ctrl;  //循環控制
	int choose = 0; //循環控制
	ofstream outputFile;
	//初始化權值
	initialWeight();

	cout << "特征數:" << NUMIN << "\t" << "以mid為單位判斷準確率 !" << endl;
	while (3 != choose)
	{
		// 選擇
		ctrl = 0;
		cout << "*********************" << endl;
		cout << "    1. Train\n    2. Test\n    3. Quit\n";
		cout << "*********************" << endl;
		cout << "Please input your choice: ";
		cin >> choose;
		if (1 == choose)
		{ 
			cout << "\nTraining ... " << endl;
			while (800 > ctrl)
			{
				if (!startTraining())
				{
					cout << "train error !" << endl;
					break;
					//exit(1);
				}
				++ctrl;
			}
			cout << "Training end!\n" << endl;
		}
		else if (2 == choose)
		{
			cout << "\nTesting ..." << endl;
			outputFile.open("Result.txt");
			if (outputFile.fail())
			{
				cout<<"Can not open result file!\n";
				exit(1);
			}
			if (!startTesting())
			{
				cout << "test error !" << endl;
				//exit(1);
			}
			else 
			{
				// 輸出結果
				outputFile << "====================================================" << endl;
				outputFile << "Right number : " << rightNum << endl;
				outputFile << "Right rate : " << (float)rightNum / (float)testNum << endl;
				outputFile.close();

				cout << "Testing end!\n" << endl;
				cout << "Total number: " << testNum << endl;
				cout << "Right number : " << rightNum << endl;
				cout << "Right rate : " << (float)rightNum / (float)testNum << endl;
				cout << "\n";
			}
			
		}
		else if (3 == choose)
		{
			cout << "\nBye~~~\n" << endl;
			break;
		}
		else
		{
			cout << "Input error!" << endl;
			continue;
		}
	}
	return 0;
}


/************************************************************************
* 函數名稱:// initialWeight
* 功能描述:// 初始化神經網絡權值
* 訪問的表:// 
* 修改的表://
* 輸入參數:// 
* 輸出參數:// 
* 返 回 值:// 無返回值
* 其它說明:// 
* 修改日期       版本號     修改人               修改內容
* -----------------------------------------------------------------------
* 2008/12/14     v1.0       李江濤               建立該函數

************************************************************************/
void initialWeight(void)
{
	int i, j;
	// 時間種子
	srand((unsigned)time(NULL));
	for (i = 0; i < NUMIN; i++)
	{
		for (j = 0; j < NUMHIDDEN; j++)
		{
			weightInHidden[i][j] = (double)((rand() % 1000) - 500) / 10000;
		}
	}

	for (i = 0; i < NUMHIDDEN; i++)
	{
		for (j = 0; j < NUMOUT; j++)
		{
			weightHiddenOut[i][j] = (double)((rand() % 1000) - 500) / 10000;
		}
	}

}

/************************************************************************
* 函數名稱:// initialWeight
* 功能描述:// 訓練神經網絡權值
* 訪問的表:// 
* 修改的表://
* 輸入參數:// 
* 輸出參數:// 
* 返 回 值:// 無返回值
* 其它說明:// 
* 修改日期       版本號     修改人               修改內容
* -----------------------------------------------------------------------
* 2008/12/14     v1.0       李江濤               建立該函數
*
* 修改日期       版本號     修改人               修改內容
* -----------------------------------------------------------------------
* 2008/12/18     v1.1       李江濤               增加頭處理,避免每次改樣本文件
************************************************************************/

bool startTraining(void)
{
	float pgmContent[NUMIN], t[NUMOUT];
	int i, j;
	double hiddenLayer[NUMHIDDEN];
	double outputLayer[NUMOUT];
	double errOfHidden[NUMHIDDEN];
	double errOfOutput[NUMOUT];

	string filename;
	int trackNum;
	ifstream trainList("train.txt");
	if (trainList.fail())
	{
		cout << "open train.txt error !";
		return false;
	}
	while (trainList.peek() != EOF )
	{
		trainList >> filename;
		trainList >> trackNum;
		for (int k=1; k<=trackNum; ++k)
		{
			for (i=0; i<NUMIN; ++i)
			{
				trainList >> pgmContent[i];
			}
			trainList >> t[0];
			t[1] = 1 - t[0];


			for (i = 0; i < NUMHIDDEN; i++)
			{
				hiddenLayer[i] = 0;
			}
			outputLayer[0] = 0;
			outputLayer[1] = 0;
			// 初始化隱藏層
			for (i=0; i<NUMHIDDEN; ++i)
			{
				for (j=0; j<NUMIN; ++j)
				{
					hiddenLayer[i] += pgmContent[j] * weightInHidden[j][i];
				}
				hiddenLayer[i] = 1 / (1 + exp((-1) * hiddenLayer[i]));
			}
			// 初始化輸出層
			for (i=0; i<NUMOUT; ++i)
			{
				for (j=0; j<NUMHIDDEN; ++j)
				{
					outputLayer[i] += hiddenLayer[j] * weightHiddenOut[j][i];
				}
				outputLayer[i] = 1 / (1 + exp((-1) * outputLayer[i]));
			}

			// 修改輸出層誤差
			for (i=0; i<NUMOUT; ++i)
			{
				errOfOutput[i] = outputLayer[i] * (1 - outputLayer[i]) * (t[i] - outputLayer[i]);
			}
			// 修改隱藏層誤差
			for (i=0; i<NUMHIDDEN; ++i)
			{
				errOfHidden[i] = hiddenLayer[i] * (1 - hiddenLayer[i]) * (weightHiddenOut[i][0] * errOfOutput[0] 
				+ weightHiddenOut[i][1] * errOfOutput[1]);
			}

			// 更新隱藏層到輸出層權值
			for (i=0; i<NUMHIDDEN; ++i)
			{
				for (j=0; j<NUMOUT; ++j)
				{
					weightHiddenOut[i][j] = weightHiddenOut[i][j] + learningRate * errOfOutput[j] * hiddenLayer[i];
				}
			}
			// 更新輸入層到隱藏層權值
			for (i=0; i<NUMIN; ++i)
			{
				for (j=0; j<NUMHIDDEN; ++j)
				{
					weightInHidden[i][j] = weightInHidden[i][j] + learningRate * errOfHidden[j] * pgmContent[i];
				}
			}  
		}
		filename.clear();
	}
	trainList.close();

	return true;
}

/************************************************************************
* 函數名稱:// initialWeight
* 功能描述:// 測試神經網絡
* 訪問的表:// 
* 修改的表://
* 輸入參數:// 
* 輸出參數:// 
* 返 回 值:// 無返回值
* 其它說明:// 
* 修改日期       版本號     修改人               修改內容
* -----------------------------------------------------------------------
* 2008/12/14     v1.0       李江濤               建立該函數

************************************************************************/

bool startTesting(void)
{
	ofstream testOut("testResult.txt");
	string filename;
	int trackNum;
	int maxNum;
	float maxOutPut;

	int zeroNum;
	float pgmContent[NUMIN];
	float t[NUMOUT];	
	int melodyTrack;
	ifstream testList("test.txt");
	if (testList.fail())
	{
		cout << "open test.txt error !";
		return false;
	}
	int i, j, k;
	int temp;
	double hiddenLayer[NUMHIDDEN];
	double outputLayer[50][NUMOUT];

	/*for (i = 0; i < NUMHIDDEN; i++)
	{
		hiddenLayer[i] = 0;
	}
	outputLayer[k][0] = 0;
	outputLayer[k][1] = 0;*/

	testNum = 0;
	rightNum = 0;

	while (testList.peek() != EOF)
	{
		melodyTrack = 0;
		maxOutPut = -100.0;
		maxNum = 0;
		temp = 0;
		testList >> filename;
		if (filename.empty())
		{
			continue;
		}
		testList >> trackNum;
		++testNum;
		for (k=1; k<=trackNum; ++k)
		{
			for (i=0; i<NUMIN; ++i)
			{
				testList >> pgmContent[i];
			}
			zeroNum = 0;
			testList >> t[0];
			if (t[0] > 0.5)
			{
				melodyTrack = k;
			}

			for (i=0; i<NUMIN; ++i)
			{
				if (pgmContent[i] == 0)
				{
					++zeroNum;
				}
			}

			if (zeroNum >= NUMIN-2)
			{
				outputLayer[k][0] = 0.1;
				continue;
			}

			for (i = 0; i < NUMHIDDEN; i++)
			{
				hiddenLayer[i] = 0;
			}
			outputLayer[k][0] = 0;
			outputLayer[k][1] = 0;

			// 計算隱藏層
			for (i = 0; i < NUMHIDDEN; i++)
			{
				for (j = 0; j < NUMIN; j++)
				{
					hiddenLayer[i] += pgmContent[j] * weightInHidden[j][i];
				}
				hiddenLayer[i] = 1 / (1 + exp((-1) * hiddenLayer[i]));
			}

			// 計算輸出層
			for (i = 0; i < NUMOUT; i++)
			{
				for (j = 0; j < NUMHIDDEN; j++)
				{
					outputLayer[k][i] += hiddenLayer[j] * weightHiddenOut[j][i];
				}
				outputLayer[k][i] = 1 / (1 + exp((-1) * outputLayer[k][i]));
			}

			//outputLayer[k][0] = outputLayer[k][0] - outputLayer[k][1];
		}


		for (k=0; k<trackNum; ++k)
		{
			if ((outputLayer[k][0]-maxOutPut) > 10e-4)
			{
				maxOutPut = (float)outputLayer[k][0];
				maxNum = k;
			}
		}

		testOut << filename << "  " << maxNum << "  " << melodyTrack << endl;
		if (maxNum == melodyTrack)
		{
			++rightNum;
		}
		filename.clear();
	}
	return true;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
免费看日韩精品| 欧美三级电影在线看| 一本大道av伊人久久综合| 欧美精品一二三四| 国产精品亲子乱子伦xxxx裸| 亚洲成人中文在线| av在线不卡免费看| 精品日本一线二线三线不卡| 洋洋成人永久网站入口| 成人永久免费视频| 精品国产一区二区三区四区四| 亚洲男人电影天堂| 国产91色综合久久免费分享| 欧美一级精品大片| 亚洲国产精品久久人人爱蜜臀| 国产.精品.日韩.另类.中文.在线.播放| 欧美三片在线视频观看 | 亚洲欧美偷拍卡通变态| 国产一区二区在线电影| 日韩一区二区三区在线视频| 亚洲一二三四久久| 色视频一区二区| 日韩美女视频一区二区| 成人小视频免费在线观看| 久久蜜臀精品av| 国产美女视频一区| 久久久久久综合| 久久精品国产免费看久久精品| 欧美日本在线视频| 亚洲高清不卡在线观看| 91久久精品一区二区二区| 综合欧美亚洲日本| av电影在线观看不卡| 国产精品久久久久精k8| 成人做爰69片免费看网站| 国产日韩亚洲欧美综合| 国产成人亚洲精品狼色在线| 久久先锋影音av鲁色资源| 久久精品国产在热久久| 久久美女高清视频| 成人免费毛片嘿嘿连载视频| 中文字幕日韩精品一区| 91日韩精品一区| 亚洲图片欧美视频| 欧美一区二区三区视频在线| 青青青伊人色综合久久| 26uuu国产在线精品一区二区| 精品亚洲国内自在自线福利| 国产三级欧美三级| 色综合久久久久综合99| 亚洲成a人v欧美综合天堂下载| 在线不卡中文字幕| 国产综合久久久久影院| 欧美激情一区二区在线| 色呦呦国产精品| 日本中文一区二区三区| 久久久久久久久久久久久女国产乱 | 欧美一区二区二区| 国产成人在线免费| 亚洲免费在线观看视频| 91精品久久久久久久久99蜜臂| 国内成人自拍视频| 国产精品久久久久久久久动漫 | 亚洲成人黄色小说| 亚洲精品在线三区| 在线观看日韩高清av| 精品一区二区久久久| 亚洲免费高清视频在线| 欧美一区二区福利在线| av资源网一区| 蜜桃久久久久久| √…a在线天堂一区| 91精品国产麻豆国产自产在线| 国产成人在线视频免费播放| 亚洲小少妇裸体bbw| ww亚洲ww在线观看国产| 91精彩视频在线观看| 国产乱码精品一区二区三| 一区二区三区波多野结衣在线观看| 日韩精品中文字幕一区| 91美女福利视频| 国产福利一区二区三区| 日韩va欧美va亚洲va久久| 亚洲精品视频在线观看免费| 欧美精品一区二区三区蜜桃视频| 在线观看91精品国产入口| 国v精品久久久网| 久色婷婷小香蕉久久| 亚洲第一二三四区| 国产精品二三区| 国产亚洲一区二区三区四区 | 2021国产精品久久精品| 欧美日韩精品欧美日韩精品一| 粉嫩一区二区三区性色av| 乱一区二区av| 午夜av电影一区| 一区二区三区在线观看网站| 中文在线一区二区| 久久久91精品国产一区二区精品 | 日本不卡视频在线| 午夜免费久久看| 一区二区三区不卡视频 | 日韩福利电影在线| 亚洲国产毛片aaaaa无费看| 日韩美女久久久| 《视频一区视频二区| 国产欧美日韩三级| 欧美精品一区二区三区在线| 欧美一三区三区四区免费在线看 | 在线免费观看不卡av| 99精品视频一区二区三区| 成人免费三级在线| 波多野结衣在线aⅴ中文字幕不卡| 国产精品羞羞答答xxdd| 国产精品亚洲人在线观看| 国产成人欧美日韩在线电影| 国产成人日日夜夜| 99久久婷婷国产精品综合| 成人黄页在线观看| 99re66热这里只有精品3直播| av在线一区二区三区| 一本一道久久a久久精品| 色综合久久88色综合天天免费| 色综合视频在线观看| 在线观看免费成人| 欧美日韩精品三区| 欧美一卡二卡在线| 久久综合九色综合欧美亚洲| 久久人人97超碰com| 国产精品免费视频观看| 国产精品久久久久久妇女6080| 亚洲人成小说网站色在线 | 亚洲欧洲日本在线| 一区二区三区在线视频播放 | 国产成人免费视频网站| 91在线你懂得| 欧美日韩大陆在线| 久久五月婷婷丁香社区| 国产精品国产三级国产普通话蜜臀 | 国产精品国产自产拍高清av王其| 亚洲视频免费看| 午夜激情久久久| 国产一区二区不卡| 91免费版在线| 日韩午夜小视频| 中文字幕一区二区三中文字幕| 亚洲欧美偷拍三级| 久久99国产乱子伦精品免费| 国产成人午夜精品影院观看视频 | 97se亚洲国产综合自在线| 欧美日韩一区在线| 久久久美女毛片| 亚洲一区日韩精品中文字幕| 美女视频黄 久久| 93久久精品日日躁夜夜躁欧美| 欧美日本一道本| 国产精品污网站| 麻豆精品在线播放| 波多野结衣的一区二区三区| 日韩一区二区高清| 亚洲欧美一区二区不卡| 精品一区二区三区av| 欧洲av在线精品| 欧美精品一区二区三区在线 | 亚洲免费av网站| 国内外成人在线视频| 在线免费观看成人短视频| 亚洲精品一区二区三区在线观看| 亚洲精品国产高清久久伦理二区| 狠狠久久亚洲欧美| 欧美日韩dvd在线观看| 中文字幕成人av| 麻豆精品一二三| 欧美色图天堂网| 亚洲欧洲另类国产综合| 精品无人区卡一卡二卡三乱码免费卡 | 亚洲综合一区二区三区| 国产电影一区二区三区| 91精品国产美女浴室洗澡无遮挡| 亚洲色欲色欲www| 成人免费黄色大片| 久久久久久99精品| 老司机免费视频一区二区| 欧美性猛交xxxx黑人交| 亚洲激情中文1区| www.在线欧美| 国产精品青草综合久久久久99| 精品午夜久久福利影院| 日韩写真欧美这视频| 视频一区在线视频| 欧美性猛交xxxx黑人交| 亚洲一区二区综合| 色噜噜偷拍精品综合在线| 日韩毛片高清在线播放| 北条麻妃国产九九精品视频| 国产欧美精品在线观看| 久久成人羞羞网站| 久久综合九色综合97婷婷| 激情综合色播激情啊| 久久婷婷色综合|