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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? mainfrm.cpp

?? 支持向量機Windows Svm
?? CPP
字號:
// MainFrm.cpp : implementation of the CMainFrame class
//

#include "stdafx.h"
#include "svm.h"

#include "MainFrm.h"
#include "svm_learn_main.h"
#include "GeneralPage.h"
#include "LearnPage.h" 
#include "PerformPage.h"
#include "KerPage.h"
#include <conio.h>
#include <process.h>
#include "svm_learn_main.h"
#include <string.h>
#include "svm_classify.h"
#include "PromptDlg.h"


#include "OptimizePage.h"
#include "LearnDlg.h"
#include "ClassifyDlg.h"

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

/////////////////////////////////////////////////////////////////////////////
// CMainFrame

IMPLEMENT_DYNCREATE(CMainFrame, CFrameWnd)

BEGIN_MESSAGE_MAP(CMainFrame, CFrameWnd)
//{{AFX_MSG_MAP(CMainFrame)
ON_WM_CREATE()
ON_COMMAND(ID_OPTION_LEARN, OnOptionLearn)
ON_COMMAND(ID_FILE_LEARN, OnFileLearn)
ON_COMMAND(ID_FILE_CLASSIFY, OnFileClassify)
	ON_COMMAND(ID_OPTION_PROMPT, OnOptionPrompt)
	ON_COMMAND(ID_TOOL_TEMP, OnToolTemp)
	ON_UPDATE_COMMAND_UI(ID_OPTION_PROMPT, OnUpdateOptionPrompt)
	ON_UPDATE_COMMAND_UI(ID_TOOL_TEMP, OnUpdateToolTemp)
	ON_UPDATE_COMMAND_UI(ID_FILE_LEARN, OnUpdateFileLearn)
	ON_UPDATE_COMMAND_UI(ID_FILE_CLASSIFY, OnUpdateFileClassify)
	ON_UPDATE_COMMAND_UI(ID_OPTION_LEARN, OnUpdateOptionLearn)
	ON_COMMAND(ID_STOP_RUNNING, OnStopRunning)
	ON_UPDATE_COMMAND_UI(ID_STOP_RUNNING, OnUpdateStopRunning)
	ON_MESSAGE(WM_COMPUTATION_FINISH,OnComputationFinish)
	ON_WM_TIMER()
	ON_UPDATE_COMMAND_UI(ID_INDICATOR_TIME,OnUpdateTime)
	ON_COMMAND(ID_CLEAR_TEXT, OnClearText)
	ON_WM_CLOSE()
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

static UINT indicators[] =
{
	ID_SEPARATOR,           // status line indicator
	//	ID_INDICATOR_CAPS,
 		ID_INDICATOR_TIME,
	//	ID_INDICATOR_NUM,
	//	ID_INDICATOR_SCRL,
};

/////////////////////////////////////////////////////////////////////////////
// CMainFrame construction/destruction

CMainFrame::CMainFrame()
{
 
}

CMainFrame::~CMainFrame()
{
}

int CMainFrame::OnCreate(LPCREATESTRUCT lpCreateStruct)
{
	if (CFrameWnd::OnCreate(lpCreateStruct) == -1)
		return -1;
	
	if (!m_wndToolBar.CreateEx(this, TBSTYLE_FLAT, WS_CHILD | WS_VISIBLE | CBRS_TOP
		| CBRS_GRIPPER | CBRS_TOOLTIPS | CBRS_FLYBY | CBRS_SIZE_DYNAMIC) ||
		!m_wndToolBar.LoadToolBar(IDR_MAINFRAME))
	{
		TRACE0("Failed to create toolbar\n");
		return -1;      // fail to create
	}
	
	if (!m_wndStatusBar.Create(this) ||
		!m_wndStatusBar.SetIndicators(indicators,
		sizeof(indicators)/sizeof(UINT)))
	{
		TRACE0("Failed to create status bar\n");
		return -1;      // fail to create
	}
	 m_wndStatusBar.SetPaneInfo(1,ID_INDICATOR_TIME,SBPS_NORMAL,150);
//	 m_wndStatusBar.GetDlgItem(
	m_nTimeIndex=m_wndStatusBar.CommandToIndex(ID_INDICATOR_TIME);
	m_wndToolBar.EnableDocking(CBRS_ALIGN_ANY);
	EnableDocking(CBRS_ALIGN_ANY);
	DockControlBar(&m_wndToolBar);
	
	return 0;
}

