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

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

?? nnbpdlg.cpp

?? 專家系統-神經網絡代碼
?? CPP
?? 第 1 頁 / 共 3 頁
字號:
		m_ctrlComboArithmetic.SetCurSel (-1);

		m_ctrlComboFunc.SetCurSel (-1);
	
		hWnd = ::GetDlgItem (this->m_hWnd, IDC_DEMO_DATA_INPUT);
		::SetWindowText (hWnd, _T(""));
	
		hWnd = ::GetDlgItem (this->m_hWnd, IDC_DEMO_SAVE_NETWORK);
		::SetWindowText (hWnd, _T(""));
	
		hWnd = ::GetDlgItem (this->m_hWnd, IDC_DEMO_SAVE_RESULT);
		::SetWindowText (hWnd, _T(""));

		hWnd = ::GetDlgItem (this->m_hWnd, IDC_SYSTEM_ERROR);
		::SetWindowText (hWnd, _T("0"));

		hWnd = ::GetDlgItem (this->m_hWnd, IDC_TRAIN_TIMES);
		::SetWindowText (hWnd, _T("0"));



	}
	else	// Fail to accomplish the task
	{		

		// 釋放全局變量所占的內存
		m_matrixDemoDataInput.InitializeZero ();

		m_matrixInputLayerValue.InitializeZero ();

		m_matrixInputToHideWeightValue.InitializeZero ();
		m_matrixHideLayerValveValue.InitializeZero ();
		m_matrixHideLayerOutput.InitializeZero ();
	
		m_matrixHideToOutputWeightValue.InitializeZero ();
		m_matrixOutputLayerValveValue.InitializeZero ();	
	
		m_matrixOutputLayerOutput.InitializeZero ();

		// ReInitialize the global value
		m_nInputLayerNumber = 0;
		m_nHideLayerNumber = 0;
		m_nOutputLayerNumber = 0;

		m_nComboFunc = -1;
		m_nComboArithmetic = -1;

		m_nSystemError = 0;
		m_nTrainTimes = 0;

		m_nSystemErrorLevel = SYSTEM_ERROR_LEVEL;
		m_nMaxTrainTimes = LOOP_MAX_TIMES;

		m_SystemErrorNew = MAX_SYSTEM_ERROR;
		m_SystemErrorOld = MAX_SYSTEM_ERROR;

		m_nStep = INIT_STEP;
		
		m_strDemoDataInput = TEXT("");
		m_strDemoSaveNetwork = TEXT("");
		m_strDemoSaveResult = TEXT("");

		::MessageBox (this->m_hWnd, _T("很抱歉,我未能完成您交給我的任務."), _T(":("),MB_OK | MB_ICONERROR);

		(CNNBPDlg *)GetDlgItem(IDC_STATE)->EnableWindow(TRUE);

		//*******************************************************************
		// handle the UI
		//
		CString strSystemErrorLevel;
		strSystemErrorLevel.Format ("%lf", m_nSystemErrorLevel);
		HWND hWnd = ::GetDlgItem (this->m_hWnd, IDC_SYSTEM_LEVEL);
		::SetWindowText (hWnd, (LPCTSTR)strSystemErrorLevel);

		CString strMaxTrainTimes;
		strMaxTrainTimes.Format ("%u", m_nMaxTrainTimes);
		hWnd = ::GetDlgItem (this->m_hWnd, IDC_MAX_TRAIN_TIMES);
		::SetWindowText (hWnd, (LPCTSTR)strMaxTrainTimes);

		hWnd = ::GetDlgItem (this->m_hWnd, IDC_INPUT_LAYER_NUMBER);
		::SetWindowText (hWnd, _T("0"));

		hWnd = ::GetDlgItem (this->m_hWnd, IDC_HIDE_LAYER_NUMBER);
		::SetWindowText (hWnd, _T("0"));

		hWnd = ::GetDlgItem (this->m_hWnd, IDC_OUTPUT_LAYER_NUMBER);
		::SetWindowText (hWnd, _T("0"));

		m_ctrlComboArithmetic.SetCurSel (-1);

		m_ctrlComboFunc.SetCurSel (-1);

		hWnd = ::GetDlgItem (this->m_hWnd, IDC_DEMO_DATA_INPUT);
		::SetWindowText (hWnd, _T(""));
	
		hWnd = ::GetDlgItem (this->m_hWnd, IDC_DEMO_SAVE_NETWORK);
		::SetWindowText (hWnd, _T(""));
	
		hWnd = ::GetDlgItem (this->m_hWnd, IDC_DEMO_SAVE_RESULT);
		::SetWindowText (hWnd, _T(""));

		hWnd = ::GetDlgItem (this->m_hWnd, IDC_SYSTEM_ERROR);
		::SetWindowText (hWnd, _T("0"));

		hWnd = ::GetDlgItem (this->m_hWnd, IDC_TRAIN_TIMES);
		::SetWindowText (hWnd, _T("0"));


		return false;

	}

	return true;
	

}


