OpenCV人脸检测demo--facedetect

2024-01-23 17:58

本文主要是介绍OpenCV人脸检测demo--facedetect,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

&1 问题来源

  在运行官网的facedetect这个demo的时候,总是不会出来result的图形,电脑右下角提示的错误是“显示器驱动程序已停止响应,而且已恢复 windows 8(R)”。

 

&2 前期处理

  • 修改代码,各种代码上的调试都尝试过,demo运行失败了;
  • 百度上的禁用视觉效果方案,即修改电脑的主题为“windows 经典”主题,demo运行失败了;
  • 百度上的重新安装显卡驱动方案,即重新装集成网卡驱动,导致显示器黑屏,倒腾了一天才整回来,失败;

 

&3 成功解决

  首先,打开注册表,找到HKEY_LOCAL_MACHINE,在SYSTEM中的CurrentControlSet中的Control的GrphicsDrivers上面点击右键,新建QEORD(64位)值(Q),数值名称为:TdrDelay,数值数据为:8,基数不用改变,选择十六进制即可。

  

  然后,在你的项目编译文件夹内加入四个文件,haarcascade_eye_tree_eyeglasses.xml和haarcascade_frontalface_alt.xml、opencv_ffmpeg310_64.dll及opencv_world310d.dll;

  

  在opencv的环境配置中,(前面有博文介绍),去掉可执行文件目录,去掉附加依赖项的opencv_world310.lib,至此,所有的环境配置方面已经完成。

 

&4 demo的代码和运行结果

 

