使用opencv实现人脸识别的代码
时间: 2023-08-08 09:08:17 浏览: 136
sa.rar_OPENCV 代码_opencv人脸识别_人脸识别
好的,下面是一个基本的使用OpenCV实现人脸识别的Python代码示例。在这个示例中,我们使用OpenCV提供的人脸识别模块和训练好的人脸识别模型来实现人脸识别。
```python
import cv2
# 加载人脸识别模型
face_cascade = cv2.CascadeClassifier('haarcascade_frontalface_default.xml')
# 加载已经训练好的人脸识别模型
recognizer = cv2.face.LBPHFaceRecognizer_create()
recognizer.read('trainer.yml')
# 打开摄像头
cap = cv2.VideoCapture(0)
while True:
# 读取摄像头的画面
ret, img = cap.read()
# 转换为灰度图像
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
# 检测人脸
faces = face_cascade.detectMultiScale(gray, scaleFactor=1.2, minNeighbors=5)
# 遍历所有检测到的人脸
for (x, y, w, h) in faces:
# 绘制人脸矩形框
cv2.rectangle(img, (x, y), (x+w, y+h), (0, 255, 0), 2)
# 提取人脸区域并进行识别
roi_gray = gray[y:y+h, x:x+w]
id_, confidence = recognizer.predict(roi_gray)
# 根据识别结果显示人名和置信度
if confidence < 100:
name = "Person {}".format(id_)
confidence = " {0}%".format(round(100 - confidence))
else:
name = "Unknown"
confidence = " {0}%".format(round(100 - confidence))
cv2.putText(img, name, (x+5, y-5), cv2.FONT_HERSHEY_SIMPLEX, 1, (255, 255, 255), 2)
cv2.putText(img, str(confidence), (x+5, y+h-5), cv2.FONT_HERSHEY_SIMPLEX, 1, (255, 255, 0), 1)
# 显示画面
cv2.imshow('Face Recognition', img)
# 按下q键退出
if cv2.waitKey(1) & 0xFF == ord('q'):
break
# 释放摄像头并关闭窗口
cap.release()
cv2.destroyAllWindows()
```
在上面的代码中,我们使用了OpenCV提供的人脸识别模块`cv2.CascadeClassifier`来检测人脸,并使用已经训练好的人脸识别模型`cv2.face.LBPHFaceRecognizer_create()`来进行人脸识别。具体的实现细节请参考代码注释。
阅读全文