三十、项目实战:实时人脸检测

OpenCV3.3之后的版本都支持了深度学习框架,具体的模型相关路径如下图所示
在这里插入图片描述

一、相关文件下载

前期准备工作:
下载两个文件:下载链接
在这里插入图片描述
最好放到跟项目一块,到时候方便调用

二、代码

yy_main.cpp

pbtxt_pathpb_path为下载的那俩文件的路径

cv::dnn::Net net = cv::dnn::readNetFromTensorflow(pb_path, pbtxt_path);
读取得到神经网络对象net

VideoCapture capture(0);,这是调用本地摄像头,要是播放视频,可以将参数0换成视频的路径字符串即可,路径记得是正斜杠哈

cv::Mat frame;
用于存储视频中的每一帧数据信息

capture.read(frame);
读取每一帧数据信息

flip(frame,frame,1);
如果是调用本地摄像头的话,可能需要对视频内容进行翻转一下,摄像头详细内容可参考博文:二十二、摄像头的调用

cv::Mat blob = cv::dnn::blobFromImage(frame, 1.0, Size(300, 300), cv::Scalar(104, 177, 123), false, false);
blobFromImage主要是用来对图片进行预处理
参数一:frame,将要输入神经网络进行处理的图片
参数二:1.0,该参数得优先考虑到参数四,当我们将图片减去平均值之后,还可以对剩下的像素值进行一定的尺度缩放,默认值是1.0;若需要减去平均像素之后的值,全部缩小一半,那么可以将该参数设为1/2即可
参数三:Size(300, 300),训练时,输入的图片大小
参数四:cv::Scalar(104, 177, 123),对BGR通道的像素求一个平均值,然后将每个像素值减去平均值,得到像素之间的相对值,尽可能减少光照等因素的影响;OpenCV给出了均值,如下图所示,当然OpenCV给出的肯定是按照BGR顺序来的
参数五:OpenCV中图片通道顺序是BGR,但是平均值假设的顺序是RGB,所以如果需要交换R和G,那么就要设置为true;这里是通过查阅OpenCV给出的均值进行填入的,故也是BGR顺序,不需要交换
参数六:是否对图片进行裁剪,这里就是false即可

下面就是参数四的设置由来
在这里插入图片描述
net.setInput(blob);
把网络传进去

cv::Mat probs = net.forward();
反向传播求梯度求结果,得到的返回结果为一个个的box,大小为1×1×N×7,N代表有多少张人脸,每个人脸有7个值;7个值得前两个不需要解析,第三个值是置信度,后四个值是左上角和右下角得坐标,后期需要这些坐标来进行框人脸

Mat detectMat(probs.size[2], probs.size[3], CV_32F, probs.ptr<float>());
人脸信息是四维,解析人脸数据信息

detectMat.rows,共有7行,每一行都是float数据

float conf = detectMat.at<float>(row, 2);
第三个是置信度,获取到置信度,置信度超过多少就算是人脸,根据情况而定

float x1 = detectMat.at<float>(row, 3) * frame.cols;
float y1 = detectMat.at<float>(row, 4) * frame.rows;
float x2 = detectMat.at<float>(row, 5) * frame.cols;
float y2 = detectMat.at<float>(row, 6) * frame.rows;
得到左上角(x1,y1)和右下角(x2,y2)坐标

因为预测得到得detectMat.at<float>(row, 3)是0-1之间的,目前是在图片上进行显示,故再乘以对应的每帧图像的行或列即可,例如这个是乘以原图的列frame.cols,得到实际人脸左上角关键点在图片中的实际的x位置,其他也都类似

cv::Rect box(x1, y1, x2 - x1, y2 - y1);
定义进行对象,参数分别为起始坐标和宽高信息

cv::rectangle(frame, box, cv::Scalar(255, 0, 0), 2, 8);
绘制矩形框,具体可参考博文:十四、图像几何形状绘制

