整理使用SVM实现分类的步骤

本文回顾了使用SVM进行物体分类的流程,以《深入理解OpenCV》中的自动分类例程为参考。主要展示了SVM代码实现,强调实际应用中需考虑测试集与训练集的选择、特征选择等方面,该例程通过轮廓的长宽比和面积来区分螺母、螺钉和垫圈。
摘要由CSDN通过智能技术生成

     之前SVM进行项目中待识别物体的分类,过去挺长时间结果有点生疏了,这里梳理一下。因为当初是根据《深入理解OpenCV》自动分类的例程,所以这里仍以此为例。这里只是列出了SVM使用环节的代码,而且本来就是一个小例子,其中测试集训练集的选取、特征的选择等都是最简单的考虑,真正应用,要进行更加全面的考虑。

    这个例程是从传送带中找到螺母、螺钉和垫圈,使用的特征是外轮廓的长宽比和面积的大小,也就是说,使用这两项就能训练SVM模型预测某一个轮廓属于哪一种类别。

 

#include <iostream>
#include <string>
#include <sstream>
#include <cmath>
using namespace std;
#include "opencv2/core.hpp"
#include "opencv2/imgproc.hpp"
#include "opencv2/highgui.hpp"
#include "opencv2/core/utility.hpp"
#include "opencv2/ml.hpp"
using namespace cv;
using namespace cv::ml;

Mat light_pattern;
//创建一个SVM模型
Ptr<SVM> svm;


/**
* Extract the features for all objects in one image  检测一幅图中所有物体的特征
* 
* @param Mat img input image
* @param vector<int> left output of left coordinates for each object 某个轮廓中心的x坐标
* @param vector<int> top output of top coordintates for each object 某个轮廓中心的y坐标
* @return vector< vector<float> > a matrix of rows of features for each object detectedoutput
                    第一层有n个元素,n即有多少个零件,第二次有2个元素,分别是面积和长宽比两个特征
**/
vector< vector<float> > ExtractFeatures(Mat img, vector<int>* left=NULL, vector<int>* top=NULL)
{
    vector< vector<float> > output;
    vector<vector<cv::Point> > contours; //存放轮廓数据
    Mat input1= img.clone();          //把原图复制一份,然后用这个副本去做轮廓检测,因为findContours函数会改变图像
    Mat input;
    vector<Vec4i> hierarchy;
    cvtColor(input1, input, COLOR_BGR2GRAY);
 
    findContours(input, contours, hierarchy, RETR_CCOMP, CHAIN_APPROX_SIMPLE);
    // Check the number of objects detected
    if(contours.size() == 0 )
    {
        return output;
    }
    RNG rng( 0xFFFFFFFF );
    for(int i=0; i<contours.size(); i++)
    {
        //先生成一个全黑的图像
        Mat mask= Mat::zeros(img.rows, img.cols, C
  • 2
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值