看过很多介绍HOG的博文,讲的最清楚的是这位博主:http://blog.csdn.net/zouxy09/article/details/7929348

代码如下:

#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 = imread("test.bmp");
vector<Rect> found, found_filtered;
cv::HOGDescriptor people_dectect_hog;
//采用默认的已经训练好了的svm系数作为此次检测的模型
people_dectect_hog.setSVMDetector(cv::HOGDescriptor::getDefaultPeopleDetector()); //对输入的图片img进行多尺度行人检测
//img为输入待检测的图片;found为检测到目标区域列表;参数3为程序内部计算为行人目标的阈值,也就是检测到的特征到SVM分类超平面的距离;
//参数4为滑动窗口每次移动的距离。它必须是块移动的整数倍;参数5为图像扩充的大小;参数6为比例系数,即测试图片每次尺寸缩放增加的比例;
//参数7为组阈值,即校正系数,当一个目标被多个窗口检测出来时,该参数此时就起了调节作用,为0时表示不起调节作用。
people_dectect_hog.detectMultiScale(img, found, , Size(, ), Size(, ), 1.05, ); //从源码中可以看出:
//#define __SIZE_TYPE__ long unsigned int
//typedef __SIZE_TYPE__ size_t;
//因此,size_t是一个long unsigned int类型
size_t i, j; for (i = ; i < found.size(); i++)
{
Rect r = found[i]; //下面的这个for语句是找出所有没有嵌套的矩形框r,并放入found_filtered中,如果有嵌套的
//话,则取外面最大的那个矩形框放入found_filtered中
for (j = ; j <found.size(); j++)
if (j != i && (r&found[j]) == r)
break;
if (j == found.size())
found_filtered.push_back(r);
}
//在图片img上画出矩形框,因为hog检测出的矩形框比实际人体框要稍微大些,所以这里需要
//做一些调整
for (i = ; i <found_filtered.size(); i++)
{
Rect r = found_filtered[i];
r.x += cvRound(r.width*0.1);
r.width = cvRound(r.width*0.8);
r.y += cvRound(r.height*0.07);
r.height = cvRound(r.height*0.8);
rectangle(img, r.tl(), r.br(), Scalar(, , ), );
} namedWindow("检测行人", CV_WINDOW_AUTOSIZE);
imshow("检测行人", img); /*
vector<Rect> found; HOGDescriptor defaultHog;
defaultHog.setSVMDetector(HOGDescriptor::getDefaultPeopleDetector()); //进行检测
defaultHog.detectMultiScale(img, found); //画长方形,框出行人
for (int i = 0; i < found.size(); i++){
Rect r = found[i];
rectangle(img, r.tl(), r.br(), Scalar(0, 0, 255), 3);
} namedWindow("检测行人", CV_WINDOW_AUTOSIZE);
imshow("检测行人", img);
*/
waitKey(); return ;
}

最新文章

  1. linux无法挂载u盘
  2. PgwSlideshow-基于Jquery的图片轮播插件
  3. 命令查看DB restore进度
  4. spring的事务操作
  5. Java 日期比较以及得到前后一天
  6. 使用NSURLSession请求需要AD认证的HTTPS服务器
  7. 基于SourceTree 下的 Git Flow 模型
  8. Guid.NewGuid().ToString()的几种格式
  9. BZOJ2038小Z的袜子(hose)
  10. LINUX 循环fork()
  11. brief introduction JAVA new I/O (NIO)
  12. TF卡分区
  13. CCF-201312-4-有趣的数
  14. C#、.NET Framework、CLR的关系
  15. SpringMVC 环境搭建(HelloWorld)
  16. linux文件查找-find和locate
  17. 【学亮IT手记】PL/SQL游标编程
  18. layui框架--关闭当前页面并刷新父页面
  19. Python AES_ECB_PKCS5加密代码
  20. HTTP是什么连接

热门文章

  1. mysql 多表管理修改
  2. C++初始化列表(good)
  3. CentOS 7下Samba服务部署
  4. CodeForces834D DP + 线段树
  5. P2885 [USACO07NOV]电话线Telephone Wire
  6. MySQL中的编码问题
  7. ettercap插件介绍
  8. JavaScript学习 - 基础(七) - DOM event(事件)
  9. python - 系统交互操作(subprocess)
  10. [转]C++11的enum class &amp; enum struct和enum