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

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

?? knnbpdlg.cpp

?? KNN和BP的算法實現。輸入一系列的樣本值
?? CPP
字號:
// KNNBPDlg.cpp : implementation file
//

#include "stdafx.h"
#include "KNNBP.h"
#include "KNNBPDlg.h"
#include <math.h>
#ifdef _DEBUG
#define new DEBUG_NEW
#endif


// CAboutDlg dialog used for App About

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

// Dialog Data
	enum { IDD = IDD_ABOUTBOX };

	protected:
	virtual void DoDataExchange(CDataExchange* pDX);    // DDX/DDV support

// Implementation
protected:
	DECLARE_MESSAGE_MAP()
};

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

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

BEGIN_MESSAGE_MAP(CAboutDlg, CDialog)
END_MESSAGE_MAP()


// CKNNBPDlg dialog




CKNNBPDlg::CKNNBPDlg(CWnd* pParent /*=NULL*/)
	: CDialog(CKNNBPDlg::IDD, pParent)
{
	m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
}

void CKNNBPDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
}

BEGIN_MESSAGE_MAP(CKNNBPDlg, CDialog)
	ON_WM_SYSCOMMAND()
	ON_WM_PAINT()
	ON_WM_QUERYDRAGICON()
	//}}AFX_MSG_MAP
	ON_BN_CLICKED(IDC_KNN, &CKNNBPDlg::OnBnClickedKnn)
	ON_BN_CLICKED(IDC_BP, &CKNNBPDlg::OnBnClickedBp)
END_MESSAGE_MAP()


// CKNNBPDlg message handlers

BOOL CKNNBPDlg::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

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

