【opencv】示例-peopledetect.cpp HOG(方向梯度直方图)描述子和SVM(支持向量机)进行行人检测...

6087888a7f92c9bd70c624febf3cc9e5.png

f1228373c681cbda839d58058f9ba266.png

d98bfec8a728ac7d058355634f270226.png

// 包含OpenCV项目所需的objdetect模块头文件
#include <opencv2/objdetect.hpp>
// 包含OpenCV项目所需的highgui模块头文件,用于图像的显示和简单操作
#include <opencv2/highgui.hpp>
// 包含OpenCV项目所需的imgproc模块头文件,用于图像处理
#include <opencv2/imgproc.hpp>
// 包含OpenCV项目所需的videoio模块头文件,用于视频的读写
#include <opencv2/videoio.hpp>
#include <iostream> // 包含输入输出流的标准头文件
#include <iomanip> // 包含输入输出流格式化的标准头文件// 使用OpenCV和标准命名空间下的所有实体
using namespace cv;
using namespace std;// 定义一个Detector类,用于行人检测
class Detector
{enum Mode { Default, Daimler } m; // 定义两种模式的枚举类型HOGDescriptor hog, hog_d;         // 定义两个HOG描述子对象
public:// 构造函数,初始化模式为Default和两个描述子hog与hog_dDetector() : m(Default), hog(), hog_d(Size(48, 96), Size(16, 16), Size(8, 8), Size(8, 8), 9){// 设置HOG描述子的SVM检测器为默认的行人检测器hog.setSVMDetector(HOGDescriptor::getDefaultPeopleDetector());// 设置hog_d描述子的SVM检测器为Daimler行人检测器hog_d.setSVMDetector(HOGDescriptor::getDaimlerPeopleDetector());}// 切换检测模式的方法void toggleMode() { m = (m == Default ? Daimler : Default); }// 获取当前模式名称的方法string modeName() const { return (m == Default ? "Default" : "Daimler"); }// 执行检测的方法vector<Rect> detect(InputArray img){// 创建一个向量来存储检测到的矩形vector<Rect> found;if (m == Default)// 默认模式下使用hog描述子进行多尺度检测hog.detectMultiScale(img, found, 0, Size(8,8), Size(), 1.05, 2, false);else if (m == Daimler)// Daimler模式下使用hog_d描述子进行多尺度检测hog_d.detectMultiScale(img, found, 0, Size(8,8), Size(), 1.05, 2, true);return found; // 返回检测结果}// 调整检测矩形的方法void adjustRect(Rect & r) const
{// HOG检测器返回的矩形稍大于真实的物体,故稍微缩小矩形以获得更好的效果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);}
};// 定义命令行参数的keys字符串
static const string keys = "{ help h   |   | print help message }""{ camera c | 0 | capture video from camera (device index starting from 0) }""{ video v  |   | use video as input }";// main函数,程序的入口
int main(int argc, char** argv)
{// 创建CommandLineParser对象来解析命令行参数CommandLineParser parser(argc, argv, keys);parser.about("This sample demonstrates the use of the HoG descriptor.");if (parser.has("help")){// 如果存在help参数,则打印帮助信息并退出parser.printMessage();return 0;}// 获取camera和video参数int camera = parser.get<int>("camera");string file = parser.get<string>("video");if (!parser.check()){// 检查参数解析是否有误,如果有则打印错误并退出parser.printErrors();return 1;}VideoCapture cap; // 创建一个VideoCapture对象来捕获视频if (file.empty())// 如果video参数为空则从相机捕获视频cap.open(camera);else{// 否则打开指定的视频文件file = samples::findFileOrKeep(file);cap.open(file);}if (!cap.isOpened()){// 如果视频流打不开则打印错误信息并退出cout << "Can not open video stream: '" << (file.empty() ? "<camera>" : file) << "'" << endl;return 2;}cout << "Press 'q' or <ESC> to quit." << endl;cout << "Press <space> to toggle between Default and Daimler detector" << endl;Detector detector; // 创建一个Detector对象Mat frame;         // 创建一个Mat对象来存储帧for (;;)           // 无限循环{cap >> frame; // 从视频流中读取一帧到frame中if (frame.empty()){// 如果帧为空则打印信息并退出循环cout << "Finished reading: empty frame" << endl;break;}int64 t = getTickCount(); // 获取当前的tick计数vector<Rect> found = detector.detect(frame); // 使用detector检测行人t = getTickCount() - t; // 计算检测所用的时间// 显示窗口{ostringstream buf;// 将模式名称和FPS信息打印到视频帧上buf << "Mode: " << detector.modeName() << " ||| "<< "FPS: " << fixed << setprecision(1) << (getTickFrequency() / (double)t);putText(frame, buf.str(), Point(10, 30), FONT_HERSHEY_PLAIN, 2.0, Scalar(0, 0, 255), 2, LINE_AA);}for (vector<Rect>::iterator i = found.begin(); i != found.end(); ++i){// 迭代找到的矩形,并在视频帧上画出矩形框Rect &r = *i;detector.adjustRect(r);rectangle(frame, r.tl(), r.br(), cv::Scalar(0, 255, 0), 2);}imshow("People detector", frame); // 显示带有检测框的视频帧// 与用户交互const char key = (char)waitKey(1);// 如果用户按下ESC或'q'键,则退出循环if (key == 27 || key == 'q') // ESC{cout << "Exit requested" << endl;break;}// 如果用户按下空格键,则切换检测模式else if (key == ' '){detector.toggleMode();}}return 0; // 程序正常退出
}

本段代码是一个使用OpenCV库的HOG(Histogram of Oriented Gradients,方向梯度直方图)描述子和SVM(Support Vector Machines,支持向量机)进行行人检测的程序。程序定义了Detector类来执行行人检测,可以在两种模式(默认模式和戴姆勒模式)之间切换。通过命令行参数,用户可以选择是从相机实时捕获视频还是读取视频文件进行检测。本程序还支持与用户的简单交互,比如按键切换模式和退出程序。最后在视频中实时标记检测到的行人,并显示当前的模式和帧率(FPS)。

hog.detectMultiScale(img, found, 0, Size(8,8), Size(), 1.05, 2, false);

3e24e5f03481fb2e8b945b2de2ca6dd3.png

624e1d57b12324aada57f0917d909eca.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/616434.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

在vue中配置样式 max-width:100px时,发现和width:100px一样没有对应的递增到最大宽度的效果?怎么回事?怎么解决?

原因&#xff1a; 可能时vue的样式大部分和display相关&#xff0c;有很多的联系&#xff0c;导致不生效 解决&#xff1a; 对设置max-width样式的元素设置display:inline-block;属性&#xff0c;即可生效&#xff0c;实现随着子元素的扩展而扩展并增加固定到最大的宽度

视频批量高效剪辑,支持将视频文件转换为音频文件,轻松掌握视频格式

在数字化时代&#xff0c;视频内容日益丰富&#xff0c;管理和编辑这些视频变得愈发重要。然而&#xff0c;传统的视频剪辑软件往往操作复杂&#xff0c;难以满足高效批量处理的需求。现在&#xff0c;一款全新的视频批量剪辑神器应运而生&#xff0c;它支持将视频文件一键转换…

【opencv】示例-phase_corr.cpp 捕获视频流并通过计算相位相关性来检测画面中的移动...

// 包含OpenCV库的头文件 #include "opencv2/core.hpp" // 包含OpenCV核心功能 #include "opencv2/videoio.hpp" // 包含视频IO功能 #include "opencv2/highgui.hpp" // 包含高级GUI功能&#xff0c;显示图像 #include "opencv2/imgproc.hp…

数据结构之单链表相关刷题

找往期文章包括但不限于本期文章中不懂的知识点&#xff1a; 个人主页&#xff1a;我要学编程(ಥ_ಥ)-CSDN博客 所属专栏&#xff1a;数据结构 数据结构之单链表的相关知识点及应用-CSDN博客 下面题目基于上面这篇文章&#xff1a; 下面有任何不懂的地方欢迎在评论区留言或…

Open CASCADE学习|BRepOffsetAPI_DraftAngle

BRepOffsetAPI_DraftAngle 是 Open CASCADE Technology (OCCT) 中用于创建带有草图斜面的几何体的类。草图斜面是一种在零件设计中常见的特征&#xff0c;它可以在零件的表面上创建一个倾斜的面&#xff0c;通常用于便于零件的脱模或是增加零件的强度。 本例演示了如何创建一个…

mp3怎样才能转换成wav格式?音频互相转换的方法

一&#xff0c;什么是WAV WAV&#xff0c;全称为波形音频文件&#xff08;Waveform Audio File Format&#xff09;&#xff0c;是一种由微软公司和IBM公司联合开发的音频文件格式。自1991年问世以来&#xff0c;WAV格式因其无损的音频质量和广泛的兼容性&#xff0c;成为了多…

在Linux驱动中,如何确保中断上下文的正确保存和恢复?

大家好&#xff0c;今天给大家介绍在Linux驱动中&#xff0c;如何确保中断上下文的正确保存和恢复&#xff1f;&#xff0c;文章末尾附有分享大家一个资料包&#xff0c;差不多150多G。里面学习内容、面经、项目都比较新也比较全&#xff01;可进群免费领取。 在Linux驱动中&am…

配置交换机端口安全

1、实验目的 通过本实验可以掌握&#xff1a; 交换机管理地址配置及接口配置。查看交换机的MAC地址表。配置静态端口安全、动态端口安全和粘滞端口安全的方法。 2、实验拓扑 配置交换机端口安全的实验拓扑如图所示。 配置交换机端口安全的实验拓扑 3、实验步骤 &#xff…

RetinalNet论文笔记

RetinalNet 概述1. 引言2. 相关工作3. 焦点损失4. RetinaNet Detector 检测器5. 实验6. 结论 3. Focal loss3.1. 平衡交叉熵3.2. 焦点损失定义3.3. 类别不平衡和模型初始化3.4. 类别不平衡和两阶段检测器 4. RetinaNet Detector特征金字塔网络骨干&#xff08;Feature Pyramid …

【图论】详解链式前向星存图法+遍历法

细说链式前向星存图法 首先要明白&#xff0c;链式前向星的原理是利用存边来进行模拟图。 推荐左神的视频–建图、链式前向星、拓扑排序 比方说有这样一张图&#xff0c;我们用链式前向星来进行模拟时&#xff0c;可以将每一条边都进行编号&#xff0c;其中&#xff0c;红色的…

【数据挖掘】实验7:高级绘图(上)

实验7&#xff1a;高级绘图&#xff08;上&#xff09; 一&#xff1a;实验目的与要求 1&#xff1a;了解R语言中各种图形元素的添加方法&#xff0c;并能够灵活应用这些元素。 2&#xff1a;了解R语言中的各种图形函数&#xff0c;掌握常见图形的绘制方法。 二&#xff1a;实…

vue3 知识点的补充 之 第一节

01 vue2与vue3的区别 vue2 采用object.defuneProperty()实现 对数组不友好 重写了数组的方法&#xff0c;同时无法监听数组length长度的改变。对于对象只能劫持设置好的数据 新增需要使用vue.set vue3 采用proxy进行代理&#xff0c;不需要重写数组的方法 同时可以监听数组长度…