OpenCV实践之路——行人检测

55 篇文章 205 订阅
45 篇文章 6 订阅


本文由@星沉阁冰不语出品,转载请注明作者和出处。

文章链接: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;
}


效果图如下:





最近开通了微信公众号,感兴趣的同学可以扫码在微信上交流。


  • 2
    点赞
  • 37
    收藏
    觉得还不错? 一键收藏
  • 5
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值