注意:在opencv安装文件夹sources\samples\cpp中的文件facedetect.cpp即是源代码。

  1 #include "opencv2/objdetect.hpp"
  2 #include "opencv2/highgui.hpp"
  3 #include "opencv2/imgproc.hpp"
  4 #include <iostream>
  5 
  6 using namespace std;
  7 using namespace cv;
  8 
  9 static void help()
 10 
 11 {
 12   cout << "\nThis program demonstrates the cascade recognizer. Now you can use Haar or LBP features.\n"
 13   "This classifier can recognize many kinds of rigid objects, once the appropriate classifier is trained.\n"
 14   "It's most known use is for faces.\n"
 15   "Usage:\n"
 16   "./facedetect [--cascade=<cascade_path> this is the primary trained classifier such as frontal face]\n"
 17   " [--nested-cascade[=nested_cascade_path this an optional secondary classifier such as eyes]]\n"
 18   " [--scale=<image scale greater or equal to 1, try 1.3 for example>]\n"
 19   " [--try-flip]\n"
 20   " [filename|camera_index]\n\n"
 21   "see facedetect.cmd for one call:\n"
 22   "./facedetect --cascade=\"../../data/haarcascades/haarcascade_frontalface_alt.xml\" --nested-cascade=\"../../data/haarcascades/haarcascade_eye_tree_eyeglasses.xml\" --scale=1.3\n\n"
 23   "During execution:\n\tHit any key to quit.\n"
 24   "\tUsing OpenCV version " << CV_VERSION << "\n" << endl;
 25 }
 26 
 27 void detectAndDraw(Mat& img, CascadeClassifier& cascade,
 28 CascadeClassifier& nestedCascade,
 29 double scale, bool tryflip);
 30 
 31 string cascadeName;
 32 string nestedCascadeName;
 33 
 34 int main(int argc, const char** argv)
 35 {
 36   VideoCapture capture;
 37   Mat frame, image;
 38   string inputName;
 39   bool tryflip;
 40   CascadeClassifier cascade, nestedCascade;
 41   double scale;
 42 
 43   cv::CommandLineParser parser(argc, argv,
 44     "{help h||}"
 45     "{cascade|haarcascade_frontalface_alt.xml|}"
 46     "{nested-cascade|haarcascade_eye_tree_eyeglasses.xml|}"
 47     "{scale|1|}{try-flip||}{@filename|lena.jpg|}"
 48   );
 49 
 50 
 51   if (parser.has("help"))
 52   {
 53     help();
 54     return 0;
 55   }
 56   cascadeName = parser.get<string>("cascade");
 57   nestedCascadeName = parser.get<string>("nested-cascade");
 58   scale = parser.get<double>("scale");
 59   if (scale < 1)
 60     scale = 1;
 61   tryflip = parser.has("try-flip");
 62   inputName = parser.get<string>("@filename");
 63   if (!parser.check())
 64   {
 65     parser.printErrors();
 66     return 0;
 67   }
 68   if (!nestedCascade.load(nestedCascadeName))
 69     cerr << "WARNING: Could not load classifier cascade for nested objects" << endl;
 70   if (!cascade.load(cascadeName))
 71   {
 72     cerr << "ERROR: Could not load classifier cascade" << endl;
 73     help();
 74     return -1;
 75   }
 76   if (inputName.empty() || (isdigit(inputName[0]) && inputName.size() == 1))
 77   {
 78     int c = inputName.empty() ? 0 : inputName[0] - '0';
 79     if (!capture.open(c))
 80     cout << "Capture from camera #" << c << " didn't work" << endl;
 81   }
 82   else if (inputName.size())
 83   {
 84     image = imread(inputName, 1);
 85     if (image.empty())
 86     {
 87       if (!capture.open(inputName))
 88       cout << "Could not read " << inputName << endl;
 89     }
 90   }
 91   else
 92   {
 93     image = imread("../data/lena.jpg", 1);
 94     if (image.empty()) cout << "Couldn't read ../data/lena.jpg" << endl;
 95   }
 96 
 97   if (capture.isOpened())
 98   {
 99     cout << "Video capturing has been started ..." << endl;
100 
101     for (;;)
102     {
103       capture >> frame;
104       if (frame.empty())
105       break;
106 
107       Mat frame1 = frame.clone();
108       detectAndDraw(frame1, cascade, nestedCascade, scale, tryflip);
109 
110       int c = waitKey(10);
111       if (c == 27 || c == 'q' || c == 'Q')
112       break;
113     }
114   }
115   else
116   {
117     cout << "Detecting face(s) in " << inputName << endl;
118     if (!image.empty())
119     {
120       detectAndDraw(image, cascade, nestedCascade, scale, tryflip);
121       waitKey(0);
122     }
123   else if (!inputName.empty())
124   {
125     /* assume it is a text file containing the
126     list of the image filenames to be processed - one per line */
127     FILE* f = fopen(inputName.c_str(), "rt");
128     if (f)
129     {
130       char buf[1000 + 1];
131       while (fgets(buf, 1000, f))
132       {
133         int len = (int)strlen(buf), c;
134         while (len > 0 && isspace(buf[len - 1]))
135         len--;
136         buf[len] = '\0';
137         cout << "file " << buf << endl;
138         image = imread(buf, 1);
139         if (!image.empty())
140         {
141           detectAndDraw(image, cascade, nestedCascade, scale, tryflip);
142           c = waitKey(0);
143           if (c == 27 || c == 'q' || c == 'Q')
144             break;
145         }
146         else
147         {
148           cerr << "Aw snap, couldn't read image " << buf << endl;
149         }
150       }
151     fclose(f);
152     }
153   }
154 }
155 
156 return 0;
157 }
158 
159 void detectAndDraw(Mat& img, CascadeClassifier& cascade,
160 CascadeClassifier& nestedCascade,
161 double scale, bool tryflip)
162 {
163 double t = 0;
164 vector<Rect> faces, faces2;
165 const static Scalar colors[] =
166 {
167 Scalar(255, 0, 0),
168 Scalar(255, 128, 0),
169 Scalar(255, 255, 0),
170 Scalar(0, 255, 0),
171 Scalar(0, 128, 255),
172 Scalar(0, 255, 255),
173 Scalar(0, 0, 255),
174 Scalar(255, 0, 255)
175 };
176 Mat gray, smallImg;
177 
178 cvtColor(img, gray, COLOR_BGR2GRAY);
179 double fx = 1 / scale;
180 resize(gray, smallImg, Size(), fx, fx, INTER_LINEAR);
181 equalizeHist(smallImg, smallImg);
182 
183 t = (double)cvGetTickCount();
184 cascade.detectMultiScale(smallImg, faces,
185 1.1, 2, 0
186 //|CASCADE_FIND_BIGGEST_OBJECT
187 //|CASCADE_DO_ROUGH_SEARCH
188 | CASCADE_SCALE_IMAGE,
189 Size(30, 30));
190 if (tryflip)
191 {
192 flip(smallImg, smallImg, 1);
193 cascade.detectMultiScale(smallImg, faces2,
194 1.1, 2, 0
195 //|CASCADE_FIND_BIGGEST_OBJECT
196 //|CASCADE_DO_ROUGH_SEARCH
197 | CASCADE_SCALE_IMAGE,
198 Size(30, 30));
199 for (vector<Rect>::const_iterator r = faces2.begin(); r != faces2.end(); r++)
200 {
201 faces.push_back(Rect(smallImg.cols - r->x - r->width, r->y, r->width, r->height));
202 }
203 }
204 t = (double)cvGetTickCount() - t;
205 printf("detection time = %g ms\n", t / ((double)cvGetTickFrequency()*1000.));
206 for (size_t i = 0; i < faces.size(); i++)
207 {
208 Rect r = faces[i];
209 Mat smallImgROI;
210 vector<Rect> nestedObjects;
211 Point center;
212 Scalar color = colors[i % 8];
213 int radius;
214 
215 double aspect_ratio = (double)r.width / r.height;
216 if (0.75 < aspect_ratio && aspect_ratio < 1.3)
217 {
218 center.x = cvRound((r.x + r.width*0.5)*scale);
219 center.y = cvRound((r.y + r.height*0.5)*scale);
220 radius = cvRound((r.width + r.height)*0.25*scale);
221 circle(img, center, radius, color, 3, 8, 0);
222 }
223 else
224 rectangle(img, cvPoint(cvRound(r.x*scale), cvRound(r.y*scale)),
225 cvPoint(cvRound((r.x + r.width - 1)*scale), cvRound((r.y + r.height - 1)*scale)),
226 color, 3, 8, 0);
227 if (nestedCascade.empty())
228 continue;
229 smallImgROI = smallImg(r);
230 nestedCascade.detectMultiScale(smallImgROI, nestedObjects,
231 1.1, 2, 0
232 //|CASCADE_FIND_BIGGEST_OBJECT
233 //|CASCADE_DO_ROUGH_SEARCH
234 //|CASCADE_DO_CANNY_PRUNING
235 | CASCADE_SCALE_IMAGE,
236 Size(30, 30));
237 for (size_t j = 0; j < nestedObjects.size(); j++)
238 {
239 Rect nr = nestedObjects[j];
240 center.x = cvRound((r.x + nr.x + nr.width*0.5)*scale);
241 center.y = cvRound((r.y + nr.y + nr.height*0.5)*scale);
242 radius = cvRound((nr.width + nr.height)*0.25*scale);
243 circle(img, center, radius, color, 3, 8, 0);
244 }
245 }
246 imshow("result", img);
247 }
facedetect源码

 

