前提・実現したいこと
顔の動画をフレーム分割し、その分割した画像から指定範囲の緑色の成分(RGBのG成分)を取得しプロットするプログラムを作成しています。顔範囲を事前に設定しておくとプログラムは正常に動きますが、顔範囲をプログラムにより取得することによって範囲をきめるプログラムに変更したところエラーがでてしまいわからなくなりました。
発生している問題・エラーメッセージ
Traceback (most recent call last):
File "face_detect.py", line 51, in <module>
face=cascade.detectMultiScale(images_face)
TypeError: Expected Ptrcv::UMat for argument 'image'
該当のソースコード
python
1 2import numpy as np 3import matplotlib.pyplot as plt 4import pandas as pd 5import cv2 6import seaborn as sns 7import os 8import shutil 9from scipy import signal 10import glob 11from scipy import fftpack 12 13HAAR_FILE="haarcascade_frontalface_default.xml" 14cascade=cv2.CascadeClassifier(HAAR_FILE) 15 16#フレーム分割 17def frame_split(video_file='./image_wave.mp4', image_dir='./image_wave/', 18 image_file='image_wave-%s.png'): 19 if os.path.exists(image_dir): 20 shutil.rmtree(image_dir) 21 22 if not os.path.exists(image_dir): 23 os.makedirs(image_dir) 24 25 i = 0 26 27 cap = cv2.VideoCapture(video_file) 28 while (cap.isOpened()): 29 flag, frame = cap.read() # Capture frame-by-frame 30 if flag == False: 31 break 32 cv2.imwrite(image_dir + image_file % str(i).zfill(6), 33 frame) 34 print('Save', image_dir + image_file % str(i).zfill(6)) 35 i += 1 36 37 cap.release() 38 39frame_split("20201119_Trim.mp4") 40 41#画像ファイルを格納,時系列にソート 42files = glob.glob("image_wave/*.png") 43files.sort() 44 45#画像を読み込み,green成分を抽出 46images = [cv2.imread(files[i]) for i in range(len(files))] 47images_green = [pd.DataFrame(images[j][:,:,1]) for j in range(len(images))] 48 49 50# #parameter(顔のおでこの座標) 51images_face = [cv2.imread(files[i]) for i in range(len(files))] 52face=cascade.detectMultiScale(images_face) 53 54for x,y,w,h in face: 55 #ほっぺあたり 56 xx=int(x+(5/9)*w) 57 yy=int(y+(1/13)*h) 58 zz=int(x+(6/9)*w) 59 ww=int(y+(2/13)*h) 60 61in1 = yy 62in2 = ww 63co1 = xx 64co2 = zz 65 66#メディアンフィルタによる平滑化(iloc[行番号x,列番号y]) 67images_green_median = [cv2.medianBlur(images_green[i].iloc[ in1 : in2 , co1 :co2 ].values,ksize=5) for i in range(len(images_green))] 68 69#平均値を算出 70img_mean = [images_green_median[i].mean() for i in range(len(images_green_median))] 71 72 73plt.plot(img_mean) 74 75plt.show()
補足情報(FW/ツールのバージョンなど)
いかのようにするとエラーは起きません。顔取得のところで間違っているみたいです
python
1 2import numpy as np 3import matplotlib.pyplot as plt 4import pandas as pd 5import cv2 6import seaborn as sns 7import os 8import shutil 9from scipy import signal 10import glob 11from scipy import fftpack 12 13#フレーム分割 14def frame_split(video_file='./image_wave.mp4', image_dir='./image_wave/', 15 image_file='image_wave-%s.png'): 16 if os.path.exists(image_dir): 17 shutil.rmtree(image_dir) 18 19 if not os.path.exists(image_dir): 20 os.makedirs(image_dir) 21 22 i = 0 23 24 cap = cv2.VideoCapture(video_file) 25 while (cap.isOpened()): 26 flag, frame = cap.read() # Capture frame-by-frame 27 if flag == False: 28 break 29 cv2.imwrite(image_dir + image_file % str(i).zfill(6), 30 frame) 31 print('Save', image_dir + image_file % str(i).zfill(6)) 32 i += 1 33 34 cap.release() 35 36frame_split("予備実験1.mov") 37 38#画像ファイルを格納,時系列にソート 39files = glob.glob("image_wave/*.png") 40files.sort() 41 42#画像を読み込み,green成分を抽出 43images = [cv2.imread(files[i]) for i in range(len(files))] 44images_green = [pd.DataFrame(images[j][:,:,1]) for j in range(len(images))] 45 46#parameter(顔のおでこの座標) 47in1 = 650 48in2 = 695 49co1 = 115 50co2 = 146 51 52#メディアンフィルタによる平滑化(iloc[行番号x,列番号y]) 53images_green_median = [cv2.medianBlur(images_green[i].iloc[ in1 : in2 , co1 :co2 ].values,ksize=5) for i in range(len(images_green))] 54 55#平均値を算出 56img_mean = [images_green_median[i].mean() for i in range(len(images_green_median))] 57 58plt.plot(img_mean) 59 60plt.show()
あなたの回答
tips
プレビュー