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

相关文章

使用Python和OpenCV库实现实时颜色识别系统

《使用Python和OpenCV库实现实时颜色识别系统》:本文主要介绍使用Python和OpenCV库实现的实时颜色识别系统,这个系统能够通过摄像头捕捉视频流,并在视频中指定区域内识别主要颜色(红... 目录一、引言二、系统概述三、代码解析1. 导入库2. 颜色识别函数3. 主程序循环四、HSV色彩空间详解

OpenCV实现实时颜色检测的示例

《OpenCV实现实时颜色检测的示例》本文主要介绍了OpenCV实现实时颜色检测的示例,通过HSV色彩空间转换和色调范围判断实现红黄绿蓝颜色检测,包含视频捕捉、区域标记、颜色分析等功能,具有一定的参考... 目录一、引言二、系统概述三、代码解析1. 导入库2. 颜色识别函数3. 主程序循环四、HSV色彩空间

Python中OpenCV与Matplotlib的图像操作入门指南

《Python中OpenCV与Matplotlib的图像操作入门指南》:本文主要介绍Python中OpenCV与Matplotlib的图像操作指南,本文通过实例代码给大家介绍的非常详细,对大家的学... 目录一、环境准备二、图像的基本操作1. 图像读取、显示与保存 使用OpenCV操作2. 像素级操作3.

C/C++中OpenCV 矩阵运算的实现

《C/C++中OpenCV矩阵运算的实现》本文主要介绍了C/C++中OpenCV矩阵运算的实现,包括基本算术运算(标量与矩阵)、矩阵乘法、转置、逆矩阵、行列式、迹、范数等操作,感兴趣的可以了解一下... 目录矩阵的创建与初始化创建矩阵访问矩阵元素基本的算术运算 ➕➖✖️➗矩阵与标量运算矩阵与矩阵运算 (逐元

C/C++的OpenCV 进行图像梯度提取的几种实现

《C/C++的OpenCV进行图像梯度提取的几种实现》本文主要介绍了C/C++的OpenCV进行图像梯度提取的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录预www.chinasem.cn备知识1. 图像加载与预处理2. Sobel 算子计算 X 和 Y

C/C++和OpenCV实现调用摄像头

《C/C++和OpenCV实现调用摄像头》本文主要介绍了C/C++和OpenCV实现调用摄像头,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录准备工作1. 打开摄像头2. 读取视频帧3. 显示视频帧4. 释放资源5. 获取和设置摄像头属性

c/c++的opencv图像金字塔缩放实现

《c/c++的opencv图像金字塔缩放实现》本文主要介绍了c/c++的opencv图像金字塔缩放实现,通过对原始图像进行连续的下采样或上采样操作,生成一系列不同分辨率的图像,具有一定的参考价值,感兴... 目录图像金字塔简介图像下采样 (cv::pyrDown)图像上采样 (cv::pyrUp)C++ O

c/c++的opencv实现图片膨胀

《c/c++的opencv实现图片膨胀》图像膨胀是形态学操作,通过结构元素扩张亮区填充孔洞、连接断开部分、加粗物体,OpenCV的cv::dilate函数实现该操作,本文就来介绍一下opencv图片... 目录什么是图像膨胀?结构元素 (KerChina编程nel)OpenCV 中的 cv::dilate() 函

qtcreater配置opencv遇到的坑及实践记录

《qtcreater配置opencv遇到的坑及实践记录》我配置opencv不管是按照网上的教程还是deepseek发现都有些问题,下面是我的配置方法以及实践成功的心得,感兴趣的朋友跟随小编一起看看吧... 目录电脑环境下载环境变量配置qmake加入外部库测试配置我配置opencv不管是按照网上的教程还是de

python+OpenCV反投影图像的实现示例详解

《python+OpenCV反投影图像的实现示例详解》:本文主要介绍python+OpenCV反投影图像的实现示例详解,本文通过实例代码图文并茂的形式给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一、前言二、什么是反投影图像三、反投影图像的概念四、反向投影的工作原理一、利用反向投影backproj