BOOL CMainFrame::PreCreateWindow(CREATESTRUCT& cs)
{
	if( !CFrameWnd::PreCreateWindow(cs) )
		return FALSE;
	return TRUE;
}

/////////////////////////////////////////////////////////////////////////////
// CMainFrame diagnostics

#ifdef _DEBUG
void CMainFrame::AssertValid() const
{
	CFrameWnd::AssertValid();
}

void CMainFrame::Dump(CDumpContext& dc) const
{
	CFrameWnd::Dump(dc);
}

#endif //_DEBUG

/////////////////////////////////////////////////////////////////////////////
// CMainFrame message handlers



UINT ComputeThreadProc(LPVOID pParam)
{
	
	svm_learn_main();
	if (com_pro.show_openfile) 
	{
		char* cmdline;
		char  oldline[200]="notepad ";
		cmdline=strcat(oldline, com_param.modelfile);
		WinExec(cmdline,3);
	}
	::PostMessage((HWND)pParam,WM_COMPUTATION_FINISH,0,0);
	return 0;
}

UINT ClassifyThreadProc(LPVOID pParam)
{
	svm_classify( );
	if (com_pro.show_action)
		printm("finish classification...");
	if (com_pro.show_openfile) 
	{
		char* cmdline;
		char  oldline[200]="notepad ";
		cmdline=strcat(oldline, com_param.resultfile);
		WinExec(cmdline,3);
	}
	::PostMessage((HWND)pParam,WM_COMPUTATION_FINISH,0,0);
	return 0;
}


void CMainFrame::OnOptionLearn() 
{
	
	CPropertySheet ps("Modify the Computation parameters");
	CLearnPage pp2;
	CPerformPage pp3;
	CKerPage pp4;
	COptimizePage pp5;
	
	pp2.m_bB=com_param.biased_Hyperplane;
	pp2.m_bI=com_param.remove_inconsitant;
	pp2.m_fC=com_param.C;
	pp2.m_fJ=com_param.cost_factor;
	pp3.m_bX=com_param.loo;
	pp3.m_fK=com_param.search_depth;
	pp3.m_fO=com_param.rho;
	pp3.m_fP=com_param.fraction;
	pp4.m_fG=com_param.rbf_gamma;
	pp4.m_fC=com_param.poly_c;
	pp4.m_fS=com_param.poly_s;
	pp4.m_iD=com_param.poly_degree;
	pp4.m_iKernelType=com_param.kernel_type;
//	pp4.m_strU=com_param.user_u;
	pp5.m_fE=com_param.epsion;
	pp5.m_lgIterationTime=com_param.iteration_time;
	pp5.m_fM=com_param.cache_size;
	pp5.m_lgNewVariable=com_param.new_variable;
	pp5.m_lgMaxQPSize=com_param.maximum_size;
	pp5.m_bFinal=com_param.final_test;
	
 
	ps.AddPage(&pp2);
	ps.AddPage(&pp3);
	ps.AddPage(&pp4);
	ps.AddPage(&pp5);
	
	if (ps.DoModal()==IDOK){
		
		com_param.biased_Hyperplane=pp2.m_bB ;
		com_param.remove_inconsitant=pp2.m_bI;
		com_param.C                = 	pp2.m_fC;
		com_param.cost_factor      = 	pp2.m_fJ;
		com_param.loo              = 	pp3.m_bX;
		com_param.search_depth     = 	pp3.m_fK;
		com_param.rho           = 	pp3.m_fO;
		com_param.fraction        = 	pp3.m_fP;
		com_param.rbf_gamma        = 	pp4.m_fG  ;
		com_param.poly_c           = 	pp4.m_fC;
		com_param.poly_s           = 	pp4.m_fS;
		com_param.poly_degree      = 	pp4.m_iD  ;
		com_param.kernel_type      = 	pp4.m_iKernelType ;
	//	com_param.user_u   =            pp4.m_strU  ;                            
		com_param.epsion           = 	pp5.m_fE;
		com_param.iteration_time   = 	pp5.m_lgIterationTime;
		com_param.cache_size       = 	pp5.m_fM  ;
		com_param.new_variable     = 	pp5.m_lgNewVariable;
		com_param.maximum_size     = 	pp5.m_lgMaxQPSize;
		com_param.final_test       = 	pp5.m_bFinal  ;
	}

}


