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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專(zhuān)輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? svm-toy.cpp

?? SVM算法的一個(gè)例子
?? CPP
字號(hào):
#include <windows.h>#include <windowsx.h>#include <stdio.h>#include <ctype.h>#include <list>#include "../../svm.h"#define DEFAULT_PARAM "-t 2 -c 100"#define XLEN 500#define YLEN 500#define DrawLine(dc,x1,y1,x2,y2,c) \	do { \		HPEN hpen = CreatePen(PS_SOLID,0,c); \		HPEN horig = SelectPen(dc,hpen); \		MoveToEx(dc,x1,y1,NULL); \		LineTo(dc,x2,y2); \		SelectPen(dc,horig); \		DeletePen(hpen); \	} while(0)using namespace std;COLORREF colors[] ={	RGB(0,0,0),	RGB(0,120,120),	RGB(120,120,0),	RGB(120,0,120),	RGB(0,200,200),	RGB(200,200,0),	RGB(200,0,200)};HWND main_window;HBITMAP buffer;HDC window_dc;HDC buffer_dc;HBRUSH brush1, brush2, brush3;HWND edit;enum {	ID_BUTTON_CHANGE, ID_BUTTON_RUN, ID_BUTTON_CLEAR,	ID_BUTTON_LOAD, ID_BUTTON_SAVE, ID_EDIT};struct point {	double x, y;	signed char value;};list<point> point_list;int current_value = 1;LRESULT CALLBACK WndProc(HWND, UINT, WPARAM, LPARAM);int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance,		   PSTR szCmdLine, int iCmdShow){	static char szAppName[] = "SvmToy";	MSG msg;	WNDCLASSEX wndclass;	wndclass.cbSize = sizeof(wndclass);	wndclass.style = CS_HREDRAW | CS_VREDRAW;	wndclass.lpfnWndProc = WndProc;	wndclass.cbClsExtra = 0;	wndclass.cbWndExtra = 0;	wndclass.hInstance = hInstance;	wndclass.hIcon = LoadIcon(NULL, IDI_APPLICATION);	wndclass.hCursor = LoadCursor(NULL, IDC_ARROW);	wndclass.hbrBackground = (HBRUSH) GetStockObject(BLACK_BRUSH);	wndclass.lpszMenuName = NULL;	wndclass.lpszClassName = szAppName;	wndclass.hIconSm = LoadIcon(NULL, IDI_APPLICATION);	RegisterClassEx(&wndclass);	main_window = CreateWindow(szAppName,	// window class name				    "SVM Toy",	// window caption				    WS_OVERLAPPEDWINDOW,// window style				    CW_USEDEFAULT,	// initial x position				    CW_USEDEFAULT,	// initial y position				    XLEN,	// initial x size				    YLEN+52,	// initial y size				    NULL,	// parent window handle				    NULL,	// window menu handle				    hInstance,	// program instance handle				    NULL);	// creation parameters	ShowWindow(main_window, iCmdShow);	UpdateWindow(main_window);	CreateWindow("button", "Change", WS_CHILD | WS_VISIBLE | BS_PUSHBUTTON,		     0, YLEN, 50, 25, main_window, (HMENU) ID_BUTTON_CHANGE, hInstance, NULL);	CreateWindow("button", "Run", WS_CHILD | WS_VISIBLE | BS_PUSHBUTTON,		     50, YLEN, 50, 25, main_window, (HMENU) ID_BUTTON_RUN, hInstance, NULL);	CreateWindow("button", "Clear", WS_CHILD | WS_VISIBLE | BS_PUSHBUTTON,		     100, YLEN, 50, 25, main_window, (HMENU) ID_BUTTON_CLEAR, hInstance, NULL);	CreateWindow("button", "Save", WS_CHILD | WS_VISIBLE | BS_PUSHBUTTON,		     150, YLEN, 50, 25, main_window, (HMENU) ID_BUTTON_SAVE, hInstance, NULL);	CreateWindow("button", "Load", WS_CHILD | WS_VISIBLE | BS_PUSHBUTTON,		     200, YLEN, 50, 25, main_window, (HMENU) ID_BUTTON_LOAD, hInstance, NULL);	edit = CreateWindow("edit", NULL, WS_CHILD | WS_VISIBLE,		            250, YLEN, 250, 25, main_window, (HMENU) ID_EDIT, hInstance, NULL);	Edit_SetText(edit,DEFAULT_PARAM);	brush1 = CreateSolidBrush(colors[4]);	brush2 = CreateSolidBrush(colors[5]);	brush3 = CreateSolidBrush(colors[6]);	window_dc = GetDC(main_window);	buffer = CreateCompatibleBitmap(window_dc, XLEN, YLEN);	buffer_dc = CreateCompatibleDC(window_dc);	SelectObject(buffer_dc, buffer);	PatBlt(buffer_dc, 0, 0, XLEN, YLEN, BLACKNESS);	while (GetMessage(&msg, NULL, 0, 0)) {		TranslateMessage(&msg);		DispatchMessage(&msg);	}	return msg.wParam;}int getfilename( HWND hWnd , char *filename, int len, int save) { 		OPENFILENAME OpenFileName; 		memset(&OpenFileName,0,sizeof(OpenFileName));	filename[0]='\0'; 		OpenFileName.lStructSize       = sizeof(OPENFILENAME); 	OpenFileName.hwndOwner         = hWnd; 		OpenFileName.lpstrFile         = filename; 	OpenFileName.nMaxFile          = len; 	OpenFileName.Flags             = 0; 	return save?GetSaveFileName(&OpenFileName):GetOpenFileName(&OpenFileName);		}void clear_all(){	point_list.clear();	PatBlt(buffer_dc, 0, 0, XLEN, YLEN, BLACKNESS);	InvalidateRect(main_window, 0, 0);}HBRUSH choose_brush(int v){	if(v==1) return brush1;	else if(v==2) return brush2;	else return brush3;}void draw_point(const point & p){	RECT rect;	rect.left = int(p.x*XLEN);	rect.top = int(p.y*YLEN);	rect.right = int(p.x*XLEN) + 3;	rect.bottom = int(p.y*YLEN) + 3;	FillRect(window_dc, &rect, choose_brush(p.value));	FillRect(buffer_dc, &rect, choose_brush(p.value));}void draw_all_points(){	for(list<point>::iterator p = point_list.begin(); p != point_list.end(); p++)		draw_point(*p);}void button_run_clicked(){	// guard	if(point_list.empty()) return;	svm_parameter param;	int i,j;		// default values	param.svm_type = C_SVC;	param.kernel_type = RBF;	param.degree = 3;	param.gamma = 0;	param.coef0 = 0;	param.qpsize = 10;	param.cache_size = 40;	param.C = 1;	param.eps = 1e-3;	param.p = 0.1;	param.shrinking = 1;	param.nr_weight = 0;	param.weight_label = NULL;	param.weight = NULL;	param.Cbegin = 1;	param.Cstep = 2;	// parse options	char str[1024];	Edit_GetLine(edit, 0, str, sizeof(str));	const char *p = str;	while (1) {		while (*p && *p != '-')			p++;		if (*p == '\0')			break;		p++;		switch (*p++) {			case 's':				param.svm_type = atoi(p);				break;			case 't':				param.kernel_type = atoi(p);				break;			case 'd':				param.degree = atof(p);				break;			case 'g':				param.gamma = atof(p);				break;			case 'r':				param.coef0 = atof(p);				break;			case 'q':				param.qpsize = atoi(p);				break;			case 'm':				param.cache_size = atof(p);				break;			case 'c':				param.C = atof(p);				break;			case 'e':				param.eps = atof(p);				break;			case 'p':				param.p = atof(p);				break;			case 'h':				param.shrinking = atoi(p);				break;			case 'w':				++param.nr_weight;				param.weight_label = (int *)realloc(param.weight_label,sizeof(int)*param.nr_weight);				param.weight = (double *)realloc(param.weight,sizeof(double)*param.nr_weight);				param.weight_label[param.nr_weight-1] = atoi(p);				while(*p && !isspace(*p)) ++p;				param.weight[param.nr_weight-1] = atof(p);				break;		}	}		// build problem	svm_problem prob;	prob.l = point_list.size();	prob.y = new double[prob.l];	prob.n = 2;	if(param.svm_type == EPSILON_SVR)	{		if(param.gamma == 0) param.gamma = 1;		svm_node *x_space = new svm_node[2 * prob.l];		prob.x = new svm_node *[prob.l];		i = 0;		for (list<point>::iterator q = point_list.begin(); q != point_list.end(); q++, i++)		{			x_space[2 * i].index = 1;			x_space[2 * i].value = q->x;			x_space[2 * i + 1].index = -1;			prob.x[i] = &x_space[2 * i];			prob.y[i] = q->y;		}		// build model & classify		svm_model *model = svm_train(&prob, &param);		svm_node x[2];		x[0].index = 1;		x[1].index = -1;		int *j = new int[XLEN];		for (i = 0; i < XLEN; i++)		{			x[0].value = (double) i / XLEN;			j[i] = (int)(YLEN*svm_predict(model, x));		}				DrawLine(buffer_dc,0,0,0,YLEN,colors[0]);		DrawLine(window_dc,0,0,0,YLEN,colors[0]);				int p = (int)(param.p * YLEN);		for(int i=1; i < XLEN; i++)		{			DrawLine(buffer_dc,i,0,i,YLEN,colors[0]);			DrawLine(window_dc,i,0,i,YLEN,colors[0]);						DrawLine(buffer_dc,i-1,j[i-1],i,j[i],colors[5]);			DrawLine(window_dc,i-1,j[i-1],i,j[i],colors[5]);				DrawLine(buffer_dc,i-1,j[i-1]+p,i,j[i]+p,colors[2]);				DrawLine(window_dc,i-1,j[i-1]+p,i,j[i]+p,colors[2]);				DrawLine(buffer_dc,i-1,j[i-1]-p,i,j[i]-p,colors[2]);				DrawLine(window_dc,i-1,j[i-1]-p,i,j[i]-p,colors[2]);		}				svm_destroy_model(model);		delete[] j;		delete[] x_space;		delete[] prob.x;		delete[] prob.y;	}	else	{		if(param.gamma == 0) param.gamma = 0.5;		svm_node *x_space = new svm_node[3 * prob.l];		prob.x = new svm_node *[prob.l];		i = 0;		for (list<point>::iterator q = point_list.begin(); q != point_list.end(); q++, i++)		{			x_space[3 * i].index = 1;			x_space[3 * i].value = q->x;			x_space[3 * i + 1].index = 2;			x_space[3 * i + 1].value = q->y;			x_space[3 * i + 2].index = -1;			prob.x[i] = &x_space[3 * i];			prob.y[i] = q->value;		}		// build model & classify		svm_model *model = svm_train(&prob, &param);		svm_node x[3];		x[0].index = 1;		x[1].index = 2;		x[2].index = -1;		for (i = 0; i < XLEN; i++)			for (j = 0; j < YLEN; j++) {				x[0].value = (double) i / XLEN;				x[1].value = (double) j / YLEN;				double d = svm_predict(model, x);				SetPixel(window_dc, i, j, colors[(int)d]);				SetPixel(buffer_dc, i, j, colors[(int)d]);			}		svm_destroy_model(model);		delete[] x_space;		delete[] prob.x;		delete[] prob.y;	}	free(param.weight_label);	free(param.weight);	draw_all_points();}LRESULT CALLBACK WndProc(HWND hwnd, UINT iMsg, WPARAM wParam, LPARAM lParam){	HDC hdc;	PAINTSTRUCT ps;	switch (iMsg) {	case WM_LBUTTONDOWN:		{			int x = LOWORD(lParam);			int y = HIWORD(lParam);			point p = {(double)x/XLEN, (double)y/YLEN, current_value};			point_list.push_back(p);			draw_point(p);		}		return 0;	case WM_PAINT:		{			hdc = BeginPaint(hwnd, &ps);			BitBlt(hdc, 0, 0, XLEN, YLEN, buffer_dc, 0, 0, SRCCOPY);			EndPaint(hwnd, &ps);		}		return 0;	case WM_COMMAND:		{			int id = LOWORD(wParam);			switch (id) {			case ID_BUTTON_CHANGE:				++current_value;				if(current_value > 3) current_value = 1;				break;			case ID_BUTTON_RUN:				button_run_clicked();				break;			case ID_BUTTON_CLEAR:				clear_all();								break;			case ID_BUTTON_SAVE:				{					char filename[1024];					if(getfilename(hwnd,filename,1024,1))					{						FILE *fp = fopen(filename,"w");						if(fp)						{							for (list<point>::iterator p = point_list.begin(); p != point_list.end(); p++)								fprintf(fp,"%d 1:%f 2:%f\n",p->value,p->x,p->y);							fclose(fp);						}					}									}				break;			case ID_BUTTON_LOAD:				{					char filename[1024];					if(getfilename(hwnd,filename,1024,0))										{						FILE *fp = fopen(filename,"r");						if(fp)						{							clear_all();							char buf[4096];							while(fgets(buf,sizeof(buf),fp))							{								int v, n, i;								double x,y;								point p;								n = sscanf(buf, "%d%d:%lf%*d:%lf",&v,&i,&x,&y);								if (n == 4)									p.x = x, p.y = y, p.value = v;								else 									if (n == 3)									{										if (i == 1)											p.x = x, p.y = 0, p.value = v;										if (i == 2)											p.x = 0, p.y = x, p.value = v;									}									else 										if (n == 1)											p.x = 0, p.y = 0, p.value = v;										else											break;								point_list.push_back(p);							}							fclose(fp);							draw_all_points();						}					}				}				break;			}		}		return 0;	case WM_DESTROY:		PostQuitMessage(0);		return 0;	}	return DefWindowProc(hwnd, iMsg, wParam, lParam);}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品久久久久aaaa| 老司机精品视频在线| 日日摸夜夜添夜夜添精品视频 | 欧美午夜片在线看| 欧美精品一区二区蜜臀亚洲| 一区二区三区四区国产精品| 丁香一区二区三区| 欧美刺激午夜性久久久久久久| 亚洲精品videosex极品| 国产精品99久久不卡二区| 欧美精选午夜久久久乱码6080| 国产精品国产三级国产aⅴ入口| 美国三级日本三级久久99| 在线看不卡av| 国产精品麻豆视频| 国产精品综合在线视频| 日韩精品一区二区在线观看| 亚洲一级二级三级| 一本到一区二区三区| 国产精品国产三级国产专播品爱网 | 亚洲视频在线一区二区| 国产精品亚洲综合一区在线观看| 91精品国产色综合久久不卡蜜臀 | 成人免费视频app| 欧美一级生活片| 亚洲成av人**亚洲成av**| 一本到三区不卡视频| 中文字幕一区二区三区四区不卡| 粉嫩aⅴ一区二区三区四区| 欧美草草影院在线视频| 久久精品噜噜噜成人88aⅴ| 日韩亚洲电影在线| 看国产成人h片视频| 欧美电影免费观看高清完整版在线 | 日韩电影在线观看一区| 欧美亚洲免费在线一区| 亚洲国产日韩一级| 91 com成人网| 美女免费视频一区二区| 精品第一国产综合精品aⅴ| 国产精品一二三四区| 久久久亚洲高清| 国产乱人伦精品一区二区在线观看| 日韩一区二区三区av| 精品一区二区三区香蕉蜜桃 | 奇米777欧美一区二区| 日韩一级片网站| 国产乱码精品一区二区三| 久久这里只有精品视频网| 国产a视频精品免费观看| 国产精品夫妻自拍| 在线亚洲人成电影网站色www| 一区二区三区在线视频观看58| 精品视频在线免费看| 捆绑调教美女网站视频一区| 国产无一区二区| 色妞www精品视频| 男男gaygay亚洲| 国产精品系列在线| 欧美亚洲尤物久久| 国内精品第一页| 亚洲日本护士毛茸茸| 91精品国产一区二区三区| 国产aⅴ综合色| 午夜精品久久久久久不卡8050| 久久尤物电影视频在线观看| 91在线小视频| 美女尤物国产一区| 日韩毛片视频在线看| 日韩一区二区三区免费看| av电影在线不卡| 蜜臀国产一区二区三区在线播放| 国产欧美在线观看一区| 欧美日韩免费不卡视频一区二区三区 | 精品视频一区 二区 三区| 精品亚洲成a人在线观看 | 色婷婷av一区二区三区软件| 日韩高清国产一区在线| 国产精品视频线看| 91精品中文字幕一区二区三区| 成人av午夜电影| 蜜臀av性久久久久av蜜臀妖精| 自拍偷拍国产亚洲| 精品蜜桃在线看| 欧美日本在线一区| 91麻豆免费视频| 国产大陆亚洲精品国产| 日本美女一区二区三区视频| 亚洲黄色片在线观看| 日本一区二区三区久久久久久久久不| 欧美日韩国产综合久久| 91免费视频网| 成人看片黄a免费看在线| 麻豆久久一区二区| 亚洲成a人片在线观看中文| 国产精品乱人伦一区二区| 久久一区二区视频| 日韩午夜三级在线| 欧美精品色综合| 欧美色网一区二区| 日本二三区不卡| 91在线播放网址| 成人高清视频在线观看| 国产精品正在播放| 国产一区不卡视频| 国产乱妇无码大片在线观看| 麻豆精品国产传媒mv男同 | 一区二区三区加勒比av| 亚洲欧美综合色| 国产精品白丝在线| 国产精品不卡在线| 日韩一区欧美小说| 亚洲欧美日韩在线不卡| 亚洲日本乱码在线观看| 亚洲免费看黄网站| 一区二区三区四区亚洲| 亚洲综合色视频| 一区二区三区鲁丝不卡| 亚洲一区二区三区中文字幕在线| 亚洲激情六月丁香| 亚洲va国产va欧美va观看| 天堂一区二区在线| 麻豆精品一区二区三区| 狠狠色丁香婷综合久久| 国产麻豆视频精品| 成人av资源在线| 在线成人高清不卡| 欧美挠脚心视频网站| 日韩亚洲欧美综合| 国产亚洲一区二区三区在线观看| 久久精品欧美一区二区三区不卡 | 国产一区二区调教| 成人免费毛片app| 在线观看视频一区二区欧美日韩| 欧美日韩中字一区| 精品久久国产字幕高潮| 中文字幕不卡三区| 曰韩精品一区二区| 热久久一区二区| 床上的激情91.| 在线亚洲欧美专区二区| 日韩一二三区视频| 国产精品久久久久aaaa樱花| 亚洲综合网站在线观看| 麻豆精品一区二区三区| 成人免费精品视频| 欧美猛男gaygay网站| 久久久99免费| 亚洲精品成人a在线观看| 美女视频黄a大片欧美| www.色精品| 337p亚洲精品色噜噜| 久久久www免费人成精品| 亚洲综合色自拍一区| 国产在线看一区| 欧美中文一区二区三区| 久久伊99综合婷婷久久伊| 亚洲综合免费观看高清完整版在线| 日韩av中文在线观看| 不卡一区二区在线| 日韩精品一区二区在线| 国产精品色哟哟| 日本视频在线一区| 91女人视频在线观看| 日韩免费高清视频| 亚洲一区二区三区在线| 国产精品888| 91精品国产综合久久久久久漫画| 国产精品美女久久久久高潮| 欧美a级理论片| 欧美在线影院一区二区| 国产精品女主播av| 久久国产婷婷国产香蕉| 欧美性xxxxxxxx| |精品福利一区二区三区| 另类小说图片综合网| 欧美色精品在线视频| 亚洲天堂中文字幕| 国产一区二区久久| 精品日韩欧美一区二区| 亚洲小少妇裸体bbw| 9久草视频在线视频精品| 亚洲视频一区二区免费在线观看| 精品中文字幕一区二区小辣椒| 欧美手机在线视频| 一区二区三区欧美视频| av资源网一区| 国产精品人人做人人爽人人添 | 风流少妇一区二区| 久久网站热最新地址| 狠狠色伊人亚洲综合成人| 欧美一区二区三区视频免费播放| 一区二区久久久久久| 一本久道中文字幕精品亚洲嫩| 国产精品久久久久久久久免费桃花| 国产一区二区剧情av在线| 日韩一区二区在线观看| 蜜臀av一区二区在线观看 | 美女诱惑一区二区| 日韩一区二区视频在线观看|