Mat 版本SVM训练程序


#include "stdafx.h"
#include <opencv2\opencv.hpp>
#include <iterator>
using namespace cv;
using namespace std;
#include <fstream>
int _tmain(int argc, _TCHAR* argv[])
{
	
	//
	#define len 3600  
	vector<string> img_path;  
	vector<int> img_catg;  
	int nLine = 0;  
	string buf;  
	ifstream svm_data( "1.txt" );  

	while( svm_data )  
	{  
		if( getline( svm_data, buf ) )  
		{  

			if( nLine % 2 == 1 )  
			{  
				img_catg.push_back( atoi( buf.c_str() ) );  
			}  
			else  
			{  
				img_path.push_back( buf );  
			} 
			nLine ++;
		}  
	}  
	svm_data.close();  

	
	/************************训练程序*************************/
	Mat data_Mat;
	int nImgNum = nLine / 2;  
	Mat srcImg_,sampleImg_;
	vector<float> descriptor;
	for( string::size_type i = 0; i != img_path.size(); i++ )  
	{    
		srcImg_ = imread(img_path[i].c_str());
		if( srcImg_.empty())  
		{  
			cout<<" can not load the image: "<<img_path[i].c_str()<<endl;  
			continue;  
		}  	
		
		/*Mat src(48,48,CV_8UC3);//归一化的大小
		Size  dsize(48,48);
		resize(srcImg_,src,dsize);
		hog_.compute(src,descriptor);*/
		descriptor = vec(srcImg_);//计算出自己需要的特征存放在descriptor.自己写的函数可以替换为HOG等特征
		Mat des(descriptor);
		Mat des_=des.reshape(1,1);
		data_Mat.push_back(des_);//特征矩阵,一行为一个特征。
		//cout<<" end processing "<<img_path[i].c_str()<<" "<<img_catg[i]<<endl;
		descriptor.clear();
	}  
	cout<<" end processing "<<endl;
	Mat	res_Mat(img_catg);
	CvSVM svm = CvSVM();  
	CvSVMParams param;  
	CvTermCriteria criteria;  
	criteria = cvTermCriteria( CV_TERMCRIT_EPS, 1000, FLT_EPSILON );  
	param = CvSVMParams( CvSVM::C_SVC, CvSVM::LINEAR, 10.0, 0.09, 1.0, 10.0, 0.5, 1.0, NULL, criteria );  
	svm.train(data_Mat,res_Mat,Mat(),Mat(),param);//训练的data_Mat数据必须为归一化的浮点数
	svm.save( "1.xml" );  



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值