结果:

 

这篇关于OpenCV人脸检测demo--facedetect的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/637074

相关文章

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

综合安防管理平台LntonAIServer视频监控汇聚抖动检测算法优势

LntonAIServer视频质量诊断功能中的抖动检测是一个专门针对视频稳定性进行分析的功能。抖动通常是指视频帧之间的不必要运动,这种运动可能是由于摄像机的移动、传输中的错误或编解码问题导致的。抖动检测对于确保视频内容的平滑性和观看体验至关重要。 优势 1. 提高图像质量 - 清晰度提升:减少抖动,提高图像的清晰度和细节表现力,使得监控画面更加真实可信。 - 细节增强:在低光条件下,抖

烟火目标检测数据集 7800张 烟火检测 带标注 voc yolo

一个包含7800张带标注图像的数据集,专门用于烟火目标检测,是一个非常有价值的资源,尤其对于那些致力于公共安全、事件管理和烟花表演监控等领域的人士而言。下面是对此数据集的一个详细介绍: 数据集名称:烟火目标检测数据集 数据集规模: 图片数量:7800张类别:主要包含烟火类目标,可能还包括其他相关类别,如烟火发射装置、背景等。格式:图像文件通常为JPEG或PNG格式;标注文件可能为X

基于 YOLOv5 的积水检测系统:打造高效智能的智慧城市应用