#include<opencv2/opencv.hpp>
#include<iostream>using namespace cv;int main(int argc, char** agrv) {std::string pbtxt_path = "E:/C++_workspace/finally_face/opencv_face_detector.pbtxt";std::string pb_path = "E:/C++_workspace/finally_face/opencv_face_detector_uint8.pb";cv::dnn::Net net = cv::dnn::readNetFromTensorflow(pb_path, pbtxt_path);VideoCapture capture(0);cv::Mat frame;while (true) {capture.read(frame);//也可以通过之前的滤波等操作实现美颜效果//其实本质都是对每帧图像frame进行处理的而已//GaussianBlur(frame, frame, Size(3, 3), 1, 1);flip(frame,frame,1);//左右翻转if (frame.empty()) {break;}cv::Mat blob = cv::dnn::blobFromImage(frame, 1.0, Size(300, 300), cv::Scalar(104, 177, 123), false, false);net.setInput(blob);cv::Mat probs = net.forward();//1*1*N*7Mat detectMat(probs.size[2], probs.size[3], CV_32F, probs.ptr<float>());for (int row = 0; row < detectMat.rows; row++) {float conf = detectMat.at<float>(row, 2);if (conf > 0.5) {float x1 = detectMat.at<float>(row, 3) * frame.cols;float y1 = detectMat.at<float>(row, 4) * frame.rows;float x2 = detectMat.at<float>(row, 5) * frame.cols;float y2 = detectMat.at<float>(row, 6) * frame.rows;cv::Rect box(x1, y1, x2 - x1, y2 - y1);cv::rectangle(frame, box, cv::Scalar(255, 0, 0), 2, 8);}}cv::imshow("frame", frame);int c = waitKey(10);if (c == 27) {break;}}cv::waitKey(0);capture.release();cv::destroyAllWindows();return 0;
}

项目结构如下:
在这里插入图片描述

运行效果如下:
在这里插入图片描述

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

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

相关文章

Java 学习和实践笔记(20):static的含义和使用

static的本义是静止的。在计算机里就表示静态变量。 在Java中&#xff0c;从内存分析图上可以看到&#xff0c;它与类、常量池放在一个区里&#xff1a; 从图可以看到&#xff0c;普通的方法和对象属性&#xff0c;都在heep里&#xff0c;而static则在方法区里。 static声明的…

[晓理紫]每日论文分享(有中文摘要,源码或项目地址)--大模型、扩散模型

专属领域论文订阅 VX 关注{晓理紫}&#xff0c;每日更新论文&#xff0c;如感兴趣&#xff0c;请转发给有需要的同学&#xff0c;谢谢支持 如果你感觉对你有所帮助&#xff0c;请关注我&#xff0c;每日准时为你推送最新论文。 分类: 大语言模型LLM视觉模型VLM扩散模型视觉语言…

STL - 并查集

1、并查集原理 在一些应用问题中&#xff0c;需要将n个不同的元素划分成一些不相交的集合&#xff1b;开始时&#xff0c;每个元素自成一个 单元素集合&#xff0c;然后按一定的规律将归于同一组元素的集合合并&#xff1b;在此过程中要反复用到查询某一 个元素归属于那个集合的…

Ps:明度直方图

明度 Luminosity直方图显示了图像中各个亮度级别的像素分布情况。 与 RGB 直方图不同&#xff0c;“明度”直方图专注于图像的亮度信息&#xff0c;而不是单独的颜色信息。 在“直方图”面板的通道中选择“明度”。 “明度”直方图提供了一种量化的方式来理解图像的整体明暗结构…

速度提高100倍 - 扩展 RAG 应用程序,以实现数十亿个嵌入,并行计算余弦相似度

原文链接&#xff1a;100x Faster — Scaling Your RAG App for Billions of Embeddings 2024 年 2 月 15 日 RAG应用程序最大的问题之一是它们的计算检索时间。想象一下&#xff0c;你有一个向量数据库&#xff0c;包含一万亿条Embedding向量的记录。当您尝试将用户查询与一…

idea 打jar包、lib文件夹

idea目录文件 idea四层级结构 idea操作Java文件的基本单位&#xff1a;项目&#xff08;Project&#xff09;。对应四级结构 第1层级架构&#xff1a;项目&#xff08;project&#xff09; 在 IntelliJ IDEA 中Project是最顶级的结构单元&#xff0c;然后就是Module&#xf…

MySQL知识点总结(六)——InnoDB底层架构

MySQL知识点总结&#xff08;六&#xff09;——InnoDB底层架构 InnoDB底层架构总览InnoDB底层各组件分析Buffer PoolChange BufferLog BufferAdaptive Hash IndexSystem TablesapceUndo TablespacesRedo Log InnoDB底层架构总览 关于InnoDB底层架构&#xff0c;网上有一张非常…

Linux之JAVA环境配置Tomcat离线安装与启动

一&#xff0c;安装jdk和Tomcat 1.1上传JDK跟Tomcat 1.2解压 解压tomcat tar -zxvf apache-tomcat-8.5.20.tar.gz 解压jdk tar -zxvf jdk-8u151-linux-x64.tar.gz 1.3.配置环境变量 vim /etc/profile 在最后加上&#xff1a; #java environment export JAVA_HOME/usr/local/ja…

异步框架Celery在Django中的运用

