代码拉取完成,页面将自动刷新
同步操作将从 Submitk/ 人脸识别 Face recognition 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
import cv2
import os
import numpy as np
from PIL import Image
# recognizer = cv2.createLBPHFaceRecognizer()
#detector = cv2.CascadeClassifier("haarcascade/haarcascade_frontalface_default.xml")
#recognizer = cv2.face.LBPHFaceRecognizer_create()
############################################
# 函数名:get_images_and_labels #
# 输入:人脸数据的地址path #
# 返回值:脸的数据集face_samples #
# 编号的数据集ids #
# 作用:获取人脸数据集和编号数据集 #
############################################
def get_images_and_labels(path):
detector = cv2.CascadeClassifier(
"haarcascade/haarcascade_frontalface_default.xml")
image_paths = [os.path.join(path, f) for f in os.listdir(path)]
face_samples = []
ids = []
for image_path in image_paths:
image = Image.open(image_path).convert('L') # 转成灰度图
image_np = np.array(image, 'uint8') # 将灰度图转成矩阵
if os.path.split(image_path)[-1].split(".")[-1] != 'jpg':
continue # 查找jpg结尾的图
image_id = int(os.path.split(image_path)[-1].split(".")[1])
faces = detector.detectMultiScale(image_np)
for (x, y, w, h) in faces:
face_samples.append(image_np[y:y+h, x:x+w])
ids.append(image_id)
return face_samples, ids
############################################
# 函数名:train #
# 输入:无 #
# 返回值:无 #
# 作用:训练人脸模型 #
############################################
def train(facepath,num):
print(facepath)
recognizer = cv2.face.LBPHFaceRecognizer_create()
# recognizer = cv2.face.EigenFaceRecognizer_create()
# recognizer = cv2.face.FisherFaceRecognizer_create()
faces, Ids = get_images_and_labels(facepath)
# print(faces, Ids)
recognizer.train(faces, np.array(Ids))
#recognizer.save('trainner/trainner.xml')
recognizer.save('trainner/'+str(num) + '.xml')
# train()
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。