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

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

?? onrdlg.cpp

?? 脫機字符識別算法
?? CPP
字號:
/* ============================================= *\
 * File:		OnrDlg.cpp						 *
 * Description: 主對話框頭文件                   *
 *				包括所有的函數                   *
\* ============================================= */

#include "stdafx.h"
#include "Onr.h"
#include "OnrDlg.h"

#include <fstream.h>
#include <time.h>
#include <stdlib.h>

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

/////////////////////////////////////////////////////////////////////////////
// CAboutDlg dialog used for App About

class CAboutDlg : public CDialog
{
public:
	CAboutDlg();

// Dialog Data
	//{{AFX_DATA(CAboutDlg)
	enum { IDD = IDD_ABOUTBOX };
	//}}AFX_DATA

	// ClassWizard generated virtual function overrides
	//{{AFX_VIRTUAL(CAboutDlg)
	protected:
	virtual void DoDataExchange(CDataExchange* pDX);    // DDX/DDV support
	//}}AFX_VIRTUAL

// Implementation
protected:
	//{{AFX_MSG(CAboutDlg)
	virtual BOOL OnInitDialog();
	//}}AFX_MSG
	DECLARE_MESSAGE_MAP()
};

CAboutDlg::CAboutDlg() : CDialog(CAboutDlg::IDD)
{
	//{{AFX_DATA_INIT(CAboutDlg)
	//}}AFX_DATA_INIT
}

void CAboutDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CAboutDlg)
	//}}AFX_DATA_MAP
}

BEGIN_MESSAGE_MAP(CAboutDlg, CDialog)
	//{{AFX_MSG_MAP(CAboutDlg)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

BOOL CAboutDlg::OnInitDialog() 
{
	CDialog::OnInitDialog();
	
	return TRUE;
}

/////////////////////////////////////////////////////////////////////////////
// COnrDlg dialog

COnrDlg::COnrDlg(CWnd* pParent) : CDialog(COnrDlg::IDD, pParent) {
	//{{AFX_DATA_INIT(COnrDlg)
	//}}AFX_DATA_INIT

	m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
}

void COnrDlg::DoDataExchange(CDataExchange* pDX) {
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(COnrDlg)
	DDX_Control(pDX, IDC_TRAINSPIN, m_Trainspin);
	DDX_Control(pDX, IDC_TESTSPIN, m_Testspin);
	DDX_Control(pDX, IDC_TRAININFO, m_TrainInfo);
	DDX_Control(pDX, IDC_INFOBOX, m_cInfoBox);
	DDX_Control(pDX, IDC_TESTWINDOW, m_TestWindow);
	//}}AFX_DATA_MAP
}

BEGIN_MESSAGE_MAP(COnrDlg, CDialog)
	//{{AFX_MSG_MAP(COnrDlg)
	ON_WM_SYSCOMMAND()
	ON_WM_PAINT()
	ON_WM_QUERYDRAGICON()
	ON_BN_CLICKED(IDC_TRAIN, OnTrain)
	ON_BN_CLICKED(IDC_CLASSIFY, OnClassify)
	ON_NOTIFY(UDN_DELTAPOS, IDC_TRAINSPIN, OnDeltaposTrainspin)
	ON_NOTIFY(UDN_DELTAPOS, IDC_TESTSPIN, OnDeltaposTestspin)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