bool CNNBPDlg::SimulateData()
{
	(CNNBPDlg *)GetDlgItem(IDC_STATE)->EnableWindow(FALSE);

	if(!m_bSimulateDataFlag)
	{
		(CNNBPDlg *)GetDlgItem(IDC_STATE)->EnableWindow(TRUE);
		return false;
	}

	if(m_strSimuNetworkFold.IsEmpty ())
	{
		::MessageBox (this->m_hWnd, _T("你還沒選取提供網絡參數的文件的裝載路徑!"), _T(":("),MB_OK | MB_ICONWARNING);

		(CNNBPDlg *)GetDlgItem(IDC_STATE)->EnableWindow(TRUE);
		return false;
	}

	if(m_strSimuDataInput.IsEmpty ())
	{
		::MessageBox (this->m_hWnd, _T("你還沒選取用來仿真的數據文件的裝載路徑!"), _T(":("),MB_OK | MB_ICONWARNING);

		(CNNBPDlg *)GetDlgItem(IDC_STATE)->EnableWindow(TRUE);
		return false;
	}

	if(m_strSimuResult.IsEmpty ())
	{
		::MessageBox (this->m_hWnd, _T("你還沒選取最終仿真結果的數據文件的存放路徑!"), _T(":("),MB_OK | MB_ICONWARNING);

		(CNNBPDlg *)GetDlgItem(IDC_STATE)->EnableWindow(TRUE);
		return false;
	}

	// 裝載網絡參數文件
	m_matrixSimuNetwork.LoadDataFromFileSpecial(m_strSimuNetworkFold,
												m_matrixInputToHideWeightValue,
												m_matrixHideLayerValveValue,
												m_matrixHideToOutputWeightValue,
												m_matrixOutputLayerValveValue,
												m_nInputLayerNumber,
												m_nHideLayerNumber,
												m_nOutputLayerNumber,
												m_nComboArithmetic,
												m_nComboFunc);
	


	// 裝載仿真數據文件
	m_matrixDemoDataInput.LoadDataFromFile (m_strSimuDataInput);


	if( m_matrixDemoDataInput.GetMatrixColNumber () != m_nInputLayerNumber )
	{
		::MessageBox (this->m_hWnd, _T("待仿真數據文件的輸入層數目與網絡中的輸入層數目不相等!!!"), _T("錯誤!"), MB_OK | MB_ICONERROR);

		// 釋放全局變量所占的內存
		m_matrixSimuNetwork.InitializeZero ();

		m_matrixInputToHideWeightValue.InitializeZero ();
		m_matrixHideLayerValveValue.InitializeZero ();
		m_matrixHideToOutputWeightValue.InitializeZero ();
		m_matrixOutputLayerValveValue.InitializeZero ();

		m_matrixDemoDataInput.InitializeZero ();

		m_strSimuNetworkFold = TEXT("");
		m_strSimuDataInput = TEXT("");
		m_strSimuResult = TEXT("");
		

		m_nInputLayerNumber	= 0;
		m_nHideLayerNumber = 0;
		m_nOutputLayerNumber = 0;

		(CNNBPDlg *)GetDlgItem(IDC_STATE)->EnableWindow(TRUE);

		//*******************************************************************
		// Update the UI
		//
		HWND hWnd = ::GetDlgItem (this->m_hWnd, IDC_SIMU_NETWORK_FOLD);
		::SetWindowText (hWnd, _T(""));

		hWnd = ::GetDlgItem (this->m_hWnd, IDC_SIMU_DATA_INPUT);
		::SetWindowText (hWnd, _T(""));

		hWnd = ::GetDlgItem (this->m_hWnd, IDC_SIMU_RESULT);
		::SetWindowText (hWnd, _T(""));

		return false;

	}
	else // Successful!!!
	{
		// 前向計算
		switch(m_nComboArithmetic)
		{
		case 0: // LM Arithmetic Selected
			LMForwardCalculate( m_nInputLayerNumber,
								m_nHideLayerNumber,
								m_nOutputLayerNumber,
								m_bSimulateDataFlag,
								m_nComboFunc,
								m_matrixDemoDataInput,
								m_matrixInputLayerValue,
								m_matrixInputToHideWeightValue,
								m_matrixHideLayerValveValue,
								m_matrixHideLayerOutput,
								m_matrixHideToOutputWeightValue,
								m_matrixOutputLayerOutput,
								m_matrixOutputLayerValveValue
							 );

			break;

		case 1: // BP Arithmetic Selected
			BPForwardCalculate2(m_nInputLayerNumber,
								m_nHideLayerNumber,
								m_nOutputLayerNumber,
								m_bSimulateDataFlag,
								m_nComboFunc,
								m_matrixDemoDataInput,
								m_matrixInputLayerValue,
								m_matrixInputToHideWeightValue,
								m_matrixHideLayerValveValue,
								m_matrixHideLayerOutput,
								m_matrixHideToOutputWeightValue,
								m_matrixOutputLayerOutput,
								m_matrixOutputLayerValveValue
							 );

			break;

		default: // No Arithmetic Selected
			return false;

		}



		// 存儲模擬結果
		(m_matrixOutputLayerOutput.Transpose()).SaveDataToFile(m_strSimuResult);


		// 釋放全局變量所占的內存
		m_matrixSimuNetwork.InitializeZero ();

		m_matrixInputToHideWeightValue.InitializeZero ();
		m_matrixHideLayerValveValue.InitializeZero ();
		m_matrixHideToOutputWeightValue.InitializeZero ();
		m_matrixOutputLayerValveValue.InitializeZero ();

		m_matrixDemoDataInput.InitializeZero ();

		m_matrixHideLayerOutput.InitializeZero ();
		m_matrixOutputLayerOutput.InitializeZero ();

		m_strSimuNetworkFold = _T("");
		m_strSimuDataInput = _T("");
		m_strSimuResult = _T("");
		
		m_nComboFunc = -1;

		m_nInputLayerNumber	= 0;
		m_nHideLayerNumber = 0;
		m_nOutputLayerNumber = 0;
		
		::MessageBox (this->m_hWnd, _T("數據仿真結果保存成功!"), _T("恭喜!"), MB_OK);

		(CNNBPDlg *)GetDlgItem(IDC_STATE)->EnableWindow(TRUE);

		//*******************************************************************
		// Update the UI
		//
		HWND hWnd = ::GetDlgItem (this->m_hWnd, IDC_SIMU_NETWORK_FOLD);
		::SetWindowText (hWnd, _T(""));

		hWnd = ::GetDlgItem (this->m_hWnd, IDC_SIMU_DATA_INPUT);
		::SetWindowText (hWnd, _T(""));

		hWnd = ::GetDlgItem (this->m_hWnd, IDC_SIMU_RESULT);
		::SetWindowText (hWnd, _T(""));

	}


	return true;

}

