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

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

?? ganzhidlg.cpp

?? 神經網絡感知器做的分類器的源碼
?? CPP
字號:
// ganzhiDlg.cpp : implementation file
//

#include "stdafx.h"
#include "ganzhi.h"
#include "ganzhiDlg.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)
	//}}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)
		// No message handlers
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CGanzhiDlg dialog

CGanzhiDlg::CGanzhiDlg(CWnd* pParent /*=NULL*/)
	: CDialog(CGanzhiDlg::IDD, pParent)
{
	//{{AFX_DATA_INIT(CGanzhiDlg)
	m_epochs = 200;
	m_eta = 0.75;
	//}}AFX_DATA_INIT
	// Note that LoadIcon does not require a subsequent DestroyIcon in Win32
	m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
}

CGanzhiDlg::~CGanzhiDlg()
{
	if (m_pSample2 != NULL) 
	{
		for(int i=0; i<m_pointNum; i++)
		{
			delete[] m_pSample2[i];
		}
	}

	if (m_pType2 != NULL) 
	{
		delete m_pType2;
	}
}

void CGanzhiDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CGanzhiDlg)
	DDX_Text(pDX, IDC_EDIT_EPOCHS, m_epochs);
	DDX_Text(pDX, IDC_EDIT_ETA, m_eta);
	//}}AFX_DATA_MAP
}

BEGIN_MESSAGE_MAP(CGanzhiDlg, CDialog)
	//{{AFX_MSG_MAP(CGanzhiDlg)
	ON_WM_SYSCOMMAND()
	ON_WM_PAINT()
	ON_WM_QUERYDRAGICON()
	ON_BN_CLICKED(IDC_BTN_SELECT, OnBtnSelect)
	ON_BN_CLICKED(IDC_BTN_TEST, OnBtnTest)
	ON_BN_CLICKED(IDC_BTN_TRAIN, OnBtnTrain)
	ON_BN_CLICKED(IDC_BTN_CLEAR, OnBtnClear)
	ON_BN_CLICKED(IDC_RADIO_RED, OnRadioRed)
	ON_BN_CLICKED(IDC_RADIO_BLUE, OnRadioBlue)
	ON_WM_LBUTTONDOWN()
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CGanzhiDlg message handlers

BOOL CGanzhiDlg::OnInitDialog()
{
	CDialog::OnInitDialog();

	// Add "About..." menu item to system menu.

	// 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);
		}
	}

	// Set the icon for this dialog.  The framework does this automatically
	//  when the application's main window is not a dialog
	SetIcon(m_hIcon, TRUE);			// Set big icon
	SetIcon(m_hIcon, FALSE);		// Set small icon
	
	// TODO: Add extra initialization here
	m_bDrawPoint = FALSE;
	m_bTest = FALSE;
	m_bTrain = FALSE;
	m_colour = -1;
	memset(m_pointArray, 0, sizeof(double)*200);
	memset(m_pointType, 0, sizeof(double)*100);
	m_pointNum = 0;

	CWnd *pWnd;
	CRect rect;
    pWnd = GetDlgItem(IDC_DRAWMAP);   
	pWnd->GetWindowRect(&rect);
	m_point.x = rect.left;
	m_point.y = rect.top - 20;
	m_point2.x = rect.right;
	m_point2.y = rect.bottom - 20;
	m_line_start.x = 0;
	m_line_start.y = 0;
	m_line_end.x = 0;
	m_line_end.y = 0;
	m_pType2 = NULL;
	m_pSample2 = NULL;

	return TRUE;  // return TRUE  unless you set the focus to a control
}

void CGanzhiDlg::OnSysCommand(UINT nID, LPARAM lParam)
{
	if ((nID & 0xFFF0) == IDM_ABOUTBOX)
	{
		CAboutDlg dlgAbout;
		dlgAbout.DoModal();
	}
	else
	{
		CDialog::OnSysCommand(nID, lParam);
	}
}

// If you add a minimize button to your dialog, you will need the code below
//  to draw the icon.  For MFC applications using the document/view model,
//  this is automatically done for you by the framework.

void CGanzhiDlg::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
	{
		CDialog::OnPaint();
	}

	if (m_pointNum > 0) 
	{
		CDC *pDC = GetDC();
		CPen RedPen(PS_SOLID, 1, RGB(255, 0, 0));
		CPen BlackPen(PS_SOLID, 1, RGB(0, 0, 0));	

		for(int i=0; i<m_pointNum; i++)
		{
			if (m_pointType[i] == -1) 
			{
				pDC->SelectObject(BlackPen);
			}
			else
			{
				pDC->SelectObject(RedPen);	
			}

			pDC->Ellipse((int)(m_pointArray[i][0] + m_point.x - 5), (int)(m_pointArray[i][1] + m_point.y - 5), (int)(m_pointArray[i][0] + m_point.x + 5), (int)(m_pointArray[i][1] + m_point.y + 5));
		}
		ReleaseDC(pDC);
	}

	if(m_bTrain)
	{
		CDC *pDC = GetDC();
		CPen GreenPen(PS_SOLID, 1, RGB(0, 255, 0));
		pDC->SelectObject(GreenPen);
		pDC->MoveTo(m_line_start);
		pDC->LineTo(m_line_end);
		ReleaseDC(pDC);
	}
}

// The system calls this to obtain the cursor to display while the user drags
//  the minimized window.
HCURSOR CGanzhiDlg::OnQueryDragIcon()
{
	return (HCURSOR) m_hIcon;
}

void CGanzhiDlg::OnBtnSelect() 
{
	if (m_colour == -1) 
	{
		MessageBox("Please Choose Color");
		return;
	}

	if (m_bDrawPoint == FALSE) 
	{
		((CButton*)GetDlgItem(IDC_BTN_SELECT))->SetWindowText("Stop Input");
		m_bDrawPoint = TRUE;
	}
	else
	{
		((CButton*)GetDlgItem(IDC_BTN_SELECT))->SetWindowText("Start Input");
		m_bDrawPoint = FALSE;
	}
}

void CGanzhiDlg::OnBtnTest() 
{
	if (m_bTest == FALSE) 
	{
		((CButton*)GetDlgItem(IDC_BTN_TEST))->SetWindowText("Stop Test");
		m_bTest = TRUE;
	}
	else
	{
		((CButton*)GetDlgItem(IDC_BTN_TEST))->SetWindowText("Start Test");
		m_bTest = FALSE;
	}
}

void CGanzhiDlg::OnBtnTrain() 
{
	UpdateData(TRUE);
	
	if (m_pointNum == 0) 
	{
		MessageBox("Please Input First");
		return;
	}

	if(!m_bDrawPoint)
	{
		((CButton*)GetDlgItem(IDC_BTN_TEST))->SetWindowText("Stop Test");
		m_bTest = TRUE;
	}

	if(!m_bTrain)
	{
		((CButton*)GetDlgItem(IDC_BTN_TRAIN)->EnableWindow(FALSE));
		m_bTrain = TRUE;
	}

	m_pSample2 = new double*[m_pointNum];
	m_pType2 = new double[m_pointNum];

	for (int i = 0; i < m_pointNum; i++)
	{
		m_pSample2[i] = new double[2];
	}

	for(int iTemp=0; iTemp<m_pointNum; iTemp++)
	{
		m_pSample2[iTemp][0] = m_pointArray[iTemp][0];
		m_pSample2[iTemp][1] = m_pointArray[iTemp][1];
	}
	for(int m=0; m<m_pointNum; m++)
	{
		m_pType2[m] = m_pointType[m];
	}
	
	pPerception = new CPerception(m_pointNum, 2, m_pSample2, m_pType2, m_epochs, m_eta);
	pPerception->Train();
	
	CString strTemp;
	strTemp.Format("%fX + %fY + %f", (pPerception->GetW()[0]), (pPerception->GetW()[1]), (pPerception->Getb()));
	MessageBox(strTemp.GetBuffer(strTemp.GetLength()));

	CDC *pDC = GetDC();
	CPen pen(PS_SOLID, 1, RGB(0, 255, 0));
	pDC->SelectObject(pen);

	m_line_start.x = m_point.x;
	m_line_start.y = (long)(m_point.y + -pPerception->Getb() / pPerception->GetW()[1]);
	m_line_end.x = m_point2.x;
	m_line_end.y = (long)(-(pPerception->Getb() + (m_point2.x - m_point.x) * pPerception->GetW()[0]) / pPerception->GetW()[1]);
	pDC->MoveTo(m_line_start);
	pDC->LineTo(m_line_end);

}

void CGanzhiDlg::OnBtnClear() 
{
	if (m_pSample2 != NULL) 
	{
		for(int i=0; i<m_pointNum; i++)
		{
			delete[] m_pSample2[i];
		}

		m_pSample2 = NULL;
	}
	
	if (m_pType2 != NULL) 
	{
		delete m_pType2;
		m_pType2 = NULL;
	}

	((CButton*)GetDlgItem(IDC_BTN_TEST))->SetWindowText("Start Test");
	m_bTest = FALSE;
	((CButton*)GetDlgItem(IDC_BTN_SELECT))->SetWindowText("Start Input");
	m_bDrawPoint = FALSE;
	((CButton*)GetDlgItem(IDC_BTN_TRAIN)->EnableWindow(TRUE));
	m_bTrain = FALSE;
	m_pointNum = 0;
	Invalidate();
}

void CGanzhiDlg::OnRadioRed() 
{
	m_colour = 1;
}

void CGanzhiDlg::OnRadioBlue() 
{
	m_colour = 2;
}

void CGanzhiDlg::OnLButtonDown(UINT nFlags, CPoint point) 
{
	if (m_bDrawPoint == TRUE && m_bTest == FALSE && m_bTrain == FALSE) 
	{
		if(point.x < m_point.x || point.x > m_point2.x || point.y < m_point.y || point.y > m_point2.y)
			return;

		CPen pen;
		if (m_colour == 1) 
		{
			pen.CreatePen(PS_SOLID, 1, RGB(255, 0, 0));
			m_pointType[m_pointNum] = 1;
		}
		else if(m_colour == 2)
		{
			pen.CreatePen(PS_SOLID, 1, RGB(0, 0, 0));
			m_pointType[m_pointNum] = -1;
		}
		else
		{
			MessageBox("Please Choose Color!!");
			return;
		}
		
		CDC *pDC = GetDC();
		pDC->SelectObject(pen);
		pDC->Ellipse(point.x - 5, point.y - 5, point.x + 5, point.y + 5);

		m_pointArray[m_pointNum][0] = point.x - m_point.x;
		m_pointArray[m_pointNum][1] = point.y - m_point.y;
		m_pointNum++;

		ReleaseDC(pDC);
	}

	if (m_bTest)
	{
		double temp = 0;
		CString strTemp;
		temp = (pPerception->m_pBias + (point.x - m_point.x) * pPerception->m_pWeight[0] + (point.y - m_point.y) * pPerception->m_pWeight[1]);
		if (temp >= 0)
		{
			strTemp.Format("This sample is in A class--Red");
			MessageBox(strTemp.GetBuffer(strTemp.GetLength()));
		}	
		else
		{
			strTemp.Format("This sample is in B class--Black");
			MessageBox(strTemp.GetBuffer(strTemp.GetLength()));
		}
	}
	
	CDialog::OnLButtonDown(nFlags, point);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩亚洲欧美一区二区三区| 97精品电影院| 日韩综合在线视频| 亚洲一区二区在线观看视频| 亚洲欧洲色图综合| 国产精品伦一区| 亚洲麻豆国产自偷在线| 一区二区三区产品免费精品久久75| 日韩一区在线播放| 亚洲国产综合在线| 日韩精品福利网| 久久丁香综合五月国产三级网站| 免费成人av在线| 国产裸体歌舞团一区二区| 国产精品主播直播| 91在线视频观看| 欧美性大战xxxxx久久久| 欧美日本韩国一区二区三区视频| 欧美三级中文字幕| 欧美va亚洲va| 国产精品对白交换视频| 伊人色综合久久天天人手人婷| 亚洲精品久久久蜜桃| 三级影片在线观看欧美日韩一区二区 | 国产精品美女一区二区| 亚洲激情在线激情| 蜜乳av一区二区| 国产九色精品成人porny| 99re8在线精品视频免费播放| 欧美性大战久久久久久久蜜臀 | 国产精品久久久久久久蜜臀| 亚洲综合另类小说| 精品一区二区三区免费毛片爱 | 欧美日韩aaa| 久久久精品tv| 亚洲图片欧美色图| 丁香婷婷综合激情五月色| 欧美视频完全免费看| 国产亚洲精品精华液| 亚洲激情六月丁香| 国产一区二区导航在线播放| av电影在线观看一区| 欧美日韩国产影片| 国产精品久久久久影院亚瑟| 日韩影院免费视频| 日本韩国一区二区三区视频| 久久精品在这里| 日日夜夜精品视频天天综合网| 国产成人免费av在线| 欧美一区二区视频在线观看 | 国产三级精品三级| 无码av免费一区二区三区试看| 国产成人在线视频网址| 欧美一区二区黄色| 亚洲在线观看免费| 91老师国产黑色丝袜在线| 久久久精品天堂| 激情久久久久久久久久久久久久久久| 95精品视频在线| 成人欧美一区二区三区| 国产成人精品在线看| 精品国产不卡一区二区三区| 日韩精品一二区| 欧美偷拍一区二区| 亚洲婷婷综合色高清在线| 国产.欧美.日韩| 国产亚洲制服色| 国产精品综合在线视频| 精品国产成人系列| 国产一区二区在线电影| 精品久久人人做人人爰| 激情五月婷婷综合| 精品国产伦一区二区三区免费| 日日欢夜夜爽一区| 91精品国产黑色紧身裤美女| 亚洲bt欧美bt精品777| 欧美日韩午夜影院| 青草国产精品久久久久久| 日韩午夜激情av| 美女视频网站久久| 精品国产一区二区三区不卡 | 精品国产一区二区国模嫣然| 久久国产精品色婷婷| 久久欧美一区二区| 国产精品一品二品| 中文字幕第一区综合| 97久久超碰精品国产| 一区二区三区四区激情| 欧美精品一级二级三级| 日本成人在线不卡视频| 久久午夜免费电影| 成人av网站免费观看| 伊人夜夜躁av伊人久久| 欧美精品第一页| 成人做爰69片免费看网站| 亚洲欧美偷拍卡通变态| 欧美日韩小视频| 激情综合网激情| 最新日韩av在线| 欧美日韩视频在线第一区| 精品一二三四区| 亚洲嫩草精品久久| 欧美videos大乳护士334| 不卡视频在线观看| 亚洲成人av在线电影| 久久精品免费在线观看| 欧美色倩网站大全免费| 国内久久婷婷综合| 亚洲一级二级三级在线免费观看| 日韩一区二区电影| 99久久免费视频.com| 免费的国产精品| ㊣最新国产の精品bt伙计久久| 69堂精品视频| av不卡一区二区三区| 秋霞午夜鲁丝一区二区老狼| 中文字幕亚洲在| 欧美一区二区免费| 91美女片黄在线观看91美女| 精品一区二区精品| 亚洲第一电影网| 亚洲免费观看高清完整| 精品国产亚洲一区二区三区在线观看| 91亚洲永久精品| 国产主播一区二区三区| 五月天一区二区三区| 国产精品三级视频| 久久久影视传媒| 国产亚洲综合色| 欧美一三区三区四区免费在线看 | 一区二区久久久久| 国产视频视频一区| 欧美一区二区视频在线观看2020| www.日韩大片| 国产河南妇女毛片精品久久久 | 亚洲一区二区三区不卡国产欧美| 精品欧美一区二区三区精品久久 | 欧美亚洲国产bt| av一区二区久久| 国产成人av电影在线播放| 精品一区二区精品| 精品一区二区精品| 久久99久久久久| 久久精品国产亚洲一区二区三区| 亚洲成av人在线观看| 亚洲成人第一页| 偷拍日韩校园综合在线| 天天色 色综合| 亚洲18女电影在线观看| 午夜精品久久久久久不卡8050| 亚洲美女区一区| 亚洲一区二区三区四区在线免费观看 | 欧美一区二区女人| 6080日韩午夜伦伦午夜伦| 欧美日本一区二区三区四区| 欧美日韩一区三区| 欧美男人的天堂一二区| 欧美顶级少妇做爰| 欧美一级在线观看| 日韩欧美在线综合网| 精品国产凹凸成av人导航| 久久久噜噜噜久久人人看 | 国产精品88av| 成人免费视频一区二区| 波多野结衣亚洲| 在线视频你懂得一区| 欧美浪妇xxxx高跟鞋交| 欧美成人激情免费网| 久久综合丝袜日本网| 亚洲gay无套男同| 麻豆精品精品国产自在97香蕉| 国模少妇一区二区三区| 国产精品1区2区| 色婷婷久久综合| 欧美一区二区三区人| 国产亚洲美州欧州综合国| 亚洲三级在线免费观看| 日韩国产精品久久久| 国产一区二区不卡老阿姨| 91美女精品福利| 日韩免费视频一区| 国产精品成人免费精品自在线观看| 一区二区三区视频在线观看| 午夜精品一区二区三区电影天堂 | 欧美日韩精品专区| 日韩亚洲欧美一区二区三区| 成人欧美一区二区三区白人| 爽爽淫人综合网网站| 国产精品一区一区三区| 一本久道久久综合中文字幕| 欧美一级片在线看| 综合亚洲深深色噜噜狠狠网站| 蜜臀精品一区二区三区在线观看| 岛国一区二区三区| 欧美美女网站色| 国产精品女同一区二区三区| 日本aⅴ免费视频一区二区三区 | www.欧美.com| 91精品啪在线观看国产60岁| 国产精品二三区|