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

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

?? crossvalidation.cpp

?? 在線支持向量機C++程序,程序中包含了應用的例子
?? CPP
字號:
/******************************************************************************
*                       ONLINE SUPPORT VECTOR REGRESSION                      *
*                      Copyright 2006 - Francesco Parrella                    *
*                                                                             *
*This program is distributed under the terms of the GNU General Public License*
******************************************************************************/


#ifndef CROSS_VALIDATION_CPP
#define CROSS_VALIDATION_CPP

#include "OnlineSVR.h"
#include <iostream>
#include <fstream>
#include <time.h>


namespace onlinesvr
{

	void OnlineSVR::CrossValidation (Matrix<double>* TrainingSetX, Vector<double>* TrainingSetY, Vector<double>* EpsilonList, Vector<double>* CList, Vector<double>* KernelParamList, int SetNumber, char* ResultsFileName)
	{
		int i, j, k;

		// Partition of the training set
		int SamplesPerSet = static_cast<int>(TrainingSetX->GetLengthRows()/SetNumber);
		
		// Build the Sets
		Vector<Matrix<double>*>* SetX = new Vector<Matrix<double>*>();
		Vector<Vector<double>*>* SetY = new Vector<Vector<double>*>();		
		for (i=0; i<SetNumber; i++) {
			SetX->Add(new Matrix<double>());
			SetY->Add(new Vector<double>());
			for (j=0; j<SamplesPerSet; j++) {
				SetX->GetValue(i)->AddRowCopy(TrainingSetX->GetRowRef(j*SetNumber+i));
				SetY->GetValue(i)->Add(TrainingSetY->GetValue(j*SetNumber+i));
			}
		}
		
		// Open the file
		ofstream File (ResultsFileName, ios::out);
		if (!File) {
			cerr << "Error. It's impossible to create the file." << endl;
			return;
		}		
		File << "Epsilon \t C \t KernelParam \t Error" << endl;

		// Cross Validation
		int IterationsNumber = EpsilonList->GetLength() * CList->GetLength() * KernelParamList->GetLength();
		int CurrentIteration = 0;
		double MinError = 10000;
		double MinEpsilon = 0;
		double MinC = 0;
		double MinKernelParam = 0;
		for (i=0; i<EpsilonList->GetLength(); i++) {
			for (j=0; j<CList->GetLength(); j++) {		
				for (k=0; k<KernelParamList->GetLength(); k++) {
					if(1==0)//if (CurrentIteration==33 || CurrentIteration==34 || CurrentIteration==42)
					{CurrentIteration++; printf("%d\n",CurrentIteration);}
					else {
					double Error = CrossValidation (SetX, SetY, EpsilonList->GetValue(i), CList->GetValue(j), KernelParamList->GetValue(k));
					File << EpsilonList->GetValue(i) << "\t" << CList->GetValue(j) << "\t" << KernelParamList->GetValue(k) << " \t" << Error << endl;
					cout << "Test " << ++CurrentIteration << "/" << IterationsNumber << "\t" << "Epsilon=" << EpsilonList->GetValue(i) << "\t" << "C=" << CList->GetValue(j) << "\t" << "KernelParam=" << KernelParamList->GetValue(k) << " \t" << "Error=" << Error   << endl;
					if (Error<MinError) {
						MinError = Error;
						MinEpsilon = EpsilonList->GetValue(i);
						MinC = CList->GetValue(j);
						MinKernelParam = KernelParamList->GetValue(k);
					}
					}
				}
			}
		}

		// Best Result		
		File << endl << "Best Solution:" << endl;
		File << MinEpsilon << "\t" << MinC << "\t" << MinKernelParam << " \t" << MinError << endl;
		cout << endl << "Best Solution:" << endl;
		cout << MinEpsilon << "\t" << MinC << "\t" << MinKernelParam << " \t" << MinError << endl;

		// Close the file
		File.close();
		
		// Free the memory
		for (i=0; i<SetNumber; i++) {
			delete SetX->GetValue(i);
			delete SetY->GetValue(i);
		}
		delete SetX;
		delete SetY;
	}