void CNNBPDlg::ForwardCalculateInit()
{
	LMForwardCalculateInit( m_nInputLayerNumber,
							m_nHideLayerNumber,
							m_nOutputLayerNumber,
							m_matrixDemoDataInput,
							m_matrixInputLayerValue,
							m_matrixInputToHideWeightValue,
							m_matrixHideLayerValveValue,
							m_matrixHideToOutputWeightValue,
							m_matrixOutputLayerValveValue
							);	
	
}

bool CNNBPDlg::DemoDataTrainRepeat()
{
	bool	bReturn = false;

	switch( m_nComboArithmetic)
	{
	case 0: // LM Arithmetic Selected
		bReturn = LMDemoDataTrainRepeat (	m_nInputLayerNumber,
											m_nHideLayerNumber,
											m_nOutputLayerNumber,
											m_bSimulateDataFlag,
											m_nComboFunc,
											m_SystemErrorOld,
											m_SystemErrorNew,
											m_nSystemErrorLevel,
											m_nSystemError,
											m_nStep,
											m_nMaxTrainTimes,
											m_nTrainTimes,
											IDC_SYSTEM_ERROR,
											IDC_TRAIN_TIMES,
											this->m_hWnd,
											m_matrixDemoDataInput,
											m_matrixInputLayerValue,
											m_matrixInputToHideWeightValue,
											m_matrixHideLayerValveValue,
											m_matrixHideLayerOutput,
											m_matrixHideToOutputWeightValue,
											m_matrixOutputLayerOutput,
											m_matrixOutputLayerValveValue
										);

		break;


	case 1: // BP Arithmetic Selected
		bReturn = BPDemoDataTrainRepeat (	m_nInputLayerNumber,
											m_nHideLayerNumber,
											m_nOutputLayerNumber,
											m_bSimulateDataFlag,
											m_nComboFunc,
											m_SystemErrorOld,
											m_SystemErrorNew,
											m_nSystemErrorLevel,
											m_nSystemError,
											m_nStep,
											m_nMaxTrainTimes,
											m_nTrainTimes,
											IDC_SYSTEM_ERROR,
											IDC_TRAIN_TIMES,
											this->m_hWnd,
											m_matrixDemoDataInput,
											m_matrixInputLayerValue,
											m_matrixInputToHideWeightValue,
											m_matrixHideLayerValveValue,
											m_matrixHideLayerOutput,
											m_matrixHideToOutputWeightValue,
											m_matrixOutputLayerOutput,
											m_matrixOutputLayerValveValue
										 );

		break;

	default: // No Arithmetic Selected
		return bReturn;

	}

	return bReturn;

}



