千锋教育-做有情怀、有良心、有品质的职业教育机构

400-811-9990
手机站
千锋教育

千锋学习站 | 随时随地免费学

千锋教育

扫一扫进入千锋手机站

领取全套视频
千锋教育

关注千锋学习站小程序
随时随地免费学习课程

上海
  • 北京
  • 郑州
  • 武汉
  • 成都
  • 西安
  • 沈阳
  • 广州
  • 南京
  • 深圳
  • 大连
  • 青岛
  • 杭州
  • 重庆
当前位置:重庆千锋IT培训  >  技术干货  >  python基于LBPH的人脸识别操作

python基于LBPH的人脸识别操作

来源:千锋教育
发布人:xqq
时间: 2023-11-14 19:36:33

python基于LBPH的人脸识别操作

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

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

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

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

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

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

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

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

importcv2

#加载训练数据集文件

#获取人脸识别对象

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:至少检测多少次,

minSizemaxSize:当前检测区域的最小面积

faces=face_detector.detectMultiScale(gray)#scaleFactor=1.01,minNeighbors=3,

maxSize=(33,33),minSize=(28,28)

#获取脸部特征值

forx,y,w,hinfaces:

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基于LBPH的人脸识别操作,希望能对大家有所帮助。更多Python学习教程请关注IT培训机构:千锋教育。

声明:本站稿件版权均属千锋教育所有,未经许可不得擅自转载。

猜你喜欢LIKE

python中UDP编程实现通信

2023-11-14

python中如何使用numpy.zeros()函数?

2023-11-14

python基于LBPH的人脸识别操作

2023-11-14

最新文章NEW

python中子类与父类的关系

2023-11-14

python实现信息熵的计算代码

2023-11-14

python如何对Python数据表进行检查

2023-11-14

相关推荐HOT

更多>>

快速通道 更多>>

最新开班信息 更多>>

网友热搜 更多>>