TypeError:__init__():与face_recognition调用不兼容的构造函数参数



我试图开发一个人脸识别考勤系统,我像教程一样编码了100%,但我仍然有一些错误,下面是代码:

from face_recognition.api import face_distance
import face_recognition as fr
import os
import cv2
import face_recognition
import numpy as np
import time
from PIL import ImageFont
def getEncodedFaces():
encoded = {}
for dirPath, dNames, fNames in os.walk("./faces"):
for f in fNames:
if f.endswith(".jpg") or f.endswith(".png"):
face = fr.load_image_file("faces/" + f)
encoding = fr.face_encodings(face)[0]
encoded[f.split(".")[0]] + encoding
return encoded
def unknownImageEncoded(img):
face = fr.load_image_file("faces/" + img)
encoding = fr.face_encodings(face)[0]
return encoding
def classifyFace(im):
faces = getEncodedFaces()
facesEncoded = list(faces.values())
knownFaceNames = list(faces.keys())
img = cv2.imread(im, 1)
faceLocations = face_recognition.face_encodings(img)
unknownFaceEncodings = face_recognition.face_encodings(img, faceLocations)
faceNames = []
for faceEncoding in unknownFaceEncodings:
matches = face_recognition.compare_faces()
name = "Unknown"
faceDistances = face_recognition.face_distance(facesEncoded, faceEncoding)
bestMatchIndex = np.argmin(face_distance)
if matches[bestMatchIndex]:
name = knownFaceNames[bestMatchIndex]
faceNames.append(name)
for (top, right, bottom, left), name in zip(faceLocations, faceNames):
cv2.rectangle(img, (left-20, top-20, right+20, bottom+20), (255, 0, 0), cv2.FILLED)
font = ImageFont.truetype("./NotoSansTC-Black.ttf")
cv2.putText(img, name, (left-20, bottom+15), font, 1.0, (255, 255, 255), 2)

while True:
cv2.imshow("Attendance System", img)
if cv2.waitkey(1) & 0xFF == ord("q"):
return faceNames
print(classifyFace("test.jpg"))

这是一个错误:

Traceback (most recent call last):
File "main.py", line 51, in <module>
print(classifyFace("test.jpg"))
File "main.py", line 31, in classifyFace
unknownFaceEncodings = face_recognition.face_encodings(img, faceLocations)
File "C:UsersfamilyAppDataLocalProgramsPythonPython36libsite-packagesface_recognitionapi.py", line 213, in face_encodings
raw_landmarks = _raw_face_landmarks(face_image, known_face_locations, model)
File "C:UsersfamilyAppDataLocalProgramsPythonPython36libsite-packagesface_recognitionapi.py", line 158, in _raw_face_landmarks
face_locations = [_css_to_rect(face_location) for face_location in face_locations]
File "C:UsersfamilyAppDataLocalProgramsPythonPython36libsite-packagesface_recognitionapi.py", line 158, in <listcomp>
face_locations = [_css_to_rect(face_location) for face_location in face_locations]
File "C:UsersfamilyAppDataLocalProgramsPythonPython36libsite-packagesface_recognitionapi.py", line 49, in _css_to_rect
return dlib.rectangle(css[3], css[0], css[1], css[2])
TypeError: __init__(): incompatible constructor arguments. The following argument types are supported:
1. _dlib_pybind11.rectangle(left: int, top: int, right: int, bottom: int)
2. _dlib_pybind11.rectangle(rect: dlib::drectangle)
3. _dlib_pybind11.rectangle(rect: _dlib_pybind11.rectangle)
4. _dlib_pybind11.rectangle()
Invoked with: -0.035434916615486145, -0.12049627304077148, 0.08377307653427124, 0.062198664993047714

以下是目录结构:

test.JPG
main.py
NotoSansTC-Black.otf
faces
|- 呂AA.jpg
|- 呂BB.jpg

有人能告诉我这意味着什么以及如何修复它吗?我试过安装许多不同版本的dlib和人脸识别。我也安装了pybind11,但它仍然会给我同样的错误。我很着急,我真的需要帮助。非常感谢。

为什么要导入face_recognition两次?两次导入face_recognition是不合适的。

compare_faces()取2个自变量,已编码矢量列表和未知编码矢量。

现在专注于你的主要错误,你没有使用face_locations,这意味着它不会从图像中定位你的脸。

您的错误在这里:

faceLocations = face_recognition.face_encodings(img)

相反,使用这个:

faceLocations = face_recognition.face_locations(img)

完整代码:

from face_recognition.api import face_distance
import face_recognition as fr
import os
import cv2
import numpy as np
import time
from PIL import ImageFont
def getEncodedFaces():
encoded = {}
for f in os.listdir(os.path.join('faces')):
face = fr.load_image_file(os.path.join('faces',f))
encoding = fr.face_encodings(face)
if not len(encoding):
continue
encoding = encoding[0]
encoded[f.split(".")[0]] = encoding
return encoded
def unknownImageEncoded(img):
face = fr.load_image_file("faces/" + img)
encoding = fr.face_encodings(face)[0]
return encoding
def classifyFace(im):
faces = getEncodedFaces()
facesEncoded = list(faces.values())
knownFaceNames = list(faces.keys())
img = cv2.imread(im, 1)
faceLocations = fr.face_locations(img)
unknownFaceEncodings = fr.face_encodings(img, faceLocations)
faceNames = []
for faceEncoding, faceloc in zip(unknownFaceEncodings, faceLocations):
top, right, bottom, left = faceloc
matches = fr.compare_faces(facesEncoded, faceEncoding)
name = "Unknown"
faceDistances = fr.face_distance(facesEncoded, faceEncoding)
bestMatchIndex = np.argmin(faceDistances)
if matches[bestMatchIndex]:
name = knownFaceNames[bestMatchIndex]
faceNames.append(name)
cv2.rectangle(img, (left-20, top-20, right+20, bottom+20), (255, 0, 0), cv2.FILLED)
font = ImageFont.truetype("./NotoSansTC-Black.ttf")
cv2.putText(img, name, (left-20, bottom+15), font, 1.0, (255, 255, 255), 2)

image = img[:, :, ::-1]
cv2.imwrite("result.jpg", image)
return faceNames
print(classifyFace("test.jpg"))

此行:for (top, right, bottom, left), name in zip(faceLocations, faceNames):

确保top, right, bottom, left值是整数值,而不是浮点值。只需打印一次即可确认。如果它们是浮点值,则使用int()将它们转换为int。像这样:

for (top, right, bottom, left), name in zip(faceLocations, faceNames):
cv2.rectangle(img, int(left)-20, int(top)-20, int(right)+20, int(bottom)+20), (255, 0, 0), cv2.FILLED)

相关内容

最新更新