bool CNNBPDlg::SaveConstantStringToFile(CString& strFileName,CString& strConstantData)
{

	// Convert CString to LPCTSTR 
	LPCTSTR	lpszFileName = "";
			
	strFileName.TrimLeft ();
	strFileName.TrimRight ();
	lpszFileName = (LPCTSTR)strFileName;

	CStdioFile dataFile;

	if(!dataFile.Open (lpszFileName, CFile::modeCreate | CFile::modeNoTruncate | CFile::modeWrite | CFile::typeText))
	{
		::MessageBox(this->m_hWnd, _T("不能創建存儲網絡參數的文件!"), _T("錯誤!"), MB_OK | MB_ICONERROR);
		dataFile.Close ();
		return FALSE;
	}

	dataFile.SeekToEnd ();

	// Write data into the file
	char *pBuffer = new char[strConstantData.GetLength ()];

	memcpy(pBuffer,strConstantData,strConstantData.GetLength ());

	dataFile.Write (pBuffer,strConstantData.GetLength ());

	dataFile.Close ();
	return TRUE;

}


/////////////////////////////////////////////////////////////////////////////
// 工作線程過程
//
/////////////////////////////////////////////////////////////////////////////

ULONG __stdcall WorkThreadProc(LPVOID lParam)
{
	if(lParam == NULL)
		return -1;

	
	STHREADDATA	*pData = (STHREADDATA *)lParam;

	// Set the flag
	pData->pDlg->m_bStartFlag = true;

	

	if(pData->pDlg->m_bSimulateDataFlag)
	{
		pData->pDlg->SimulateData();
	}
	else
	{
		pData->pDlg->TrainingDemo();
	}	

	pData->pDlg->m_bStartFlag = false;

	delete pData;

	pData = 0;

	return 0;

}


