python人脸识别及人脸录入代码
时间: 2023-05-09 17:04:31 浏览: 214
Python人脸识别及人脸录入是非常重要的技能,因为随着人工智能的发展,人脸识别及人脸录入已经成为普遍的需求。在这个技能背后,有很多算法和代码,需要我们仔细学习和深入理解,才能真正掌握这一技能。
Python人脸识别是基于OpenCV库的,OpenCV也是一个强大的计算机视觉库。在进行人脸识别的时候,首先需要训练模型,也就是收集一些有标签的人脸图像,建立一个人脸数据库。建立完数据库后,可以使用OpenCV库来进行人脸识别,具体代码如下:
```
import cv2
# 加载人脸分类器
face_detector = cv2.CascadeClassifier("haarcascade_frontalface_default.xml")
# 加载面部识别模型
model = cv2.face.LBPHFaceRecognizer_create()
model.read("model.xml")
# 加载摄像头
cap = cv2.VideoCapture(0)
while True:
ret, img = cap.read() # 读取摄像头数据
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) # 转换为灰度图像
# 在输入帧上应用分类器
faces = face_detector.detectMultiScale(gray, scaleFactor=1.2, minNeighbors=5)
# 对于每个检测到的脸,进行识别
for (x, y, w, h) in faces:
cv2.rectangle(img, (x, y), (x+w, y+h), (255, 0, 0), 2) #画矩形
roi_gray = gray[y:y+h, x:x+w] # 截取脸部图像
roi_gray = cv2.resize(roi_gray, (200, 200), interpolation=cv2.INTER_AREA)
label, confidence = model.predict(roi_gray) # 预测
print(label) # 打印标签
# 显示视频流
cv2.imshow('video', img)
if cv2.waitKey(1) & 0xff == ord('q'):
break
# 释放资源
cap.release()
cv2.destroyAllWindows()
```
这段代码首先加载了人脸分类器和面部识别模型,然后通过打开摄像头来实时获取视频流,并检测出视频流中的人脸。对于每个检测到的脸,通过模型来进行识别,识别出人的标签并打印出来。最后,将视频流展示出来。
除了人脸识别,还有人脸录入这一重要的技能。人脸录入是将人脸图像存入人脸数据库的过程,在进行人脸识别之前需要先进行录入。以下是人脸录入的代码:
```
import cv2
import os
# 名字和 ID
name = input("请输入你的名字: ")
Id = input("请输入你的工号: ")
# 加载人脸分类器
face_detector = cv2.CascadeClassifier("haarcascade_frontalface_default.xml")
# 加载摄像头
cap = cv2.VideoCapture(0)
# 计数器
c = 0
while True:
ret, img = cap.read() # 读取摄像头数据
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) # 转换为灰度图像
# 在输入帧上应用分类器
faces = face_detector.detectMultiScale(gray, scaleFactor=1.2, minNeighbors=5)
# 对于每个检测到的脸,进行处理
for (x, y, w, h) in faces:
cv2.rectangle(img, (x, y), (x+w, y+h), (255, 0, 0), 2) #画矩形
roi_gray = gray[y:y+h, x:x+w] # 截取脸部图像
roi_gray = cv2.resize(roi_gray, (200, 200), interpolation=cv2.INTER_AREA)
# 写入文件
cv2.imwrite("dataset/User." + str(Id) + '.' + str(c) + ".jpg", roi_gray)
cv2.imshow('image', img)
c += 1
# 终止录入
if cv2.waitKey(1) & 0xff == ord('q'):
break
# 释放资源
cap.release()
cv2.destroyAllWindows()
```
这段代码中首先让用户输入名字和工号,然后通过加载人脸分类器来检测视频流中的人脸。对于每个检测到的脸,通过截取脸部图像并进行缩放,将其存储到dataset目录下,文件命名为“User.工号.编号.jpg”。在录入脸部图像时,需要避免保存重复的图像。如果保存的图片过多,可以自行对图片进行筛选,删除质量比较低的图片。通过以上代码的实现,人脸录入的过程就完成了。
总结一下,Python人脸识别及人脸录入是极其重要的技能,在很多场景中都有应用。在学习和理解这一技能的过程中,需要掌握OpenCV库的基本知识,并学习常见的算法,才能够更好地应用这一技能。
阅读全文