OpenCV读入图片序列进行HOG行人检测并保存为视频
来源:互联网 发布:投资数据库终端 编辑:程序博客网 时间:2024/05/18 16:40
OpenCV读入图片序列进行HOG行人检测并保存为视频
http://blog.csdn.net/masibuaa/article/details/16084467
分类:
版权声明:本文为博主原创文章,未经博主允许不得转载。
此程序是用OpenCV的默认SVM参数进行检测,若图片过大过多,处理起来会比较慢。
- #include <stdio.h>
- #include <iostream>
- #include <fstream>
- #include <opencv2/core/core.hpp>
- #include <opencv2/highgui/highgui.hpp>
- #include <opencv2/imgproc/imgproc.hpp>
- #include <opencv2/objdetect/objdetect.hpp>
- #include <opencv2/ml/ml.hpp>
- using namespace std;
- using namespace cv;
- int main()
- {
- Mat src;
- string ImgName;//图片文件名
- //ifstream fin("Seq4List.txt");//打开图片序列的文件列表
- ifstream fin("subset.txt");
- namedWindow("ImageSeq",0);
- VideoWriter videoWriter;//视频写入器
- videoWriter.open("Seq6.avi", CV_FOURCC('x','v','I','D'),25,Size(1292,964));//注意若图片尺寸与写入器的尺寸不同的话可能失败
- if(!videoWriter.isOpened()) cout<< "创建VideoWriter失败"<<endl;
- HOGDescriptor people_detect_hog; //HOG特征检测器
- //采用默认的已经训练好了的SVM系数作为检测的模型
- people_detect_hog.setSVMDetector(HOGDescriptor::getDefaultPeopleDetector());
- while(getline(fin,ImgName))
- {
- cout<<"处理:"<<ImgName<<endl;
- string fullName = "D:\\TrackingTool-Matlab\\seq4\\" + ImgName;//加上路径名,"\\"表示转义字符"\"
- src = imread(fullName);
- vector<Rect> found, found_filtered; //矩形框数组
- //对输入的图片进行多尺度行人检测,检测窗口移动步长为(8,8)
- people_detect_hog.detectMultiScale(src, found, 0, Size(8, 8), Size(32, 32), 1.05, 2);
- //找出所有没有嵌套的矩形框r,并放入found_filtered中,如果有嵌套的话,则取外面最大的那个矩形框放入found_filtered中
- for(int i=0; i < found.size(); i++)
- {
- Rect r = found[i];
- int j=0;
- for(; j < found.size(); j++)
- if(j != i && (r & found[j]) == r)
- break;
- if( j == found.size())
- found_filtered.push_back(r);
- }
- //画矩形框,因为hog检测出的矩形框比实际人体框要稍微大些,所以这里需要做一些调整
- for(int i=0; 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(src, r.tl(), r.br(), Scalar(0,255,0), 3);
- }
- videoWriter << src;//写入一帧到文件
- imshow("ImageSeq",src);
- waitKey(50);//注意:imshow之后必须有waitKey(),否则无法显示图像
- }
- videoWriter.release();
- //system("pause");
- return 0;
- }
源码下载,环境为VS2010 + OpenCV2.4.4
http://download.csdn.net/detail/masikkk/6547695
0 0
- OpenCV读入图片序列进行HOG行人检测并保存为视频
- OpenCV读入图片序列进行HOG行人检测并保存为视频
- OpenCV读入图片序列进行HOG行人检测并保存为视频
- Opencv中HOG+SVM进行行人检测
- Opencv HOG检测行人
- Opencv HOG检测行人
- Opencv HOG行人检测
- 新手学习opencv九:基于Hog的视频行人检测
- Opencv自带的HOG进行行人检测-QT例程
- 题目:在Opencv中利用HOG进行行人检测
- opencv学习-hog行人检测
- OpenCV实现HOG行人检测
- 【opencv】hog做行人检测
- OpenCV 实现HOG行人检测
- HOG+SVM进行行人检测
- OpenCV 2.4+ C++ HOG行人检测
- OpenCV Demo :行人检测(HOG+SVM)
- Opencv HOG行人检测 源码分析(一)
- centos7 cannot find a valid baseurl for repo base
- Linux Is Not Matrix——zabbix监控mysql
- Android自定义View的一些理解
- css学习
- OpenCV 视频与图片序列相互转换 VideoWriter生成视频流
- OpenCV读入图片序列进行HOG行人检测并保存为视频
- Eigen中的基本函数
- Leetcode 137: (Single Number II)
- 用于并行计算的多线程数据结构,第 1 部分: 设计并发数据结构
- 关于java中的protected一点理解
- 复杂链表的复制
- NOI2015模拟SXK 字符串游戏 后缀数组预处理+主席树查询
- BigDecimal计费
- 常规求幂、二分求幂、快速位求幂