void CAboutDlg::OnHelpdocument() 
{
	// TODO: Add your control notification handler code here

	DWORD		nBufferLength=256;
	TCHAR		lpBuffer[256];
	CString		m_strPath;

	GetCurrentDirectory(nBufferLength,lpBuffer);
	m_strPath = lpBuffer;
	m_strPath = m_strPath + '\\' + TEXT("Help.chm");
	HINSTANCE hHelpFile = ShellExecute (NULL,"open", m_strPath, NULL, NULL, SW_SHOWNORMAL);
	
	if((long)hHelpFile == ERROR_FILE_NOT_FOUND)
	{
		::MessageBox(this->m_hWnd, _T("幫助文件沒有找到,你是不是把它給刪了?"), _T("沒找到"), MB_ICONEXCLAMATION | MB_OK );
		return ;
	}
	
}

void CAboutDlg::OnLButtonDown(UINT nFlags, CPoint point) 
{
	// TODO: Add your message handler code here and/or call default

	CDialog::OnOK ();
	
	//CDialog::OnLButtonDown(nFlags, point);
}

void CNNBPDlg::OnStopTrain() 
{
	// TODO: Add your control notification handler code here
	DWORD dwExitCode = 0;
	::GetExitCodeThread (m_hThread, &dwExitCode);
	
	if(dwExitCode == STILL_ACTIVE)
	{
		::TerminateThread (m_hThread, (DWORD)0);

		CloseHandle (m_hThread);
		m_hThread = NULL;

		HWND hWnd = ::GetDlgItem (this->m_hWnd, IDC_SYSTEM_ERROR);
		::SetWindowText (hWnd, _T("0"));

		hWnd = ::GetDlgItem (this->m_hWnd, IDC_TRAIN_TIMES);
		::SetWindowText (hWnd, _T("0"));
	}

	
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
av电影天堂一区二区在线| 久久久三级国产网站| 成人激情开心网| 国产99久久久久| 国产成人日日夜夜| 丁香另类激情小说| 国产精品一区二区三区四区| 日韩国产欧美一区二区三区| 亚洲一级二级三级| 午夜欧美视频在线观看| 亚洲人成7777| 亚洲福利一区二区三区| 老司机午夜精品99久久| 国内偷窥港台综合视频在线播放| 精久久久久久久久久久| 成人av在线观| 91久久精品一区二区三| 欧美中文字幕不卡| 日韩免费观看高清完整版| 久久精品一区二区三区不卡| 中文字幕精品一区二区三区精品| 亚洲视频中文字幕| 视频一区二区不卡| 国产精品一二三| 91国产视频在线观看| 91精品国产综合久久久蜜臀粉嫩 | 日韩精品中午字幕| 国产亚洲美州欧州综合国| 1024国产精品| 蜜桃久久久久久| 99久久久精品免费观看国产蜜| 色婷婷综合激情| 日韩精品中午字幕| 亚洲精品福利视频网站| 国内精品久久久久影院薰衣草| 成人黄动漫网站免费app| 欧美酷刑日本凌虐凌虐| 国产精品初高中害羞小美女文| 一区二区高清在线| 国产激情精品久久久第一区二区 | 日韩一区二区三| 亚洲欧洲精品成人久久奇米网| 午夜精品国产更新| 97精品超碰一区二区三区| 欧美一区二区日韩| 夜夜夜精品看看| 国产不卡视频一区二区三区| 欧美一区二区三区四区高清| 中文字幕视频一区| 国产精品一卡二| 欧美一区在线视频| 一区二区三区色| 97久久精品人人做人人爽| 精品国产网站在线观看| 亚洲国产另类精品专区| 北岛玲一区二区三区四区| 337p亚洲精品色噜噜噜| 亚洲色图视频免费播放| 国产精品一区一区| 久久久美女毛片| 精品中文字幕一区二区小辣椒| 欧美日韩在线电影| 亚洲国产精品影院| 在线精品视频一区二区三四| 亚洲欧洲在线观看av| 国产福利视频一区二区三区| 日韩欧美一级在线播放| 天天av天天翘天天综合网色鬼国产| 色老汉一区二区三区| 亚洲视频你懂的| 色综合天天在线| 亚洲色图另类专区| 日本久久电影网| 一区二区三区四区国产精品| 99精品久久99久久久久| 亚洲三级视频在线观看| 一本久道久久综合中文字幕| 亚洲色图欧洲色图| 欧美日韩高清一区二区不卡| 性久久久久久久久久久久| 91麻豆精品国产91久久久久久| 视频一区中文字幕| 日韩欧美一区二区视频| 韩国av一区二区三区四区| 久久精品一区蜜桃臀影院| 成人丝袜视频网| 亚洲精品中文字幕乱码三区| 欧美在线观看一区二区| 全国精品久久少妇| 久久久蜜桃精品| av网站免费线看精品| 一区二区三区中文在线观看| 欧美精品在线视频| 国产一区二区在线影院| 精品欧美乱码久久久久久1区2区| 亚洲6080在线| 韩国中文字幕2020精品| 99精品1区2区| 亚洲柠檬福利资源导航| 男男视频亚洲欧美| 日韩精品自拍偷拍| 日韩精品一区二区三区在线观看| 日本成人中文字幕在线视频 | 亚洲综合在线免费观看| 欧美日韩一区二区三区不卡| 乱中年女人伦av一区二区| 国产日韩视频一区二区三区| 色综合色综合色综合| 日本亚洲三级在线| 国产精品成人在线观看| 欧美精品日日鲁夜夜添| 成人午夜av电影| 婷婷国产在线综合| 国产视频一区二区在线| 亚洲人123区| 91久久奴性调教| 国产又黄又大久久| 亚洲国产中文字幕| 中文字幕一区二区在线播放| 欧美日韩免费高清一区色橹橹 | 精品欧美一区二区在线观看| 成人av免费在线观看| 日本一区中文字幕| 亚洲日本护士毛茸茸| 国产亚洲福利社区一区| 69久久夜色精品国产69蝌蚪网| jlzzjlzz亚洲日本少妇| 国产一区二区三区高清播放| 日韩高清不卡在线| 亚洲综合小说图片| 成人免费小视频| 国产精品污网站| 久久久久亚洲综合| 日韩三级视频中文字幕| 欧美在线free| 日本国产一区二区| 91免费看`日韩一区二区| 国产成人综合亚洲网站| 极品少妇xxxx偷拍精品少妇| 视频一区视频二区在线观看| 亚洲精品久久嫩草网站秘色| 国产精品的网站| 国产精品久久久久久亚洲毛片| 精品福利二区三区| 精品国产免费久久| 精品福利在线导航| 2024国产精品视频| 欧美精品一区二区三区久久久| 日韩女优视频免费观看| 欧美一区中文字幕| 欧美成人女星排行榜| 欧美xxxxx牲另类人与| 精品国产免费一区二区三区香蕉| 精品免费一区二区三区| 精品第一国产综合精品aⅴ| 精品av综合导航| 国产欧美日本一区二区三区| 一区二区三区日韩精品视频| 夜夜嗨av一区二区三区| 亚洲.国产.中文慕字在线| 日日摸夜夜添夜夜添精品视频| 日本va欧美va精品发布| 久久不见久久见中文字幕免费| 久久机这里只有精品| 国产乱码一区二区三区| 成人午夜电影久久影院| 91香蕉视频在线| 91 com成人网| 久久久久久久久蜜桃| 中文字幕日本不卡| 亚洲午夜激情网站| 久久se精品一区精品二区| 国产乱码精品一区二区三区av| 97久久精品人人做人人爽| 欧美日韩不卡在线| 国产亚洲精品超碰| 一卡二卡欧美日韩| 韩国三级中文字幕hd久久精品| 成人综合在线网站| 欧美三级电影精品| 久久久久国产免费免费 | 欧美另类videos死尸| 日韩欧美第一区| 亚洲欧美福利一区二区| 青青草成人在线观看| 不卡视频在线看| 91精品国产综合久久国产大片| 国产女主播视频一区二区| 一区二区不卡在线播放| 国产精品一区三区| 欧美日韩国产经典色站一区二区三区 | 日本视频在线一区| 成人aaaa免费全部观看| 日韩三级精品电影久久久| 国产精品久久久久影院老司| 亚洲成人动漫av| 成人av资源网站| 精品福利视频一区二区三区| 亚洲国产视频直播| 成人丝袜高跟foot|