参考博客&#xff1a;https://www.cnblogs.com/pyedu/p/12461819.html 参考视频&#xff1a;01 celery的工作机制_哔哩哔哩_bilibili 定义&#xff1a;简单灵活、处理大量消息的分布式系统&#xff0c;专注于实时处理异步队列&#xff0c;支持任务调度 主要架构&#xff1a; …

软件实例,物流货运配货单打印模板软件单据打印查询管理系统软件教程,可以同时打印标签或补打

软件实例&#xff0c;物流货运配货单打印模板软件单据打印查询管理系统软件教程&#xff0c;可以同时打印标签或补打 一、前言 以下软件教程以 佳易王物流单打印查询系统V17.1为例说明 软件文件下载可以点击最下方官网卡片——软件下载——试用版软件下载 这个版本在原来基…

【软件使用】postman使用教程

​ &#x1f34e;个人博客&#xff1a;个人主页 &#x1f3c6;个人专栏&#xff1a;软件安装及使用 ⛳️ 功不唐捐&#xff0c;玉汝于成 ​ 目录 前言 正文 步骤1&#xff1a;安装Postman 步骤2&#xff1a;发送请求 步骤3&#xff1a;管理环境变量 步骤4&#xff1…

Leetcode 26-30题

删除有序数组中的重复项 给定一个有序数组&#xff0c;要求原地删除重复出现的元素&#xff0c;返回删除后的数组的长度。 这里的原地删除其实可以这样表示&#xff0c;用双指针从前往后扫一遍&#xff0c;遇到新的没出现过的元素就放到前面去&#xff0c;就可以实现删除后的数…

Linux线程同步(2)死锁与互斥锁

死锁&#xff08;Deadlock&#xff09;是指两个或两个以上的进程&#xff08;或线程&#xff09;在执行过程中&#xff0c;由于竞争资源或者由于彼此通信而造成的一种阻塞的现象&#xff0c;若无外力作用&#xff0c;它们都将无法推进下去。此时称系统处于死锁状态或系统产生了…

Java实现就医保险管理系统 JAVA+Vue+SpringBoot+MySQL

目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 科室档案模块2.2 医生档案模块2.3 预约挂号模块2.4 我的挂号模块 三、系统展示四、核心代码4.1 用户查询全部医生4.2 新增医生4.3 查询科室4.4 新增号源4.5 预约号源 五、免责说明 一、摘要 1.1 项目介绍 基于JAVAVue…

【前端素材】推荐优质后台管理系统Qovex平台模板(附源码)

一、需求分析 1、定义 后台管理系统是一种用于管理和监控网站、应用程序或系统的在线工具。它通常是通过网页界面进行访问和操作&#xff0c;用于管理网站内容、用户权限、数据分析等。后台管理系统是网站或应用程序的控制中心&#xff0c;管理员可以通过后台系统进行各种管理…

构造函数,原型,实例,类的关系整理

视频来源js原型链、构造函数和类_哔哩哔哩_bilibili 如视频所说&#xff0c;构造函数的prototype指向原型&#xff0c;实例化的对象的__proto__指向原型&#xff0c;原型通过constructor指向构造函数&#xff0c;正如class里面的constructor方法就相当于Person构造函数一样&am…

基于PID-bang-bang控制算法的卫星姿态控制matlab仿真

目录 1.课题概述 2.系统仿真结果 3.核心程序与模型 4.系统原理简介 5.完整工程文件 1.课题概述 基于PID-bang-bang控制算法的卫星姿态控制。仿真输出控制器的控制收敛曲线&#xff0c;卫星姿态调整过程的动画。 2.系统仿真结果 3.核心程序与模型 版本&#xff1a;MATLAB…

前后端联调可能出现的问题

调不到后端数据 前后端传参方式不一样 --- formdata 主要接收文件 或者有文件和数据 --- json 纯数据

springboot+vue项目部署配置开机自启动

1.前端部属 下载nginx解压&#xff0c;在nginx\conf下找到nginx.conf 添加如下代码 server {listen 8081;server_name localhost;charset utf-8;location / {root F:/1ceshi/dist; #前端打包路径try_files $uri $uri/ /index.html;index index.html index.htm;}l…

本地创建Git仓库

在 Windows 下&#xff0c;可以通过以下步骤在本地创建一个 并模拟远程Git 仓库。 1、在命令行中打开模拟远程Git 仓库目标文件夹&#xff1a; 打开命令提示符或 PowerShell。例如&#xff1a; 创建裸仓库&#xff08;模拟远程仓库&#xff09;&#xff1a;创建一个裸仓库&am…