pythonの画像認識であるOpenCVを利用して左右両耳の検出を行いたいのですがうまく出来ません。インターネットにある顔認識のソースコードをもとに耳を検出するための「haarcascade_mcs_rightear.xml」「haarcascade_mcs_leftear.xml」を使用しました。
以下のソースコードで右耳の検出を行った場合、画像のように耳を検出しました
しかし、左耳の場合、画像のままの結果です。検出されない状態です。他の耳の画像で行っても同じ状態です。
ソースコードを左耳のみに設定しても検出ができません。
画像の選択がよくないのか、ソースコードの部分が悪いのかを教えていただきたいです。
また、どのようにソースコードを書き替えるのかを教えていただきたいです。
よろしくお願いいたします。
anacondaを利用しています
pythonの環境は Python 3.8.3 です。
windowsは8.1です。
python
1import cv2 2 3# create the haar cascade 4rear_cascade = cv2.CascadeClassifier('haarcascade_mcs_rightear.xml') 5lear_cascade = cv2.CascadeClassifier('haarcascade_mcs_leftear.xml') 6 7# read a file 8img_color = cv2.imread('101.jpg') 9height,width = img_color.shape[:2] 10img_color = cv2.resize(img_color , (int(width*1.0), int(height*1.0))) 11img_gray = cv2.cvtColor(img_color, cv2.COLOR_BGR2GRAY) 12 13rears = rear_cascade.detectMultiScale(img_gray, 1.3, 5) 14lears = lear_cascade.detectMultiScale(img_gray, 1.3, 5) 15 16 17# draw rectangles around the ear 18for (x, y, w, h) in rears: 19 cv2.rectangle(img_color, (x, y), (x+w, y+h), (0, 255, 0), 2) 20 roi_gray = img_gray[y:y+h, x:x+w] 21 roi_color = img_color[y:y+h, x:x+w] 22 rears = rear_cascade.detectMultiScale(roi_gray) 23 24 for (x, y, w, h) in lears: 25 cv2.rectangle(img_color, (x, y), (x+w, y+h), (0, 255, 0), 2) 26 roi_gray = img_gray[y:y+h, x:x+w] 27 roi_color = img_color[y:y+h, x:x+w] 28 lears = lear_cascade.detectMultiScale(roi_gray) 29 30cv2.imshow("Ears found", img_color) 31cv2.waitKey(0) 32cv2.destroyAllWindows() 33cv2.imwrite('101-1.jpg', img_color)