void CMainFrame::OnFileLearn() 
{
	CLearnDlg Ld;
	
	Ld.m_strModel=com_param.modelfile;//這兩條沒用
	Ld.m_strTrain=com_param.trainfile;
	if (Ld.DoModal()==IDOK) 
	{
		com_pro.show_openfile=Ld.m_bOpen;
		strcpy(com_param.trainfile,Ld.m_strTrain);
		strcpy(com_param.modelfile,Ld.m_strModel);
		GetActiveView()->SetWindowText(NULL);
		BeginComputation();//設(shè)置一些參數(shù)
		//開辟新線程
		CWinThread* pThread=
			AfxBeginThread(ComputeThreadProc,GetSafeHwnd(),THREAD_PRIORITY_NORMAL);
	}
	
}

void CMainFrame::OnFileClassify() 
{
	CClassifyDlg Ld;
	Ld.m_strResult=com_param.resultfile;
	Ld.m_strModel=com_param.modelfile;
	Ld.m_strClassify=com_param.classifyfile;
	
	if (Ld.DoModal()==IDOK) 
	{
		strcpy(com_param.classifyfile,Ld.m_strClassify);
		strcpy(com_param.modelfile,Ld.m_strModel);
		strcpy(com_param.resultfile,Ld.m_strResult);
		com_pro.show_openfile=Ld.m_bOpen;
		GetActiveView()->SetWindowText(NULL);
		BeginComputation();
		CWinThread* pThread=
			AfxBeginThread(ClassifyThreadProc,GetSafeHwnd(),THREAD_PRIORITY_NORMAL);
	}
}


