用Python实现简单的人脸识别,10分钟搞定!(附源码)

本文介绍如何使用Python和OpenCV构建简单的人脸识别系统,包括收集人脸样本、训练识别模型以及实现实时识别。通过OpenCV的LBPHFaceRecognizer创建模型,结合haarcascade_frontalface_default.xml进行人脸检测。训练完成后,系统能识别预定义的用户。
摘要由CSDN通过智能技术生成

#保存图像,把灰度图片看成二维数组来检测人脸区域

#(这里是建立了data的文件夹,当然也可以设置为其他路径或者调用数据库)

cv2.imwrite(“data/User.”+str(face_id)+‘.’+str(count)+‘.jpg’,gray[y:y+h,x:x+w])

#显示图片

cv2.imshow(‘image’,img)

#保持画面的连续。waitkey方法可以绑定按键保证画面的收放,通过q键退出摄像

k = cv2.waitKey(1)

if k == ‘27’:

break

#或者得到800个样本后退出摄像,这里可以根据实际情况修改数据量,实际测试后800张的效果是比较理想的

elif count >= 800:

break

#关闭摄像头,释放资源

cap.realease()

cv2.destroyAllWindows()

经博主测试,在执行

“face_detector = cv2.CascadeClssifier(r’C:\Users\admin\Desktop\python\data\haarcascade_frontalface_default.xml’)”此语句时,实际路径中的目录名尽量不要有中文字符出现,否则容易报错。

这样,你的电脑就能看到你啦!

2. 通过算法建立对照模型


本次所用的算法为opencv中所自带的算法,opencv较新版本中(我使用的是2.4.8)提供了一个FaceRecognizer类,里面有相关的一些人脸识别的算法及函数接口,其中包括三种人脸识别算法(我们采用的是第三种)

1.eigenface

2.fisherface

3.LBPHFaceRecognizer

LBP是一种特征提取方式,能提取出图像的局部的纹理特征,最开始的LBP算子是在3X3窗口中,取中心像素的像素值为阀值,与其周围八个像素点的像素值比较,若像素点的像素值大于阀值,则此像素点被标记为1,否则标记为0。这样就能得到一个八位二进制的码,转换为十进制即LBP码,于是得到了这个窗口的LBP值,用这个值来反映这个窗口内的纹理信息。

LBPH是在原始LBP上的一个改进,

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值