OpenCV3  Ref SVM : cv::ml::SVM Class Reference

OpenCV2:

#include <opencv2/core/core.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <opencv2/ml/ml.hpp>
#include <iostream>

using namespace cv;
using namespace std;

int main()
{
float labels[4] = { 0, 0, 1, 1 }; //训练标签数据,前两个表示男生,后两个表示女生
Mat labelsMat(3, 1, CV_32FC1, labels);

float trainingData[4][2] = { { 186,80 },{ 185,81 },{ 160,50 },{ 161,48 } }; //训练数据,两个维度,表示身高和体重
Mat trainingDataMat(3, 2, CV_32FC1, trainingData);

CvSVMParams params; //SVM参数
params.svm_type = CvSVM::C_SVC; //SVM类型. 这里用C_SVC
params.kernel_type = CvSVM::LINEAR; //SVM 核类型
params.term_crit = cvTermCriteria(CV_TERMCRIT_ITER, 100, 1e-6); //终止条件,最大迭代次数和容许误差

CvSVM SVM;
SVM.train(trainingDataMat, labelsMat, Mat(), Mat(), params);//训练

Mat sampleMat = (Mat_<float>(1, 2) << 184, 79); //测试数据,为一男生
float response = SVM.predict(sampleMat);

if (response == 0)
cout << "Boy" << endl;
else if (response == 1)
cout << "Girl" << endl;

return 0;
}

OpenCV3中的SVM:

#include <opencv2/core/core.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <opencv2/ml/ml.hpp>
#include <iostream>

using namespace cv;
using namespace cv::ml;
using namespace std;

int main()
{
float labels[4] = { 0, 0, 1, 1 }; //训练标签数据
Mat labels_train(4, 1, CV_32F, labels);

float trainingData[4][2] = { { 186,80 },{ 185,81 },{ 160,50 },{ 161,48 } }; //训练数据,两个维度
Mat data_train(4, 2, CV_32F, trainingData);

Ptr<SVM> svm = SVM::create();
svm->setKernel(cv::ml::SVM::KernelTypes::LINEAR);
svm->setType(cv::ml::SVM::Types::C_SVC);
svm->setTermCriteria(TermCriteria( TermCriteria::MAX_ITER + TermCriteria::EPS, 1000, FLT_EPSILON ));

svm->train(data_train, ROW_SAMPLE, labels_train);
//svm->save("SVMmodel"); //存储模型
//Ptr<SVM> svm = StatModel::load<SVM>("SVMmodel"); //读取模型

Mat testData(1,2,CV_32F);//测试数据
Mat responses; //预测结果
testData.at<float>(0,0) = 184;
testData.at<float>(0,1) = 79;
svm->predict(testData, responses);
responses.convertTo(responses,CV_32S);

if (response.at<int>(0,0) == 0)
cout << "Boy" << endl;
else if (response.at<int>(0,0) == 1)
cout << "Girl" << endl;

return 0;
}
---------------------
作者:纯洁可爱小昊昊
来源:CSDN
原文:https://blog.csdn.net/jhszh418762259/article/details/60143152
版权声明:本文为博主原创文章,转载请附上博文链接!

最新文章

  1. sizzle分析记录: 自定义伪类选择器
  2. 【JavaScript 插件】实现图片倒影效果 - reflex.js
  3. Validate Disk Failover Failed
  4. 一个人的旅行-Floyd
  5. iOS 关于多线程的一些知识点(不断更新)
  6. GET和POST的区别,就是明信片和信封的区别
  7. java当中的定时器的4种使用方式
  8. dateline 在数据库中就是 整型字段。date函数是可以转换成可读日期的。
  9. [LeetCode] Interleaving String [30]
  10. 利用monkeyrunner实现Android屏幕连续截图
  11. 关于团购VPS的事情报告
  12. Bootstrap开发框架视频整理
  13. 树&#183;AVL树/平衡二叉树
  14. raise ValueError(&quot;Cannot convert {0!r} to Excel&quot;.format(value))
  15. MySQL 分页数据错乱重复
  16. MySQL查询当天、本周、本月数据语句
  17. jQuery(六)
  18. 【C++ Primer 第11章 练习答案】2. 关联容器概述
  19. 利用System.Uri转URL为绝对地址
  20. node(3)Buffer缓冲区

热门文章

  1. 转:Nginx的超时keeplive_timeout配置详解
  2. linux vsftpd 550 create directory operation failed解决方法
  3. spring mvc ,spring boot 整合swagger
  4. PHP 符号大全
  5. stm32_f103使用gcc编译的环境下printf打印函数的实现
  6. 回文数索引(string类erase解题)
  7. 文本处理三剑客与shell正则表达式
  8. 机器阅读理解(看各类QA模型与花式Attention)(转载)
  9. STM32之GD25Q256应用笔记
  10. HDU - 6143 Killer Names(dp记忆化搜索+组合数)