本文由@星沉阁冰不语出品,转载请注明作者和出处。
文章链接:http://blog.csdn.net/xingchenbingbuyu/article/details/51255253
微博:http://weibo.com/xingchenbing
行人检测是视觉领域很热也很有用的一个主题,特别是在无人驾驶中,行人检测的重要性不言而喻。
在之前进行了人脸检测之后,行人检测就显得简单多了。过程大致与人脸检测一样,都是先加载分类器,然后进行多尺度检测。就偷懒不再赘述。感兴趣的可以看人脸检测的这一篇文章:OpenCV实践之路——人脸检测(C++/Python)
这里只是把代码放在这里,没几行,而且都有着注释:
#include <opencv2/core/core.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <opencv2/gpu/gpu.hpp>
//#include <stdio.h>
using namespace cv;
int main(int argc, char** argv)
{
Mat img;
vector<Rect> people;
img = imread("xingren.jpg",1);
//定义HOG对象,采用默认参数,或者按照下面的格式自己设置
HOGDescriptor defaultHog;
//(cv::Size(64, 128), cv::Size(16, 16), cv::Size(8, 8),
//cv::Size(8, 8),9, 1, -1,
//cv::HOGDescriptor::L2Hys, 0.2, true,
//cv::HOGDescriptor::DEFAULT_NLEVELS);
//设置SVM分类器,用默认分类器
defaultHog.setSVMDetector(HOGDescriptor::getDefaultPeopleDetector());
//对图像进行多尺度行人检测,返回结果为矩形框
defaultHog.detectMultiScale(img, people,0,Size(8,8),Size(0,0),1.03,2);
//画长方形,框出行人
for (int i = 0; i < people.size(); i++)
{
Rect r = people[i];
rectangle(img, r.tl(), r.br(), Scalar(0, 0, 255), 3);
}
namedWindow("检测行人", CV_WINDOW_AUTOSIZE);
imshow("检测行人", img);
waitKey(0);
return 0;
}
最近开通了微信公众号,感兴趣的同学可以扫码在微信上交流。