在城市发展中,积水问题日益严重,特别是在大雨过后,积水往往会影响交通甚至威胁人们的安全。通过现代计算机视觉技术,我们能够智能化地检测和识别积水区域,减少潜在危险。本文将介绍如何使用 YOLOv5 和 PyQt5 搭建一个积水检测系统,结合深度学习和直观的图形界面,为用户提供高效的解决方案。 源码地址: PyQt5+YoloV5 实现积水检测系统 预览: 项目背景

opencv 滚动条

参数介绍:createTrackbar( trackbarname , "hello" , &alpha_slider ,alpha_max ,  on_trackbar )  ;在标签中显示的文字(提示滑动条的用途) TrackbarName创建的滑动条要放置窗体的名字 “hello”滑动条的取值范围从 0 到 alpha_max (最小值只能为 zero).滑动后的值存放在

android-opencv-jni

//------------------start opencv--------------------@Override public void onResume(){ super.onResume(); //通过OpenCV引擎服务加载并初始化OpenCV类库,所谓OpenCV引擎服务即是 //OpenCV_2.4.3.2_Manager_2.4_*.apk程序包,存

JavaFX应用更新检测功能(在线自动更新方案)

JavaFX开发的桌面应用属于C端,一般来说需要版本检测和自动更新功能,这里记录一下一种版本检测和自动更新的方法。 1. 整体方案 JavaFX.应用版本检测、自动更新主要涉及一下步骤: 读取本地应用版本拉取远程版本并比较两个版本如果需要升级,那么拉取更新历史弹出升级控制窗口用户选择升级时,拉取升级包解压,重启应用用户选择忽略时,本地版本标志为忽略版本用户选择取消时,隐藏升级控制窗口 2.

OpenCV结构分析与形状描述符(11)椭圆拟合函数fitEllipse()的使用

操作系统:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 编程语言:C++11 算法描述 围绕一组2D点拟合一个椭圆。 该函数计算出一个椭圆,该椭圆在最小二乘意义上最好地拟合一组2D点。它返回一个内切椭圆的旋转矩形。使用了由[90]描述的第一个算法。开发者应该注意,由于数据点靠近包含的 Mat 元素的边界,返回的椭圆/旋转矩形数据

树莓派5_opencv笔记27:Opencv录制视频(无声音)

今日继续学习树莓派5 8G:(Raspberry Pi,简称RPi或RasPi)  本人所用树莓派5 装载的系统与版本如下:  版本可用命令 (lsb_release -a) 查询: Opencv 与 python 版本如下: 今天就水一篇文章,用树莓派摄像头,Opencv录制一段视频保存在指定目录... 文章提供测试代码讲解,整体代码贴出、测试效果图 目录 阶段一:录制一段

Verybot之OpenCV应用三:色标跟踪

下面的这个应用主要完成的是Verybot跟踪色标的功能,识别部分还是居于OpenCV编写,色标跟踪一般需要将图像的颜色模式进行转换,将RGB转换为HSV,因为对HSV格式下的图像进行识别时受光线的影响比较小,但是也有采用RGB模式来进行识别的情况,这种情况一般光线条件比较固定,背景跟识别物在颜色上很容易区分出来。         下面这个程序的流程大致是这样的: