【问题标题】:python cv2.face lacking argumentspython cv2.face缺少参数
【发布时间】:2018-09-12 07:32:52
【问题描述】:

下面附上的代码

import cv2
import numpy as np

recognizer = cv2.face
recognizer.loadTrainingData('trainer/example.yml')
#recognizer.read()
cascadePath = "haarcascade_frontalface_default.xml"
faceCascade = cv2.CascadeClassifier(cascadePath);


cam = cv2.VideoCapture(1)
font = cv2.FONT_HERSHEY_SIMPLEX
while True:
    ret, im =cam.read()
    gray=cv2.cvtColor(im,cv2.COLOR_BGR2GRAY)
    faces=faceCascade.detectMultiScale(gray, 1.3,5)
    for(x,y,w,h) in faces:
        cv2.rectangle(im,(x,y),(x+w,y+h),(225,0,0),2)
        Id, conf = recognizer.predict(gray[y:y+h,x:x+w])
        cv2.PutText(cv2.cv.fromarray(im),str(Id), (x,y+h),font, 255)
    cv2.imshow('face',im) 
    if cv2.waitKey(10) == ord('q'):
        break
cam.release()
cv2.destroyAllWindows()

我发现在这个 opencv 版本中不可能写出像下面这样的代码

recognizer = cv2.createLBPHFaceRecognizer() 
recognizer.load('trainer/example.yml')

目标是将之前收集的数据加载到example.yml中。但是我不确定该怎么做,并且附加的代码几乎没有不完整的参数。

【问题讨论】:

    标签: python opencv3.0 face-recognition opencv3.1 opencv-contrib


    【解决方案1】:

    创建识别器对象:

    recognizer = cv2.face.LBPHFaceRecognizer_create()
    

    要加载数据:

    recognizer.read(filename)
    

    【讨论】:

    • 我在创建数据时也是这样做的,不是为了加载数据。
    • 我认为你可以做识别器.read(filename) 来读取模型。见这里:docs.opencv.org/trunk/dd/d65/…
    猜你喜欢
    • 1970-01-01
    • 2019-08-14
    • 2019-12-06
    • 1970-01-01
    • 1970-01-01
    • 2014-12-20
    • 2021-11-22
    • 2018-09-06
    • 2013-10-23
    相关资源
    最近更新 更多