2016-09-04 3 views
2

Я пытаюсь создать обнаружение лица и глаз с помощью библиотеки OpenCV. Это код, с которым я работал. Это плавно работает без ошибок, но единственная проблема, не показывает никаких результатов нет лица и глаз не найдены с этим кодомPython - Невозможно обнаружить лицо и глаза?

import cv2 
import sys 
import numpy as np 
import os 

# Get user supplied values 
imagePath = sys.argv[1] 


# Create the haar cascade 
faceCascade = cv2.CascadeClassifier('C:\Users\Karthik\Downloads\Programs\opencv\sources\data\haarcascades\haarcascad_frontalface_default.xml') 
eyeCascade= cv2.CascadeClassifier('C:\Users\Karthik\Downloads\Programs\opencv\sources\data\haarcascades\haarcascade_eye.xml') 

# Read the image 
image = cv2.imread(imagePath) 
gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY) 

# Detect faces in the image 
faces = faceCascade.detectMultiScale(
    gray, 
    scaleFactor=1.2, 
    minNeighbors=5, 
    minSize=(30, 30), 
    flags = cv2.cv.CV_HAAR_SCALE_IMAGE 
) 

print "Found {0} faces!".format(len(faces)) 

# Draw a rectangle around the faces 
for (x, y, w, h) in faces: 
    cv2.rectangle(image, (x, y), (x+w, y+h), (255, 0, 0), 2) 
    roi_gray = gray[y:y+h, x:x+w] 
    roi_color = image[y:y+h, x:x+w] 

    eyes = eyeCascade.detectMultiscale(roi_gray) 
    for (ex,ey,ew,eh) in eyes: 
      cv2.rectangle(roi_color,(ex,ey),(ex+ew,ey+eh),(0, 255, 0), 2) 


cv2.imshow("Faces found", image) 
print image.shape 
cv2.waitKey(0) 

ответ

2

Для меня это работает в моем jupyter ноутбук на Ubuntu 15.10 с использованием OpenCV 3.1.0-DEV с python 3.4

Может быть, у вас простая опечатка?

haarcascad_frontalface_default.xml =>haarcascade_frontalface_default.xml

и здесь:

eyes = eyeCascade.detectMultiscale(roi_gray) =>eyeCascade.detectMultiScale(roi_gray)

Это мой рабочий код:

%matplotlib inline 

import matplotlib 
import matplotlib.pyplot as plt 

import cv2 
import sys 
import numpy as np 
import os 

# Create the haar cascade 
faceCascade = cv2.CascadeClassifier('haarcascade_frontalface_default.xml') 
eyeCascade= cv2.CascadeClassifier('haarcascade_eye.xml') 

# Read the image 
image = cv2.imread('lena.png', 0) 

if image is None: 
    raise ValueError('Image not found') 

# Detect faces in the image 
faces = faceCascade.detectMultiScale(image) 

print('Found {} faces!'.format(len(faces))) 

# Draw a rectangle around the faces 
for (x, y, w, h) in faces: 
    cv2.rectangle(image, (x, y), (x+w, y+h), 255, 2) 
    roi = image[y:y+h, x:x+w] 

    eyes = eyeCascade.detectMultiScale(roi) 
    for (ex,ey,ew,eh) in eyes: 
      cv2.rectangle(roi,(ex,ey),(ex+ew,ey+eh), 255, 2) 


plt.figure() 
plt.imshow(image, cmap='gray') 
plt.show() 

enter image description here

+0

Большое спасибо за то, что он отлично работает для меня, когда я запускаю этот код через cmd, показывая результаты, но когда я запускаю программу через IDLE, она показывает ошибку [Traceback (последний последний звонок): Файл «D: \ Acads \ 7.1 Sem \ BTP \ FaceDetect-master \ 3.py ", строка 19, в gray = cv2.cvtColor (image, cv2.COLOR_BGR2GRAY) ошибка: .. \ .. \ .. \ .. \ opencv \ modules \ imgproc \ src \ color.cpp: 3739: ошибка: (-215) scn == 3 || scn == 4 в функции cv :: cvtColor] после этой ошибки я удалил [gray = cv2.cvtColor (image, cv2.COLOR_BGR2GRAY)] теперь его работа без ошибок вы можете помочь мне с этим тоже – karthik

+0

Если у вас сейчас есть флаг 0 в вашем 'cv2.imread (file, 0)' вы уже будете считывать входное изображение в виде серого, чтобы ваше изображение имело только 1 канал (scn). Вот почему cvtColor говорит: «Нет, я не могу преобразовать 3-канальное изображение BGR в 1 канал серого, потому что он уже 1 канал, и мне нужно« scn == 3 или scn == 4' ». Поэтому удалите 0 из imread, если вы хотите как цветное, так и серое изображение в коде. – Fabian

+1

Для будущих ошибок, подобных этому, используйте 'print (image.shape)', которые дадут вам (высота, ширина, каналы) вашего изображения. Если он возвращает только кортеж (высота, ширина), то изображение будет выделено в виде серого. – Fabian

 Смежные вопросы

  • Нет связанных вопросов^_^