博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Python学习案例之人脸检测识别
阅读量:5298 次
发布时间:2019-06-14

本文共 2266 字,大约阅读时间需要 7 分钟。

前言

随着科技的发展,人脸识别技术在许多领域得到的非常广泛的应用,手机支付、银行身份验证、手机人脸解锁等等。

识别

废话少说,这里我们使用 opencv 中自带了 haar人脸特征分类器,利用训练好的 haar 特征的 xml 文件,在图片上检测出人脸的坐标,利用这个坐标,我们可以将人脸区域剪切保存,也可以在原图上将人脸框出。

代码实现:

# -*-coding:utf8-*-#import osimport cv2from PIL import Image, ImageDrawfrom datetime import datetime"""分类器 https://github.com/opencv/opencv/tree/master/data/haarcascades安装模块:pip install Pillow   pip install opencv-python博客:https://blog.52itstyle.vip/archives/3771/"""def detectFaces(image_name):    img = cv2.imread(image_name)    face_cascade = cv2.CascadeClassifier(os.getcwd()+"\\haarcascade\\haarcascade_frontalface_alt.xml")    if img.ndim == 3:        gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)    else:        gray = img  # if语句:如果img维度为3,说明不是灰度图,先转化为灰度图gray,如果不为3,也就是2,原图就是灰度图    faces = face_cascade.detectMultiScale(gray, 1.2, 5)  # 1.3和5是特征的最小、最大检测窗口,它改变检测结果也会改变    result = []    for (x, y, width, height) in faces:        result.append((x, y, x + width, y + height))    return result# 保存人脸图def saveFaces(image_name):    faces = detectFaces(image_name)    if faces:        # 将人脸保存在save_dir目录下。        # Image模块:Image.open获取图像句柄,crop剪切图像(剪切的区域就是detectFaces返回的坐标),save保存。        save_dir = image_name.split('.')[0] + "_faces"        os.mkdir(save_dir)        count = 0        for (x1, y1, x2, y2) in faces:            file_name = os.path.join(save_dir, str(count) + ".jpg")            Image.open(image_name).crop((x1, y1, x2, y2)).save(file_name)            count += 1if __name__ == '__main__':    time1 = datetime.now()    result = detectFaces(os.getcwd()+"\\images\\gaoyuanyuan.jpg")    time2 = datetime.now()    print("耗时:" + str(time2 - time1))    if len(result) > 0:        print("有人存在!!---》人数为:" + str(len(result)))    else:        print('视频图像中无人!!')    drawFaces(os.getcwd()+"\\images\\", "hanxue.jpg")    saveFaces(os.getcwd()+"\\images\\gaoyuanyuan.jpg")

识别效果图:

109211-20190302192438127-583797782.jpg

多人识别效果:

109211-20190302192446111-164043419.jpg

经过测试,最终选用了 haarcascade_frontalface_alt.xml 做人脸识别,识别率最高。

人脸检测分类器对比:

级联分类器的类型 XML文件名
人脸检测器(默认) haarcascade_frontalface_default.xml
人脸检测器(快速的Haar) haarcascade_frontalface_alt2.xml
人脸检测器(Tree) haarcascade_frontalface_alt_tree.xml
人脸检测器(Haar_1) haarcascade_frontalface_alt.xml

小结

开源的人脸检测分类器对于标准的人脸识别足够了,要想精确识别比如,侧脸、模糊、光照、遮挡的人脸,只能通过深度机器学习进一步优化识别精度和速度。

源码

转载于:https://www.cnblogs.com/smallSevens/p/10462516.html

你可能感兴趣的文章
bzoj2257
查看>>
Linux查看文件编码格式及文件编码转换<转>
查看>>
Leetcode: Find Leaves of Binary Tree
查看>>
Vue 模板解释
查看>>
http://www.bootcss.com/
查看>>
20145308 《网络对抗》 注入shellcode+Return-to-libc攻击 学习总结
查看>>
将多张图片和文字合成一张图片
查看>>
自己动手写ORM(01):解析表达式树生成Sql碎片
查看>>
如何使用USBWebserver在本机快速建立网站测试环境
查看>>
百度Ueditor编辑器的Html模式自动替换样式的解决方法
查看>>
变量提升
查看>>
线性表可用顺序表或链表存储的优缺点
查看>>
在现有的mysql主从基础上,搭建mycat实现数据的读写分离
查看>>
[Flex] flex手机项目如何限制横竖屏?只允许横屏?
查看>>
tensorflow的graph和session
查看>>
JavaScript动画打开半透明提示层
查看>>
Mybatis生成resulteMap时的注意事项
查看>>
jquery-jqzoom 插件 用例
查看>>
1007. Maximum Subsequence Sum (25)
查看>>
iframe的父子层跨域 用了百度的postMessage()方法
查看>>