void CMainFrame::OnOptionPrompt() 
{
	CPromptDlg pd;
	pd.m_bAction		=com_pro.show_action;
	pd.m_bCompute1		=com_pro.show_compute_1;
	pd.m_bCompute2		=com_pro.show_compute_2;
	pd.m_bCompute3		=com_pro.show_compute_3;

	pd.m_bReadFile		=com_pro.show_readfile;
	pd.m_bWriteFile		=com_pro.show_writefile;
	pd.m_bTestResult	=com_pro.show_testresult;
	pd.m_bTitle			=com_pro.show_title;
	pd.m_bTrainResult	=com_pro.show_trainresult;
	pd.m_bWriteModel	=com_param.blWriteModel;

	if (pd.DoModal()==IDOK) 
	{
		com_pro.show_action    =       pd.m_bAction	;
		com_pro.show_compute_1   =       pd.m_bCompute1	;
		com_pro.show_compute_2   =       pd.m_bCompute2	;
		com_pro.show_compute_3   =       pd.m_bCompute3	;

		com_pro.show_readfile  =       pd.m_bReadFile	;
		com_pro.show_writefile =       pd.m_bWriteFile	;
		com_pro.show_testresult=       pd.m_bTestResult	;
		com_pro.show_title     =	pd.m_bTitle	;
		com_pro.show_trainresult=      pd.m_bTrainResult;
		com_param.blWriteModel=pd.m_bWriteModel	;
	}

}
UINT TempOperationThreadProc(LPVOID pParam)
{
	char filestr[200]="D:\\Digit\\Digit_";
	char trainfile[200];
	char testfile[200];
	char modelfile[200];
	char resultfile[200];

	char trainstr[20];
	char teststr[20];
	char modelstr[20];
	char resultstr[20];

	for (int i=1;i<=100&&com_param.Running;i++)
	{
		sprintf(trainstr,"%d.trn",i);
		sprintf(teststr,"%d.tst",i);
		sprintf(modelstr,"%d.mdl",i);
		sprintf(resultstr,"%d.rsl",i);
		strcpy(trainfile,filestr);
		strcat(trainfile,trainstr);
		strcpy(testfile,filestr);
		strcat(testfile,teststr);
		strcpy(modelfile,filestr);
		strcat(modelfile,modelstr);
		strcpy(resultfile,filestr);
		strcat(resultfile,resultstr);

		strcpy(com_param.trainfile,trainfile);
		strcpy(com_param.classifyfile,testfile);
		strcpy(com_param.modelfile,modelfile);
		strcpy(com_param.resultfile,resultfile);

		svm_learn_main();
		svm_classify();
	}
	::PostMessage((HWND)pParam,WM_COMPUTATION_FINISH,0,0);
	return 1;
	
}


void CMainFrame::OnToolTemp() 
{
	
	BeginComputation();
	CWinThread* pThread=
			AfxBeginThread(TempOperationThreadProc,GetSafeHwnd(),THREAD_PRIORITY_NORMAL);

		
}

void CMainFrame::OnUpdateOptionPrompt(CCmdUI* pCmdUI) 
{
// pCmdUI->Enable(!com_param.Running);
}
	


void CMainFrame::OnUpdateToolTemp(CCmdUI* pCmdUI) 
{
  pCmdUI->Enable(com_param.Finished&&!com_param.Running);
}
	


void CMainFrame::OnUpdateFileLearn(CCmdUI* pCmdUI) 
{
 pCmdUI->Enable(com_param.Finished&&!com_param.Running);
}
	


void CMainFrame::OnUpdateFileClassify(CCmdUI* pCmdUI) 
{
	  pCmdUI->Enable(com_param.Finished&&!com_param.Running);
}

void CMainFrame::OnUpdateOptionLearn(CCmdUI* pCmdUI) 
{
 	pCmdUI->Enable(com_param.Finished&&!com_param.Running);
}

void CMainFrame::OnStopRunning() 
{
	if (AfxMessageBox("Do u wanna stop?",MB_YESNO)==IDYES)
	{
	com_param.Running=FALSE;	
	temp_pro.Copy(com_pro);
	com_pro.Clear();
	m_wndStatusBar.SetPaneText(1,"Trying to stop....");
	}
}

void CMainFrame::OnUpdateStopRunning(CCmdUI* pCmdUI) 
{
	pCmdUI->Enable(!com_param.Finished&&com_param.Running);
	
}
void CMainFrame::BeginComputation()
{
	com_param.Running=TRUE;
	com_param.Finished=FALSE;
	temp_pro.Copy(com_pro);
	m_nTimer=SetTimer(1001,500,NULL);
	m_tmBegin=CTime::GetCurrentTime();

}
void CMainFrame::OnComputationFinish(WPARAM wParam,LPARAM lParam)
{
	CeaseComputation();
}

void CMainFrame::CeaseComputation()
{
	
	if (com_param.Running==FALSE)
		printm("----Computation was stop by user.");
	com_param.Running=FALSE;
	com_param.Finished=TRUE;
	com_pro.Copy(temp_pro);
	


	KillTimer(m_nTimer);
	m_wndStatusBar.SetPaneText(1,"Waiting...");
	if (com_param.Close)
		CFrameWnd::OnClose();
}

	

