opencv HOG特征提取+svm行人检测

本章内容:


        1. HOG特征描述符计算
        2. opencv系统默认 hog + svm行人检测

 

输出结果

代码

#include <ostream>
#include <opencv.hpp>
#include<opencv2/opencv.hpp>
#include "opencv2/xfeatures2d.hpp"

int main(int argc, char *argv[])
{
    /*
     本章内容:
        1. HOG特征描述符计算
        2. opencv系统默认 hog + svm行人检测
    */
    cv::String fileName = "/home/wang/dev/Image/pepole.jpeg";
    cv::Mat src = cv::imread(fileName);
    cv::Mat src1 = src.clone();
    if(src.data == NULL){
        printf("图像读入失败\n");
        return -1;
    }
    cv::imshow("src",src);
    /*1. HOG特征描述符计算流程
     * 1. 转换成灰度图像
     * 2.定义HOG特征描述符
     * 3.计算特征描述符
    */
    cv::Mat gray;
    cv::cvtColor(src,gray,cv::COLOR_BGR2GRAY);
    cv::HOGDescriptor hogDes(cv::Size(64,128),cv::Size(16,16),cv::Size(8,8),cv::Size(8,8),9);
    std::vector<float> dess;
    std::vector<cv::Point> loca;
    hogDes.compute(gray,dess,cv::Size(0,0),cv::Size(0,0),loca);
    std::cout << "number of HOG descriptors : " << dess.size() << std::endl;

    // 行人检测
    cv::HOGDescriptor hog = cv::HOGDescriptor();
    std::vector<float>  desPeople= hog.getDefaultPeopleDetector();
    std::cout << "desPeople.size() = " << desPeople.size() << std::endl;
    /*
    brief Sets coefficients for the linear SVM classifier.
    @param svmdetector coefficients for the linear SVM classifier.
    */
    hog.setSVMDetector(desPeople);
    std::vector<cv::Rect> Flocations;
    hog.detectMultiScale(src,Flocations,0,cv::Size(8,8),cv::Size(32,32),1.05,2);
    std::cout << "pepole num = " << Flocations.size() << std::endl;
    for(int i=0; i < Flocations.size();i++){
        cv::rectangle(src,Flocations[i],cv::Scalar(0,255,0),4);
    }
    cv::imshow("pepole detect",src);

    cv::waitKey(0);
    return 1;
}

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值