	double OnlineSVR::CrossValidation (Vector<Matrix<double>*>* SetX, Vector<Vector<double>*>* SetY, double Epsilon, double C, double KernelParam)
	{
		// Variables
		Vector<double>* Errors = new Vector<double>();
		int i, j;

		// Subdivide TrainingSet into SubSets
		for (i=0; i<SetX->GetLength(); i++)
		{
			// New SVR
			OnlineSVR* SVR = new OnlineSVR();
			SVR->SetEpsilon(Epsilon);
			SVR->SetC(C);
			SVR->SetKernelType(OnlineSVR::KERNEL_RBF);
			SVR->SetKernelParam(KernelParam);
			SVR->SetVerbosity(OnlineSVR::VERBOSITY_NO_MESSAGES);
			// Train with N-1 SubSet
			for (j=0; j<SetX->GetLength(); j++) {
				if (i != j) {					
					SVR->Train(SetX->GetValue(j), SetY->GetValue(j));
				}
			}
			// Test with the other SubSet
			Vector<double>* ErrorList = SVR->Margin(SetX->GetValue(i),SetY->GetValue(i));			
			double MeanError = ErrorList->AbsSum() / static_cast<double>(SetX->GetValue(i)->GetLengthRows());
			delete ErrorList;
			// Free
			Errors->Add(MeanError);
			delete SVR;
		}
		
		// Free the memory
		double MeanError = Errors->AbsSum() / Errors->GetLength();		
		delete Errors;
		return MeanError;
	}

	void OnlineSVR::LeaveOneOut (Matrix<double>* TrainingSetX, Vector<double>* TrainingSetY, Vector<double>* EpsilonList, Vector<double>* CList, Vector<double>* KernelParamList, char* ResultsFileName)
	{
		int i, j, k;
		
		// Open the file
		ofstream File (ResultsFileName, ios::out);
		if (!File) {
			cerr << "Error. It's impossible to create the file." << endl;
			return;
		}
		File << "Epsilon \t C \t KernelParam \t Error" << endl;

		// Leave one out
		int IterationsNumber = EpsilonList->GetLength() * CList->GetLength() * KernelParamList->GetLength();
		int CurrentIteration = 0;
		double MinError = 10000;
		double MinEpsilon = 0;
		double MinC = 0;
		double MinKernelParam = 0;
		for (i=0; i<EpsilonList->GetLength(); i++) {
			for (j=0; j<CList->GetLength(); j++) {		
				for (k=0; k<KernelParamList->GetLength(); k++) {
					double Error = LeaveOneOut (TrainingSetX, TrainingSetY, EpsilonList->GetValue(i), CList->GetValue(j), KernelParamList->GetValue(k));
					File << EpsilonList->GetValue(i) << "\t" << CList->GetValue(j) << "\t" << KernelParamList->GetValue(k) << " \t" << Error << endl;
					cout << "Test " << ++CurrentIteration << "/" << IterationsNumber << "\t" << "Epsilon=" << EpsilonList->GetValue(i) << "\t" << "C=" << CList->GetValue(j) << "\t" << "KernelParam=" << KernelParamList->GetValue(k) << " \t" << "Error=" << Error   << endl;
					if (Error<MinError) {
						MinError = Error;
						MinEpsilon = EpsilonList->GetValue(i);
						MinC = CList->GetValue(j);
						MinKernelParam = KernelParamList->GetValue(k);
					}
				}
			}
		}

		// Best Result		
		File << endl << "Best Solution:" << endl;
		File << MinEpsilon << "\t" << MinC << "\t" << MinKernelParam << " \t" << MinError << endl;
		cout << endl << "Best Solution:" << endl;
		cout << MinEpsilon << "\t" << MinC << "\t" << MinKernelParam << " \t" << MinError << endl;

		// Close the file
		File.close();		
	}


