创新互联Python教程:python基于LBPH的人脸识别操作

创新互联致力于互联网网站建设与网站营销,提供网站设计制作、做网站、网站开发、seo优化、网站排名、互联网营销、小程序设计、公众号商城、等建站开发,创新互联网站建设策划专家,为不同类型的客户提供良好的互联网应用定制解决方案,帮助客户在新的全球化互联网环境中保持优势。

基于LBPH的人脸识别操作原理

1、LBPH(Local Binary Pattern Histogram)将检测到的人脸分为小单元,并将其与模型中的对应单元进行比较,对每个区域的匹配值产生一个直方图。

由于这种方法的灵活性,LBPH 是唯一允许模型样本人脸和检测到的人脸在形状、大小上可以不同的人脸识别算法。

2、调整后的区域中调用 predict()函数

predict()函数返回两个元素的数组:第一个元素是所识别 个体的标签,第二个是置信度评分。

3、所有的算法都有一个置信度评分阈值,置信度评分用来衡量所识别人脸与原模型的差距,0 表示完全匹配。可能有时不想保留所有的识别结果,则需要进一步处理,因此可用自己的算法来估算识别的置信度评分。

4、LBPH一个好的识别参考值要低于 50 ,任何高于 80 的参考值都会被认为是低的置信度评分。

基于LBPH的人脸识别操作实例

import cv2

# 加载训练数据集文件

# 获取人脸识别对象
recognizer = cv2.face.LBPHFaceRecognizer_create()
# 读取训练数据
recognizer.read('trainer/trainer.yml')

# 准备识别图片
img = cv2.imread('6.pgm')

# 将图片灰度
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)

# 加载特征数据
face_detector = cv2.CascadeClassifier('D:/Python/opencv/sources/data/haarcascades
/haarcascade_frontalface_default.xml')
# 参数: scaleFactor(比例因子):图片缩放多少,minNeighbors:至少检测多少次,
minSize maxSize:当前检测区域的最小面积
faces = face_detector.detectMultiScale(gray)  # scaleFactor=1.01, minNeighbors=3, 
maxSize=(33, 33), minSize=(28, 28)

# 获取脸部特征值
for x, y, w, h in faces:
    cv2.rectangle(img, (x, y), (x+w, y+h), (0, 255, 0), thickness=2)
    cv2.circle(img, (x+w//2, y+h//2), radius=w//2, thickness=2, color=(0, 0, 255))

    # 人脸识别
    id, confidence = recognizer.predict(gray[y:y+h, x:x+w])
    print('标签id:', id, '置信评分:', confidence)


# 显示图片
cv2.imshow('result', img)
cv2.waitKey(0)  # 一直显示
cv2.destroyAllWindows()  # 释放资源

网页题目:创新互联Python教程:python基于LBPH的人脸识别操作
转载来于:http://www.csdahua.cn/qtweb/news9/219859.html

网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网