void CMainFrame::OnTimer(UINT nIDEvent) 
{
	CTimeSpan t=CTime::GetCurrentTime()-m_tmBegin;
	m_strTime=t.Format("Computing %H:%M:%S already ");
//	m_wndStatusBar.SetPaneText(1,m_strTime,TRUE);
	CFrameWnd::OnTimer(nIDEvent);
}
void CMainFrame::OnUpdateTime(CCmdUI* pCmdUI)
{
	pCmdUI->Enable();
	pCmdUI->SetText(m_strTime);
}

void CMainFrame::OnClearText() 
{
 	GetActiveView()->SetWindowText(NULL);
}

void CMainFrame::OnClose() 
{
	if (!com_param.Finished)
	{
		if( AfxMessageBox("Still computing ,Do u wanna exit?",MB_YESNO)==IDYES)
		{
			com_param.Running=FALSE;
			com_param.Close=TRUE;
			return ;
		}
		else return ;

	}
	else 	CFrameWnd::OnClose();
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久激情综合网| 欧美日韩综合不卡| 欧美亚洲愉拍一区二区| 久久综合丝袜日本网| 一区二区成人在线视频| 久久99国产精品久久99| 91久久精品网| 国产日产欧产精品推荐色| 亚洲成人午夜影院| 99久久久免费精品国产一区二区| 日韩欧美国产麻豆| 亚洲一级不卡视频| 97精品国产露脸对白| 久久美女艺术照精彩视频福利播放| 亚洲国产精品嫩草影院| gogogo免费视频观看亚洲一| 久久婷婷综合激情| 蜜桃av噜噜一区| 欧美日韩视频不卡| 亚洲精选视频在线| 不卡电影一区二区三区| 久久久精品一品道一区| 久久se这里有精品| 69久久99精品久久久久婷婷| 一区二区三区蜜桃| 日本精品一级二级| 亚洲色图丝袜美腿| 成人自拍视频在线| 国产亚洲福利社区一区| 国产精品综合二区| 久久免费偷拍视频| 国产大陆精品国产| 国产日韩一级二级三级| 国产99久久久久| 欧美激情综合网| 国产成人亚洲综合a∨婷婷图片| 欧美成人欧美edvon| 美腿丝袜亚洲综合| 日韩网站在线看片你懂的| 日韩成人伦理电影在线观看| 欧美久久久久久蜜桃| 五月天亚洲婷婷| 欧美一区三区四区| 久久精品久久精品| 精品国产一区二区在线观看| 国产精品99久久久久久久女警 | 极品瑜伽女神91| 337p粉嫩大胆色噜噜噜噜亚洲| 久久精品av麻豆的观看方式| 日韩欧美国产成人一区二区| 国产在线一区二区综合免费视频| 久久尤物电影视频在线观看| 白白色 亚洲乱淫| 亚洲精品久久久蜜桃| 欧美精品日韩综合在线| 免费在线看一区| 国产日韩精品一区二区三区 | 欧美中文一区二区三区| 日日骚欧美日韩| 精品国产污污免费网站入口 | 国产精品―色哟哟| 91色九色蝌蚪| 日韩和欧美一区二区| 久久久亚洲精品一区二区三区| 国产乱码精品一区二区三区忘忧草 | 麻豆一区二区三区| 国产日韩亚洲欧美综合| 91影视在线播放| 日韩精品一二三四| 国产精品美日韩| 日韩一区二区免费高清| 国产盗摄一区二区| 日韩一区精品视频| ●精品国产综合乱码久久久久 | 94-欧美-setu| 免费高清成人在线| 亚洲三级小视频| 日韩丝袜情趣美女图片| 99re在线精品| 激情综合五月婷婷| 亚洲一区二区三区美女| 久久久另类综合| 欧美日本一区二区在线观看| 不卡一区在线观看| 麻豆极品一区二区三区| 亚洲免费观看高清完整版在线观看熊| 日韩一级大片在线观看| 97成人超碰视| 国产成人自拍网| 五月综合激情网| 国产精品国模大尺度视频| 日韩精品中文字幕一区二区三区| 91美女在线视频| 国产白丝精品91爽爽久久| 日韩av一区二区三区| 亚洲精品欧美二区三区中文字幕| 久久久国产精品午夜一区ai换脸| 69av一区二区三区| 欧美伊人精品成人久久综合97 | 欧美日韩国产天堂| 成人av一区二区三区| 蜜桃视频免费观看一区| 五月婷婷久久综合| 亚洲国产毛片aaaaa无费看| 国产精品不卡在线观看| 26uuu欧美| 337p粉嫩大胆色噜噜噜噜亚洲| 欧美一区二区在线不卡| 欧美日韩日日夜夜| 欧美色窝79yyyycom| 91免费观看在线| 99久久伊人网影院| 成人午夜激情视频| 国产精华液一区二区三区| 麻豆国产欧美日韩综合精品二区| 日韩精品亚洲一区| 日韩精品一区第一页| 天堂蜜桃一区二区三区| 日本在线播放一区二区三区| 首页国产丝袜综合| 日本欧美一区二区三区乱码| 日产国产欧美视频一区精品| 五月婷婷色综合| 美女网站在线免费欧美精品| 奇米色一区二区| 捆绑紧缚一区二区三区视频| 日韩精品一级二级| 精品在线一区二区三区| 国产精品小仙女| 成人av片在线观看| 91国偷自产一区二区使用方法| 欧美亚洲图片小说| 欧美丰满美乳xxx高潮www| 日韩欧美在线123| 久久久久青草大香线综合精品| 国产精品美女久久久久久久久 | 日本道免费精品一区二区三区| 在线一区二区三区做爰视频网站| 欧美日韩亚洲综合在线 | 亚洲国产精品国自产拍av| 亚洲欧美怡红院| 午夜精品免费在线| 国产精品原创巨作av| 菠萝蜜视频在线观看一区| 色先锋资源久久综合| 欧美亚洲国产怡红院影院| 91麻豆精品国产91久久久资源速度 | 久久精子c满五个校花| 久久久高清一区二区三区| 欧美吻胸吃奶大尺度电影| 欧美videofree性高清杂交| 久久久噜噜噜久噜久久综合| 国产目拍亚洲精品99久久精品| 中文字幕精品在线不卡| 国产精品久久久久三级| 亚洲香肠在线观看| 麻豆成人在线观看| 激情成人午夜视频| 欧美日韩一区成人| 日韩精品一区二区三区在线播放| 国产亚洲精品aa午夜观看| 综合久久久久久| 理论片日本一区| 成人美女视频在线观看18| 91美女视频网站| 欧美一区永久视频免费观看| 亚洲欧美在线另类| 青青草97国产精品免费观看 | 亚洲bt欧美bt精品| 美脚の诱脚舐め脚责91| 国产精品1区2区| 欧美狂野另类xxxxoooo| 国产亚洲自拍一区| 一区二区视频免费在线观看| 亚洲国产视频一区| 成人精品电影在线观看| 欧美偷拍一区二区| 久久综合九色综合97_久久久 | 免费日本视频一区| 成av人片一区二区| 国产三级精品视频| 五月婷婷激情综合| 99热精品一区二区| 久久亚区不卡日本| 捆绑变态av一区二区三区| 色中色一区二区| 国产欧美一区二区精品秋霞影院 | 日韩国产欧美三级| 99久久综合狠狠综合久久| 91精品国产综合久久久久久漫画| 中文字幕一区在线观看视频| 国产精品亚洲专一区二区三区| 欧美日韩日日夜夜| 亚洲视频1区2区| 国产一区二区成人久久免费影院| 欧美精品久久99| 一区二区三区不卡视频| 国产激情一区二区三区| 久久众筹精品私拍模特| 日韩精品91亚洲二区在线观看|