void CKNNBPDlg::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 CKNNBPDlg::OnPaint()
{
	if (IsIconic())
	{
		CPaintDC dc(this); // device context for painting

		SendMessage(WM_ICONERASEBKGND, reinterpret_cast<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();
	}
	int data[20][3] = {
		42,  208,  1,
		30, 69, 0,
		69, 12, 0,
		51,  232,  1,
		95,  104,  0,
		196, 75,  0,
		288, 47,   1,
		65,  35,   1,
		239, 115, 1,
		93, 118,  0,
		204, 217,  1,
		79,  45,   1,
		40,  259, 0,
		40,  85,   0,
		118, 216,  1,
		9,   31,   0,
		30, 109, 1,
		41,  50, 1,
		36,  255,  0,
		216, 108,  1
	};
    CButton* pKnn = (CButton*)GetDlgItem(IDC_KNN);
	CButton* pBp = (CButton*)GetDlgItem(IDC_BP);
	//initialization
	SolidBrush brush(Color(255, 255, 255, 255));//white
	Pen pen(Color(255, 0, 0, 0), 1);//black
	pen.SetEndCap(LineCapArrowAnchor);
	Pen redPen(Color(255, 156, 0, 156), 1);//red
	Pen greenPen(Color(255, 50, 156, 150), 1);//green
	SolidBrush redBrush(Color(255, 255, 0, 0));//redpoint
	SolidBrush greenBrush(Color(255, 0, 255, 0));//greenpoint
	CRect rect;
	CStatic* pWnd = (CStatic*)GetDlgItem(IDC_STATIC);
	CDC* pDC = pWnd->GetDC();
	//pWnd->Invalidate();
	//pWnd->UpdateWindow();
	pWnd->GetWindowRect(rect);
	Graphics graphics(pDC->m_hDC);
	graphics.FillRectangle(&brush, 1, 1, rect.Width()-2, rect.Height()-2);
	graphics.DrawLine(&pen, 10, rect.Height() - 10, 311, rect.Height() - 10);
	graphics.DrawLine(&pen, 10, rect.Height() - 10, 10, rect.Height() - 311);
	//graphics.d
	if(pKnn->GetCheck())
	{
		
		float distance[20];
		int status[20];
		int pstatus[300];
		float temp1;
		int temp2, sum = 0;
		int knn = 5;
		for(int i = 0; i <300; i++)
		{
			for (int j = 0; j < 300; j++)
			{
				for (int k = 0; k < 20; k++)
				{
					distance[k] = (float)sqrt(pow((data[k][0] - i), 2.0) + pow((data[k][1] - j), 2.0));
					status[k] = data[k][2];
				}
				//sort
				for (int m = 0; m < knn; m++)
				{
					for (int n = m + 1; n < 20; n++)
					{
						if(distance[m] > distance[n])
						{
							temp1 = distance[m];
							distance[m] = distance[n];
							distance[n] = temp1;
							temp2 = status[m];
							status[m] = status[n];
							status[n] = temp2;
						}
					}
				}
				sum = 0;
				for (int m = 0; m < knn; m++)
				{
					sum += status[m];
				}
				if(sum > (int)(knn/2))
					pstatus[j] = 1;
				else
					pstatus[j] = 0;
			}
			
			for (int j = 0; j < 300; j++)
			{
				if(pstatus[j] == 1)
				{
					
					graphics.DrawLine(&greenPen, 11+i, rect.Height() - (311-j), 11+i, rect.Height() - (311-(j+1)));
				}
				else
				{
					graphics.DrawLine(&redPen, 11+i, rect.Height() - (311-j), 11+i, rect.Height() - (311-(j+1)));
				}
			}
			
		}
	
		for(int i = 0; i < 20; i++)//20個樣本點
		{
			for (int j = 0; j < 2; j++)
			{
				if(data[i][2] == 1)
					graphics.FillEllipse(&greenBrush, 11 + data[i][0], rect.Height() - (311-data[i][1]), 10, 10);
				else
					graphics.FillEllipse(&redBrush, 11 + data[i][0], rect.Height() - (311-data[i][1]), 10, 10);
			}
		}	
	}
	if(pBp->GetCheck())
	{
		//a - learning speed, w - weight, q - threshold, e - error
		double w13[2],w14[2],w23[2],w24[2],w35[2],w45[2],q3[2],q4[2],q5[2],e[20],a =0.1,y3,y4,y5,e3,e4,e5;
		w13[0]=0.5,w14[0]=0.9,w23[0]=0.4,w24[0]=1.0,w35[0]=-1.2,w45[0]=1.1,q3[0]=0.8,q4[0]=-0.1,q5[0]=0.3;
		do 
		{
			for(int i = 0; i < 20; i++)
		    {
				//compute
				y3 = sigmoid(data[i][0]*w13[0]+data[i][1]*w23[0]-q3[0]);
				y4 = sigmoid(data[i][0]*w14[0]+data[i][1]*w24[0]-q4[0]);
				y5 = sigmoid(y3*w35[0]+y4*w45[0]-q5[0]);
				e[i] = data[i][2] - y5;
				e5 = y5*(1-y5)*e[i];
				w35[1] = a*y3*e5;
				w45[1] = a*y4*e5;
				q5[1] = a*(-1)*e5;
				e3 = y3*(1-y3)*e5*w35[0];
				e4 = y4*(1-y4)*e5*w45[0];
				w13[1] = a*data[i][0]*e3;
				w23[1] = a*data[i][1]*e3;
				q3[1] = a*(-1)*e3;
				w14[1] = a*data[i][0]*e4;
				w24[1] = a*data[i][1]*e4;
				q4[1] = a*(-1)*e4;
				//updata
				w13[0] += w13[1];
				w14[0] += w14[1];
				w23[0] += w23[1];
				w24[0] += w24[1];
				w35[0] += w35[1];
				w45[0] += w45[1];
				q3[0] += q3[1];
				q4[0] += q4[1];
				q5[0] += q5[1];
			}
			double temp = error(e);
		} while(error(e) >= 5.0409);//error<0.001
		for(int i = 0; i < 300; i++)
		{
			for (int j = 0; j < 300; j++)
			{
				y3 = sigmoid(i*w13[0]+j*w23[0]-q3[0]);
				y4 = sigmoid(i*w14[0]+j*w24[0]-q4[0]);
				y5 = sigmoid(y3*w35[0]+y4*w45[0]-q5[0]);
				
				if(y5 != 0.55118738802672185)
				{

					graphics.DrawLine(&greenPen, 11+i, rect.Height() - (311-j), 11+i, rect.Height() - (311-(j+1)));
				}
				else
				{
					graphics.DrawLine(&redPen, 11+i, rect.Height() - (311-j), 11+i, rect.Height() - (311-(j+1)));
				}
				
			}
		}

		for(int i = 0; i < 20; i++)
		{
			for (int j = 0; j < 2; j++)
			{
				if(data[i][2] == 1)
					graphics.FillEllipse(&greenBrush, 11 + data[i][0], rect.Height() - (311-data[i][1]), 10, 10);
				else
					graphics.FillEllipse(&redBrush, 11 + data[i][0], rect.Height() - (311-data[i][1]), 10, 10);
			}
		}	
	}
	pWnd->ReleaseDC(pDC);
}
// The system calls this function to obtain the cursor to display while the user drags
//  the minimized window.
HCURSOR CKNNBPDlg::OnQueryDragIcon()
{
	return static_cast<HCURSOR>(m_hIcon);
}

double CKNNBPDlg::error(double e[])
{
	double result = 0.0;
	for(int i = 0; i < 20; i++)
	{
		result += pow(e[i], 2.0);
	}
	return result; 
}

double CKNNBPDlg::sigmoid(double x)
{
	double result = 0.0, e = 2.71;
	result = 1/(1 + pow(e, (0.0 - x)));
	return result; 
}
void CKNNBPDlg::OnBnClickedKnn()
{
	CRect rect;
	CStatic* pWnd = (CStatic*)GetDlgItem(IDC_STATIC);
	CDC* pDC = pWnd->GetDC();
	pWnd->Invalidate();
	pWnd->UpdateWindow();
	pWnd->GetWindowRect(rect);
	InvalidateRect(&rect);
	//Invalidate();
	// TODO: Add your control notification handler code here
}

void CKNNBPDlg::OnBnClickedBp()
{
	CRect rect;
	CStatic* pWnd = (CStatic*)GetDlgItem(IDC_STATIC);
	CDC* pDC = pWnd->GetDC();
	pWnd->Invalidate();
	pWnd->UpdateWindow();
	pWnd->GetWindowRect(rect);
	InvalidateRect(&rect);
	//Invalidate();
	// TODO: Add your control notification handler code here
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲成人一区二区| 国产九色精品成人porny| 中文av一区特黄| 欧美精品一区二区在线观看| 欧美一区二区精品在线| 欧美日韩不卡一区二区| 欧美三级韩国三级日本三斤| 在线免费视频一区二区| 欧美在线|欧美| 欧美三级中文字幕| 91精品国产乱| 精品少妇一区二区三区在线播放| 欧美一级视频精品观看| 日韩欧美激情一区| 久久综合中文字幕| 欧美国产欧美综合| 日韩理论片网站| 亚洲综合一二区| 亚洲一本大道在线| 日本成人中文字幕| 麻豆成人av在线| 国产精品一区在线| av电影天堂一区二区在线观看| www..com久久爱| 日本精品裸体写真集在线观看| 欧美性生交片4| 678五月天丁香亚洲综合网| 日韩欧美在线123| 久久久久9999亚洲精品| 国产精品传媒入口麻豆| 亚洲最快最全在线视频| 日韩中文字幕av电影| 麻豆精品久久精品色综合| 国产自产视频一区二区三区 | bt欧美亚洲午夜电影天堂| 丰满少妇久久久久久久| 色综合中文字幕国产 | 五月天精品一区二区三区| 免费高清视频精品| 国产激情视频一区二区在线观看| 岛国精品在线播放| 欧美日韩三级在线| 久久综合久久鬼色| 亚洲免费观看视频| 麻豆精品精品国产自在97香蕉| 福利一区福利二区| 欧美日韩视频在线第一区| 精品国产1区2区3区| 亚洲三级视频在线观看| 日本午夜一本久久久综合| 丁香天五香天堂综合| 欧美在线观看你懂的| 26uuu成人网一区二区三区| 中文字幕一区二| 蜜桃在线一区二区三区| 不卡区在线中文字幕| 欧美日韩精品福利| 国产欧美日韩精品一区| 亚洲国产一区在线观看| 国产一区二区三区高清播放| 日本精品一区二区三区四区的功能| 日韩欧美国产一区二区三区| 亚洲欧美日韩综合aⅴ视频| 久久99热国产| 欧美图片一区二区三区| 亚洲国产精品二十页| 日本伊人色综合网| 91女神在线视频| 国产欧美久久久精品影院| 天堂影院一区二区| 色综合中文字幕国产 | 日韩成人精品在线| aaa欧美色吧激情视频| 欧美不卡一区二区三区| 亚洲综合图片区| 从欧美一区二区三区| 日韩欧美精品三级| 午夜精品成人在线| 99国产精品久久久久久久久久| 日韩一级免费一区| 亚洲午夜久久久久中文字幕久| 国产91色综合久久免费分享| 日韩午夜激情免费电影| 亚洲不卡在线观看| 91麻豆6部合集magnet| 欧美国产一区视频在线观看| 久久99国产精品免费| 欧美区一区二区三区| 亚洲激情自拍视频| 成人激情图片网| 久久精品一区二区| 激情综合色丁香一区二区| 欧美高清视频一二三区| 亚洲精品国产高清久久伦理二区| 国产成人精品亚洲午夜麻豆| 精品国产免费一区二区三区四区 | 国产亚洲欧美一区在线观看| 免费在线观看视频一区| 欧美日韩国产另类一区| 亚洲国产乱码最新视频 | 日韩视频免费观看高清在线视频| 亚洲精品免费电影| 94-欧美-setu| 亚洲欧美偷拍三级| 日本丶国产丶欧美色综合| 亚洲精品欧美专区| 色综合久久六月婷婷中文字幕| 国产精品久久久久久福利一牛影视 | 91精品国产色综合久久ai换脸| 亚洲精品欧美激情| 欧美午夜一区二区| 亚洲成人av福利| 91精品国产综合久久久久久久 | 亚洲免费电影在线| 一本大道久久精品懂色aⅴ| 亚洲欧美经典视频| 色美美综合视频| 一区二区三区久久| 欧美三级中文字幕在线观看| 天天综合天天做天天综合| 欧美高清视频不卡网| 奇米影视一区二区三区小说| 日韩欧美你懂的| 国产老女人精品毛片久久| 亚洲国产成人自拍| 91久久精品日日躁夜夜躁欧美| 亚洲国产成人tv| 日韩精品一区二区三区蜜臀| 国产精品一线二线三线| 一区精品在线播放| 欧美私模裸体表演在线观看| 热久久国产精品| 国产片一区二区三区| 色综合咪咪久久| 麻豆精品在线视频| 国产精品色在线观看| 欧美视频三区在线播放| 欧美日本免费一区二区三区| 老司机精品视频线观看86| 日本一区二区久久| 欧美午夜影院一区| 国产尤物一区二区| 亚洲精品亚洲人成人网在线播放| 91精品国产欧美日韩| 国产盗摄一区二区| 玉米视频成人免费看| 欧美日韩亚洲另类| 亚洲激情图片qvod| 日韩欧美第一区| 国产美女精品在线| 亚洲一区二区偷拍精品| 91精品国产91久久综合桃花| 韩国毛片一区二区三区| 亚洲伦理在线免费看| 欧美浪妇xxxx高跟鞋交| 老色鬼精品视频在线观看播放| 中文字幕一区不卡| 欧美色男人天堂| 九九九久久久精品| 中文字幕成人在线观看| 欧美久久一区二区| 国模冰冰炮一区二区| 国产精品免费视频观看| 91麻豆swag| 国产精品1区二区.| 夜夜亚洲天天久久| 日韩视频免费直播| 蜜桃视频一区二区三区 | 韩国三级电影一区二区| 国产精品福利一区| 精品国产一区二区三区久久影院 | 色综合天天视频在线观看| 亚洲成人免费影院| 国产亚洲一区二区三区在线观看| 欧美日韩视频专区在线播放| 国产米奇在线777精品观看| 亚洲欧美乱综合| 中文字幕精品一区二区精品绿巨人 | 麻豆久久久久久久| 中文字幕亚洲成人| 日韩一区二区中文字幕| 91网站最新地址| 久久99精品久久久久婷婷| 亚洲欧美日韩精品久久久久| 91精品国产91久久久久久一区二区| 丁香天五香天堂综合| 蜜臀久久久久久久| 亚洲美女一区二区三区| 中文字幕欧美日本乱码一线二线| 欧美日韩不卡一区二区| www.在线成人| 免费成人美女在线观看.| 亚洲国产精品久久久久婷婷884| 欧美激情一区在线观看| 欧美一区二区三区影视| 欧美日韩精品免费| 99re在线精品| 国产成人亚洲精品青草天美| 丝袜亚洲另类欧美| 亚洲国产精品久久艾草纯爱|