未知部分代码,未检测到面部识别python程序中的未知面部[opencv]

时间:2018-02-12 05:59:27

标签: python python-3.x opencv computer-vision face-recognition

请帮帮我。我正在运行一个人脸识别探测器python程序,它将显示来自sqllite studio数据库的数据,并且我编写了一个代码,显示未知的面部为未知......

import cv2,os
import sqlite3
import numpy as np
from PIL import Image 
import pickle

recognizer = cv2.face.LBPHFaceRecognizer_create()
recognizer.read('trainer/trainer.yml')
cascadePath = "Classifiers/face.xml"
faceCascade = cv2.CascadeClassifier(cascadePath);
path = 'dataSet'

def getProfile(Id):
   conn=sqlite3.connect("facebase.db")
   cmd="SELECT * FROM people WHERE ID="+str(Id)
   cursor=conn.execute(cmd)
   profile=None
   for row in cursor:
       profile=row
   conn.close()
   return profile 


cam = cv2.VideoCapture(0)
font = cv2.FONT_HERSHEY_SIMPLEX #Creates a font
while True:
   ret, im =cam.read()
   gray=cv2.cvtColor(im,cv2.COLOR_BGR2GRAY)
   faces=faceCascade.detectMultiScale(gray, 1.2,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])
       profile=getProfile(Id)
       if(profile!=None):
         cv2.putText(im,str(profile[0]), (x,y+10), font, 2, (255,255,255),3)
         cv2.putText(im,str(profile[1]), (x,y+40), font, 2, (255,255,255),3)

       else:
         Id="Unknown"
         cv2.rectangle(im, (x-22,y-90), (x+w+22, y-22), (0,255,0), -1)
         cv2.putText(im, str(Id), (x,y-40), font, 2, (255,255,255), 3)
cv2.imshow('im',im) 
if cv2.waitKey(10) & 0xFF==ord('q'):
    break
cam.release()
cv2.destroyAllWindows()

问题是代码的未知部分是注意工作。 例如,如果检测到未知面部而不是显示未知面部,则会显示数据库中的随机名称。

       if(profile!=None):
         cv2.putText(im,str(profile[0]), (x,y+10), font, 2, (255,255,255),3)
         cv2.putText(im,str(profile[1]), (x,y+40), font, 2, (255,255,255),3)

       else:
         Id="Unknown"
         cv2.rectangle(im, (x-22,y-90), (x+w+22, y-22), (0,255,0), -1)
         cv2.putText(im, str(Id), (x,y-40), font, 2, (255,255,255), 3)

我正在使用python 3.4和opencv 3.4任何人都可以帮助我???我是python中的新手。

谢谢....

1 个答案:

答案 0 :(得分:1)

我解决了问题,在大多数情况下,conf测量预测的准确性,因此conf将小于50.未知将大于50.所以可以通过添加if(conf)来解决。

    if(conf<60):
            profile=getProfile(Id)
    else:
            Id=0
            profile=getProfile(Id)
    if(profile!=None):
        cv2.rectangle(im, (x-22,y-90), (x+w+80, y-22), (0,255,0), -1)
        cv2.putText(im,str(profile[0]), (x,y-40), font, 2, (255,255,255), 3)
        cv2.putText(im,str(profile[1]), (x+50,y-40), font, 2(255,255,255),3)

而不是

   if(profile!=None):
     cv2.putText(im,str(profile[0]), (x,y+10), font, 2, (255,255,255),3)
     cv2.putText(im,str(profile[1]), (x,y+40), font, 2, (255,255,255),3)

   else:
     Id="Unknown"
     cv2.rectangle(im, (x-22,y-90), (x+w+22, y-22), (0,255,0), -1)
     cv2.putText(im, str(Id), (x,y-40), font, 2, (255,255,255), 3)