本帖最后由 Code 于 2016-7-17 20:08 编辑
本贴的开发环境的安装,请查看我的另一篇帖子
本帖将介绍利用opencv进行基础的人脸检测,这里将用到的 OpenCV 类和函数有:CascadeClassifier,detectMultiScale。整个检测流程可以这样说,利用样本的 Haar特征进行分类器训练,得到级联分类器,加载训练好的人脸分类器,利用分类器在视频帧中查找人脸区域。
Harr特征:
所谓Haar特征,其实就是在窗口的某个位置取一个矩形的小块,然后将这个矩形小块划分为黑色和白色两部分,并分别对两部分所覆盖的像素点(图像上的每个点称为一个像素)的灰度值求和,最后用白色部分像素点灰度值的和减去黑色部分像素点灰度值的和,得到一个Haar特征的值。
Haar特征反映了局部区域之间的相对明暗关系,能够为人脸和非人脸的区分提供有效的信息,例如眼睛区域比周围的皮肤区域要暗,通过Haar特征就可以将这一特点表示出来。
上面是背景的基本介绍,感兴趣的同学可以更加深入探究一下,但是不懂这些背景故事也没事,下面将介绍怎么具体应用。
首先确保你已经在你的树莓派上完成了环境的配置工作,现在新建个py文件(名字你自取)。代码如下(特征文件帖子最后有下载):
- <div><font size="4"><b><div class="blockcode"><blockquote># -*- coding: utf-8 -*-
- import cv2
- import numpy as np
-
- print('Press Esc to exit')
- faceCascade = cv2.CascadeClassifier('haarcascade_frontalface_default.xml') #加载特征文件,使用级联分类器
-
- faceimage = cv2.imread("lena.jpg") #读取lena.jpg文件,要实验人脸检测,可以自行替换相关有正面人脸照片
- gray = cv2.cvtColor(faceimage, cv2.COLOR_BGR2GRAY) #将彩色图片转换为灰度图
- faces = faceCascade.detectMultiScale(gray, 1.3, 5)#将要检测图片灰度图输入,进行人脸检测,输出人脸的区域顶点及长宽值
-
-
- print faces
- print len(faces)
- print faceimage.shape
-
- for (z,(x, y, w, h)) in enumerate(faces): #返回索引及元素:enumerate()
- cv2.rectangle(faceimage, (x, y), (x+w, y+h), (np.random.randint(0,255), np.random.randint(0,255), np.random.randint(0,255)), 2)#画出人脸区域矩形框
- cv2.putText(faceimage, "Face #{}".format(z + 1), (x, y - 10),cv2.FONT_HERSHEY_SIMPLEX, 0.55, (0, 0, 255), 2)#输出文字
- cv2.imshow('FaceDetect', faceimage) #显示图像
-
-
-
- cv2.waitKey(0)
复制代码
保存文件,在lx终端上输入
应该就有这样的效果:
特征文件下载:
haarcascade_frontalface_default.zip
|
|
|
|
|
|