///////////////////////////////////////////////////////////////////////////////
// 初始化對話框
BOOL COnrDlg::OnInitDialog() 
{
	CDialog::OnInitDialog();

	// IDM_ABOUTBOX must be in the system command range.
	ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);
	ASSERT(IDM_ABOUTBOX < 0xF000);

	CMenu* pSysMenu = GetSystemMenu(FALSE);
	if (pSysMenu != NULL) 
	{
		CString strAboutMenu;
		strAboutMenu.LoadString(IDS_ABOUTBOX);
		if (!strAboutMenu.IsEmpty()) 
		{
			pSysMenu->AppendMenu(MF_SEPARATOR);
			pSysMenu->AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu);
		}
	}

	SetIcon(m_hIcon, TRUE);			// Set big icon
	SetIcon((HICON)(LoadImage(AfxGetResourceHandle(), 
		MAKEINTRESOURCE(IDR_MAINFRAME), IMAGE_ICON, 16, 16, 0)), FALSE);

	// 設置滾動條的范圍
	m_Testspin.SetRange(0,NN_NUMBERS-1);
	m_Trainspin.SetRange(0,NN_NUMBERS-1);
	m_Testspin.SetPos(0);
	m_Trainspin.SetPos(0);
	
	// 打開文件
	ifstream data("learn.dat", ios::nocreate);
	ifstream test("test.dat", ios::nocreate);

	// 檢查文件的有效性
	if (!test || !data) 
	{
		MessageBox("No learning or test data present.", "Cannot run...",
			MB_OK | MB_ICONERROR);
	}

	// 讀文件
	for(int i=0;i<NN_NUMBERS;i++) 
	{
		for(int j=0;j<NN_RESX * NN_RESY;j++) 
		{
			int onoff;
			test >> onoff;
			m_bTestData[i][j] = onoff;

			data >> onoff;
			m_bNumbers[i][j] = onoff;
		}
	}

	// 設置初始要畫的數字指針
	m_ipDrawNum = &m_bNumbers[0][0];

	return true;
}

void COnrDlg::OnSysCommand(UINT nID, LPARAM lParam) {
	if ((nID & 0xFFF0) == IDM_ABOUTBOX) 
	{
		CAboutDlg dlgAbout;

		dlgAbout.DoModal();
	}
	else 
	{
		CDialog::OnSysCommand(nID, lParam);
	}
}

void COnrDlg::OnPaint() 
{
	if (IsIconic())	{
		CPaintDC dc(this); // device context for painting

		SendMessage(WM_ICONERASEBKGND, (WPARAM) dc.GetSafeHdc(), 0);

		// Center icon in client rectangle
		int cxIcon = GetSystemMetrics(SM_CXICON);
		int cyIcon = GetSystemMetrics(SM_CYICON);
		CRect rect;
		GetClientRect(&rect);
		int x = (rect.Width() - cxIcon + 1) / 2;
		int y = (rect.Height() - cyIcon + 1) / 2;

		// Draw the icon
		dc.DrawIcon(x, y, m_hIcon);
	} else {
		CPaintDC dc(this);
		CDialog::OnPaint();

		// 這種方法畫矩形可能有點迂回,不過的確可以工作
		CRect rect;

		m_TestWindow.GetClientRect(&rect);
		m_TestWindow.ClientToScreen(&rect);
		ScreenToClient(&rect);
		dc.FrameRect(&rect, &CBrush(RGB(0,0,0)));
		rect.DeflateRect(1,1);
		dc.FillSolidRect(rect, RGB(255,255,255));

		// 畫數字
		DrawNumber(&dc, m_ipDrawNum, &rect);
	}
}

HCURSOR COnrDlg::OnQueryDragIcon() 
{
	return (HCURSOR) m_hIcon;
}

///////////////////////////////////////////////////////////
// 由于某些原因,如果采用"Maxinum Speed"優化將引起程序運行的
// 失敗,所以先關掉優化,在該段代碼結束后再打開優化功能
///////////////////////////////////////////////////////////

#pragma optimize( "", off )

//////////////////////////////////////////////////////////////////////////
//  訓練數據
void COnrDlg::OnTrain() 
{
	srand((unsigned)time(NULL));			// 設置隨機數
	m_cInfoBox.ResetContent();
	
	// 所有權值0初始化
	memset(&m_fWeights,0,sizeof(m_fWeights));

	// 產生一些帶有隨機噪聲的訓練數據
	m_cInfoBox.InsertString(-1, "Generating noisy data...");
	int num = 0;
	for (int i=0;i<NN_NUMBERS * NN_NOISY;i++) 
	{
		for(int j=0;j<NN_RESX * NN_RESY;j++) 
		{
			if (rand() % 100 < 7) 
			{
				m_iNoisy[i][j] = !m_bNumbers[num][j];
			} 
			else 
				m_iNoisy[i][j] = m_bNumbers[num][j];
		}
		
		if ((float)(i+1)/NN_NOISY == (i+1)/NN_NOISY && i != 0) 
			num++;
	}

	m_cInfoBox.InsertString(-1, "Learning...");

	RunNet(true);

	m_TrainInfo.SetWindowText("Complete...");
	m_cInfoBox.InsertString(-1,"Training Complete!");
	GetDlgItem(IDC_CLASSIFY)->EnableWindow(true);
}

///////////////////////////////////////////////////////////////////////////
// 畫數字
void COnrDlg::DrawNumber(CDC *dc, int *cell, CRect *rect) 
{
	// 下面的計算主要是使得數字畫在矩形筐的正中央
	CPoint tl;
	tl.x = rect->Width()/2 - (NN_RESX*10)/2;
	tl.y = rect->Height()/2 - (NN_RESY*10)/2;

	tl.Offset(rect->TopLeft());
	int ix = tl.x;
	
	// 產生一些圍繞數字的紅色虛線
	CPen pen;
	if (pen.CreatePen(PS_DOT, 1, RGB(127,0,0))) 
	{
		CPen *pOldPen = dc->SelectObject(&pen);

		CPoint pt1 = rect->TopLeft();
		CPoint pt2 = rect->BottomRight();
		dc->MoveTo(tl.x-5, tl.y-2);
		dc->LineTo(tl.x+NN_RESX*10+5, tl.y-2);
		dc->MoveTo(tl.x-5, tl.y+10*NN_RESY+1);
		dc->LineTo(tl.x+NN_RESX*10+5, tl.y+10*NN_RESY+1);
		dc->MoveTo(tl.x-2, tl.y-7);
		dc->LineTo(tl.x-2, tl.y+NN_RESY*10+7);
		dc->MoveTo(tl.x+NN_RESX*10+2, tl.y-7);
		dc->LineTo(tl.x+NN_RESX*10+2, tl.y+NN_RESY*10+7);

		dc->SelectObject(pOldPen);
	}

	// 顯示一些文本
	CRect format(tl.x+1, tl.y+NN_RESY*10+2,
				 tl.x+NN_RESX*10-1, tl.y+NN_RESY*10+18);
	if (m_bDisplayString) 
	{
		CFont fnt;
		if (fnt.CreatePointFont(80,"Arial")) 
		{
			CFont* pOldFont = dc->SelectObject(&fnt);

			dc->SetTextColor(RGB(0,0,127));
			dc->DrawText(m_Str,format,DT_CENTER);
			dc->SelectObject(pOldFont);
		}	
	}

	// 畫數字
	for(int i=0;i<NN_RESX*NN_RESY;i++) 
	{
		if ((*cell) == 1) 
		{
			dc->FillSolidRect(tl.x,tl.y,10,10,RGB(0,0,0));
		}
		tl.x += 10;
		if (tl.x == ix + 10*NN_RESX) 
		{
			tl.x = ix;
			tl.y += 10;
		}
		cell++;
	}
}

//////////////////////////////////////////////////////////////////////////////////
// 識別
void COnrDlg::OnClassify() 
{
	int pos = (BYTE)m_Testspin.GetPos();
	
	m_ipDrawNum = &m_bTestData[pos][0];
	InvalidateNumber();

	float d[NN_NUMBERS];
	for(int j=0;j<NN_NUMBERS;j++) 
	{
		d[j] = 0;
		for(int k=0;k<NN_RESX * NN_RESY;k++) 
		{
			d[j] += m_fWeights[j][k]*m_bTestData[pos][k];
		}
	}
	
	int bestind = 0;
	for(j=1;j<NN_NUMBERS;j++) 
		if (d[j] > d[bestind]) 
			bestind = j;

	// 計算畫文本的區域
	CRect size;
	m_TestWindow.GetClientRect(&size);
	int x = size.Width()/2  - (NN_RESX*10)/2;
	int y = size.Height()/2 - (NN_RESY*10)/2;
	CRect format(x,size.Height()-y+1, size.Width()-x, size.Height()-5);
	
	m_bDisplayString = true;
	GetText(m_Str, bestind+1);
}

/////////////////////////////////////////////////////////////////////////////
// 運行網絡
// 參數:training-為真時表示網絡出于訓練狀態
void COnrDlg::RunNet(bool training) 
{
	// 檢測帶有噪聲的數據
	float d[NN_NUMBERS];
	int cycles = 0;//初始化循環次數為0
	bool correct;

	do 
	{
		correct = true;
		for(int i=0;i<NN_NUMBERS * NN_NOISY;i++) 
		{
			for(int j=0;j<NN_NUMBERS;j++) 
			{
				d[j] = 0;
				for(int k=0;k<NN_RESX * NN_RESY;k++) 
				{
					d[j] += m_fWeights[j][k]*m_iNoisy[i][k];
				}
			}
			
			int bestind = 0;
			for(j=1;j<NN_NUMBERS;j++) 
				if (d[j] > d[bestind]) 
					bestind = j;
			
			int realval = (int)(i/NN_NOISY);
			if (bestind == realval) continue;
			
			if (training) 
			{
				CString result;
				result.Format("Guessed %d instead of %d.",bestind, realval);
				m_TrainInfo.SetWindowText(result);
				correct = false;
				
				for(j=0;j<NN_RESX * NN_RESY;j++) 
				{
					m_fWeights[bestind][j] -= m_iNoisy[i][j];
					m_fWeights[realval][j] += m_iNoisy[i][j];
				}
			}
		}
		
		SetDlgItemInt(IDC_ITERATE, ++cycles);
	} while (!correct && cycles <= NN_MAXITER);
	
	//如果循環次數太大還每得到結果則退出
	if (cycles >= NN_MAXITER) 
	{
		MessageBox("Training has timed-out.",
			"Error in Training", MB_OK | MB_ICONINFORMATION);
		return;
	}
}

//恢復系統優化
#pragma optimize( "", on )

////////////////////////////////////////////////////////////////////////
// 處理訓練數據的滾動條
void COnrDlg::OnDeltaposTrainspin(NMHDR* pNMHDR, LRESULT* pResult) 
{
	NM_UPDOWN* pNMUpDown = (NM_UPDOWN*)pNMHDR;
	int iPos = pNMUpDown->iPos;
	int iDelta = pNMUpDown->iDelta;
	
	m_bDisplayString = false;

	if ((iPos == 0 && iDelta == -1) || (iPos == NN_NUMBERS-1 && iDelta == 1)) 
	{
		if (iDelta == -1) 
		{
			m_ipDrawNum = &m_bNumbers[0][0];
			InvalidateNumber();
		} 
		else 
		{
			m_ipDrawNum = &m_bNumbers[NN_NUMBERS-1][0];
			InvalidateNumber();
		}
	} 
	else 
	{
		m_ipDrawNum = &m_bNumbers[iPos+iDelta][0];
		InvalidateNumber();
	}
	
	*pResult = 0;
}

//////////////////////////////////////////////////////////////////////////////////
// 處理測試數據的滾動條
void COnrDlg::OnDeltaposTestspin(NMHDR* pNMHDR, LRESULT* pResult) 
{
	NM_UPDOWN* pNMUpDown = (NM_UPDOWN*)pNMHDR;
	int iPos = pNMUpDown->iPos;
	int iDelta = pNMUpDown->iDelta;

	m_bDisplayString = false;

	if ((iPos == 0 && iDelta == -1) || (iPos == NN_NUMBERS-1 && iDelta == 1)) 
	{
		if (iDelta == -1) 
		{
			m_ipDrawNum = &m_bTestData[0][0];
			InvalidateNumber();
		} 
		else 
		{
			m_ipDrawNum = &m_bTestData[NN_NUMBERS-1][0];
			InvalidateNumber();
		}
	} 
	else 
	{
		m_ipDrawNum = &m_bTestData[iPos+iDelta][0];
		InvalidateNumber();
	}
	
	*pResult = 0;
}

//////////////////////////////////////////////////////////////////////////
// 得到數字相對應的文本
void COnrDlg::GetText(CString &str, int num) {
	switch (num) {
	case 1:
		str = "Result:1"; 
		break;
	case 2:
		str = "Result:2"; 
		break;
	case 3:
		str = "Result:3"; 
		break;
	case 4:
		str = "Result:4"; 
		break;
	case 5:
		str = "Result:5"; 
		break;
	case 6:
		str = "Result:6"; 
		break;
	case 7:
		str = "Result:7"; 
		break;
	case 8:
		str = "Result:8"; 
		break;
	case 9:
		str = "Result:9"; 
		break;
	default:
		str = "Undetermined";
	}
}

///////////////////////////////////////////////////////////////////////////////
// 強制重畫
void COnrDlg::InvalidateNumber() 
{
	CRect rect;
	
	m_TestWindow.GetClientRect(&rect);
	m_TestWindow.ClientToScreen(&rect);
	ScreenToClient(&rect);

	InvalidateRect(rect, false);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
在线亚洲一区二区| 国产精品久久看| 精品99久久久久久| 久久精品一区八戒影视| 秋霞电影网一区二区| 麻豆91小视频| 972aa.com艺术欧美| 欧美在线看片a免费观看| 91精品在线观看入口| 精品国产免费人成在线观看| 欧美高清在线一区| 亚洲va韩国va欧美va| 美女网站一区二区| 成人avav影音| 欧美日韩美少妇| 久久色成人在线| 一区二区三区国产精华| 紧缚奴在线一区二区三区| 成人夜色视频网站在线观看| 91国偷自产一区二区开放时间 | 亚洲va在线va天堂| 成人性生交大片免费看中文| 欧美少妇xxx| 中文天堂在线一区| 男女男精品网站| 97久久精品人人爽人人爽蜜臀| 欧美高清视频一二三区 | 丁香六月久久综合狠狠色| 日本韩国欧美三级| 日本一区二区久久| 九色综合狠狠综合久久| 欧美综合一区二区| 国产精品久久久久久久蜜臀| 激情文学综合网| 51久久夜色精品国产麻豆| 亚洲天堂精品视频| 91色porny在线视频| 国产亚洲一区字幕| 激情久久五月天| 日韩三级在线免费观看| 日本亚洲欧美天堂免费| 欧美日韩午夜在线| 亚洲伊人色欲综合网| 91污片在线观看| 亚洲视频小说图片| 99精品国产99久久久久久白柏| 国产欧美日韩在线看| 国产伦精品一区二区三区免费 | 中文字幕日韩av资源站| 国产一区二区成人久久免费影院| 欧美xxxxx裸体时装秀| 日韩av一区二区在线影视| 中文字幕亚洲电影| av一本久道久久综合久久鬼色| 久久蜜桃一区二区| 成人黄色在线看| 亚洲视频在线一区二区| 欧美午夜一区二区三区免费大片| 亚洲自拍偷拍欧美| 日韩午夜三级在线| 国产精品一区二区不卡| 国产精品传媒在线| 欧美日韩一区二区三区四区五区| 午夜精品久久久久久久久久| 在线综合+亚洲+欧美中文字幕| 日韩**一区毛片| 欧美韩日一区二区三区四区| 91丨九色丨尤物| 美美哒免费高清在线观看视频一区二区 | 欧美日韩国产欧美日美国产精品| 婷婷成人激情在线网| 国产人伦精品一区二区| 欧美精品欧美精品系列| 国产成人小视频| 日韩高清电影一区| 中文字幕一区免费在线观看| 欧美日韩电影在线| 99久久久久免费精品国产 | 国产午夜精品久久久久久久| 欧美色图第一页| 成人少妇影院yyyy| 久久精品国产精品亚洲综合| 中文字幕在线一区免费| 日韩欧美一级片| 欧美色视频一区| 91蜜桃网址入口| 精品国偷自产国产一区| 欧美在线|欧美| 92精品国产成人观看免费| 韩国成人福利片在线播放| 天堂资源在线中文精品| 亚洲欧美色综合| 中文字幕亚洲在| 国产精品久久久久久久久久免费看| 日韩免费性生活视频播放| 欧美在线视频日韩| 在线观看一区二区精品视频| 91丨九色丨蝌蚪丨老版| 色综合视频在线观看| 99久久精品国产一区二区三区| 精品一区二区三区av| 久久99国产乱子伦精品免费| 日韩avvvv在线播放| 日产国产欧美视频一区精品| 日本美女视频一区二区| 久久国产精品99久久久久久老狼| eeuss国产一区二区三区| 中文字幕欧美日韩一区| 国产真实乱子伦精品视频| 日韩美女视频19| 国产精品毛片无遮挡高清| 国产欧美日韩在线| 欧美激情在线一区二区三区| 亚洲欧洲精品一区二区三区不卡| 国产精品电影一区二区三区| 国产精品夫妻自拍| 亚洲午夜国产一区99re久久| 午夜精品在线看| 国产一区视频网站| 99精品视频在线播放观看| 欧美猛男超大videosgay| 欧美一三区三区四区免费在线看| 欧美精品一区二区三区在线播放| 欧美极品少妇xxxxⅹ高跟鞋| 亚洲综合另类小说| 毛片一区二区三区| 91视频你懂的| 日韩欧美一区二区不卡| 亚洲免费av在线| 黑人巨大精品欧美黑白配亚洲| 99精品久久只有精品| 日韩女优制服丝袜电影| 成人教育av在线| 91福利在线免费观看| 久久美女艺术照精彩视频福利播放| 亚洲精选视频在线| 国产高清久久久| 欧美一区二区三区在| 亚洲精品亚洲人成人网 | 国产美女精品一区二区三区| 色偷偷成人一区二区三区91| 久久精品人人爽人人爽| 日韩电影在线免费观看| 欧美在线一二三| 亚洲人成精品久久久久| 国产v综合v亚洲欧| 久久亚洲精品小早川怜子| 日精品一区二区三区| 欧美日韩一卡二卡三卡 | 亚洲视频在线观看一区| 成人黄色在线视频| 国产精品青草久久| 成人一级视频在线观看| 国产欧美一区二区精品久导航| 日韩精品电影一区亚洲| 欧美夫妻性生活| 日日摸夜夜添夜夜添亚洲女人| 99久久99久久免费精品蜜臀| 国产精品久久久久久久久免费相片| 国产福利一区在线观看| 国产欧美一区二区精品仙草咪| 国产精品2024| 亚洲三级在线看| 欧美日韩国产综合一区二区三区| 午夜国产精品一区| 日韩网站在线看片你懂的| 久久99久久99小草精品免视看| 久久先锋影音av鲁色资源| 久久爱另类一区二区小说| 国产农村妇女精品| 91免费视频网址| 日本大胆欧美人术艺术动态 | 亚洲另类色综合网站| 欧美老年两性高潮| 狠狠色丁香久久婷婷综| 国产精品私人影院| 欧美精品三级日韩久久| 日韩美女视频在线| 国产成人h网站| 亚洲va欧美va人人爽午夜| 久久久久9999亚洲精品| 91福利在线免费观看| 国产精品18久久久| 亚洲一区在线观看免费观看电影高清 | www国产成人免费观看视频 深夜成人网| 成人午夜av在线| 日韩精品电影在线观看| 亚洲欧洲av一区二区三区久久| 在线播放日韩导航| 91丨porny丨首页| 狠狠色丁香婷婷综合| 五月天中文字幕一区二区| 久久精品人人爽人人爽| 777久久久精品| 欧美三级电影精品| 91在线一区二区三区| 国产激情精品久久久第一区二区| 午夜视频在线观看一区二区三区| 综合在线观看色| 日本一区二区三区视频视频|