	double OnlineSVR::LeaveOneOut (Matrix<double>* SetX, Vector<double>* SetY, double Epsilon, double C, double KernelParam)
	{
		// Variables
		Vector<double>* Errors = new Vector<double>();
		int i;

		// Train the SVR
		OnlineSVR* SVR = new OnlineSVR();
		SVR->SetEpsilon(Epsilon);
		SVR->SetC(C);
		SVR->SetKernelType(OnlineSVR::KERNEL_RBF);
		SVR->SetKernelParam(KernelParam);
		SVR->SetVerbosity(OnlineSVR::VERBOSITY_NO_MESSAGES);
		SVR->Train(SetX, SetY);

		// Forget a sample and test the errors
		for (i=0; i<SetX->GetLengthRows(); i++)
		{
			OnlineSVR* SVR2 = SVR->Clone();
			SVR2->Forget(i);
			double Error = SVR2->Margin(SetX->GetRowRef(i), SetY->GetValue(i));
			Errors->Add(Error);
			delete SVR2;
		}
		
		// Free the memory
		double MeanError = Errors->AbsSum() / Errors->GetLength();		
		delete SVR;
		delete Errors;
		return MeanError;
	}
}

#endif

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品一区二区在线看| 高清shemale亚洲人妖| 久久免费视频一区| 91黄色免费看| 国产一区二区免费视频| 亚洲成人你懂的| 国产精品久久久久7777按摩| 欧美高清dvd| 91免费看片在线观看| 九色porny丨国产精品| 亚洲va韩国va欧美va| 国产精品第四页| 精品电影一区二区| 欧美日本一道本| 91丨九色porny丨蝌蚪| 国产福利一区二区| 麻豆91在线播放免费| 午夜成人免费电影| 亚洲三级电影全部在线观看高清| 欧美xxxxx牲另类人与| 欧美日韩国产精选| 欧美在线观看视频一区二区| 成人一区二区三区在线观看| 久久草av在线| 麻豆精品一二三| 日本在线不卡视频一二三区| 亚洲综合激情小说| 亚洲精品中文字幕在线观看| 国产欧美一区二区精品久导航| 日韩精品自拍偷拍| 日韩一级免费一区| 日韩三级在线免费观看| 欧美日韩高清一区二区三区| 欧美视频完全免费看| 欧美主播一区二区三区| 色呦呦网站一区| 99久久精品99国产精品| 91在线视频免费91| 在线视频观看一区| 欧美三级日韩三级国产三级| 欧美这里有精品| 欧美日韩精品欧美日韩精品| 欧美在线综合视频| 欧美日韩黄视频| 日韩一区二区三区精品视频| 91麻豆精品国产自产在线观看一区 | 国产婷婷精品av在线| 久久久久99精品国产片| 欧美高清一级片在线观看| 国产精品毛片a∨一区二区三区| 国产精品国产a级| 亚洲欧洲国产日本综合| 亚洲精品日韩综合观看成人91| 一二三四社区欧美黄| 午夜亚洲国产au精品一区二区| 婷婷久久综合九色综合绿巨人| 婷婷中文字幕综合| 另类综合日韩欧美亚洲| 国产伦精品一区二区三区免费迷 | 一区二区三区在线视频免费 | 蜜臀av国产精品久久久久| 国内精品国产三级国产a久久| 国产精品亚洲第一区在线暖暖韩国| 丁香啪啪综合成人亚洲小说| 91丝袜美腿高跟国产极品老师| 91国产丝袜在线播放| 777午夜精品免费视频| 26uuu国产日韩综合| 国产精品看片你懂得| 亚洲成av人片一区二区梦乃| 精品一区二区在线看| 91丝袜国产在线播放| 91精品一区二区三区久久久久久| 久久在线免费观看| 亚洲免费在线观看视频| 日本不卡123| 成人免费的视频| 欧美日韩精品综合在线| 久久午夜色播影院免费高清| 亚洲精品国产精华液| 看电视剧不卡顿的网站| 成人激情免费网站| 欧美精品视频www在线观看| 久久色在线观看| 亚洲国产毛片aaaaa无费看| 国产一区二区三区最好精华液| 91亚洲午夜精品久久久久久| 欧美放荡的少妇| 国产精品丝袜一区| 蜜臀精品一区二区三区在线观看| 白白色 亚洲乱淫| 91精品久久久久久久99蜜桃| 国产精品午夜春色av| 日本美女一区二区三区视频| 97久久精品人人澡人人爽| 欧美大片在线观看| 亚洲综合激情另类小说区| 国产精品影视网| 欧美精品久久天天躁| 国产精品国模大尺度视频| 六月婷婷色综合| 欧美日韩视频在线观看一区二区三区| 久久久不卡影院| 日韩av电影一区| 色婷婷国产精品| 欧美国产禁国产网站cc| 理论片日本一区| 欧美调教femdomvk| 亚洲人成网站影音先锋播放| 国产精品1区2区| 日韩精品在线网站| 日本三级韩国三级欧美三级| 91日韩在线专区| 中文字幕不卡三区| 国产精品99久久久久久有的能看| 欧美日韩精品二区第二页| 亚洲蜜臀av乱码久久精品| 成人丝袜高跟foot| 国产日本欧洲亚洲| 国产精品一区在线观看你懂的| 制服丝袜中文字幕亚洲| 亚洲最新视频在线播放| 一本色道久久综合亚洲aⅴ蜜桃| 国产日韩精品一区二区三区在线| 久久国产尿小便嘘嘘| 欧美一区二区三区四区久久 | 成人精品在线视频观看| 久久综合精品国产一区二区三区| 免费人成精品欧美精品| 欧美人与性动xxxx| 日韩一区精品字幕| 欧美喷水一区二区| 天天影视网天天综合色在线播放| 欧美日韩五月天| 日韩av一区二区在线影视| 7777精品伊人久久久大香线蕉超级流畅| 亚洲最色的网站| 欧美日韩不卡一区二区| 亚洲二区在线视频| 欧美日韩的一区二区| 日韩和欧美一区二区| 日韩亚洲欧美综合| 国产综合久久久久影院| 精品国产污网站| 国产成人在线网站| 国产精品高清亚洲| 一本大道久久a久久精品综合 | 久久成人综合网| 久久久久久久久久久久久女国产乱 | 青青草精品视频| 久久在线观看免费| 成人av影院在线| 亚洲男人的天堂av| 欧美日韩一区二区三区免费看| 亚洲超碰97人人做人人爱| 日韩欧美高清在线| 国产激情一区二区三区四区| 欧美国产精品专区| 欧美中文字幕一区二区三区| 人人超碰91尤物精品国产| 精品国产1区2区3区| www.日韩av| 午夜精品在线看| 久久综合九色欧美综合狠狠| 99久久精品久久久久久清纯| 亚洲大片免费看| 精品国产乱子伦一区| 成人激情电影免费在线观看| 夜夜揉揉日日人人青青一国产精品| 7777精品伊人久久久大香线蕉经典版下载| 精品一区二区三区在线观看国产| 中文欧美字幕免费| 欧美视频精品在线| 国产福利精品一区二区| 亚洲免费观看高清| 日韩欧美国产麻豆| 色噜噜夜夜夜综合网| 日韩福利电影在线| 最近中文字幕一区二区三区| 欧美日韩精品三区| 波多野洁衣一区| 日韩中文字幕一区二区三区| 国产亚洲欧美日韩俺去了| 欧美亚洲精品一区| 国产成人在线网站| 视频一区二区三区入口| 国产精品嫩草影院com| 91精品国产91综合久久蜜臀| 从欧美一区二区三区| 日韩一区欧美二区| 亚洲天堂2016| 久久久国际精品| 欧美片在线播放| 一本久久综合亚洲鲁鲁五月天| 蜜臀久久久久久久| 亚洲欧美日韩国产综合在线| 久久新电视剧免费观看| 制服.丝袜.亚洲.另类.中文| 97se亚洲国产综合自在线观| 国产一区欧美日韩|