質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
OpenCV

OpenCV(オープンソースコンピュータービジョン)は、1999年にインテルが開発・公開したオープンソースのコンピュータビジョン向けのクロスプラットフォームライブラリです。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

0回答

1206閲覧

python顔取得プログラムにおけるエラー

kazuma_1990

総合スコア0

OpenCV

OpenCV(オープンソースコンピュータービジョン)は、1999年にインテルが開発・公開したオープンソースのコンピュータビジョン向けのクロスプラットフォームライブラリです。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2020/11/19 10:53

前提・実現したいこと

顔の動画をフレーム分割し、その分割した画像から指定範囲の緑色の成分(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()

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

YT0014

2020/11/20 03:18

detectMultiScale()を利用したサンプルは検索されましたか? detectMultiScale()の仕様は確認されましたか?
kazuma_1990

2020/11/20 04:25

はい。確認できてます。他のプログラムにて使用経験があり確認できてます。
YT0014

2020/11/20 05:59 編集

こちらで確認した限りでは、detectMultiScale()へ渡す画像は、グレイスケールに変換しております。 また、http://opencv.jp/opencv-2.1/cpp/object_detection.html によれば、CV_8Uで渡すことが必要なようです。 実行時に読み取られる画像は、グレイスケール、かつ、CV_8Uでしょうか? または、カラー画像でのdetectMultiScale()のサンプルを確認されているのでしょうか? エラーメッセージを見れば、画像ファイルの形式が誤っていると思えるのですが。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問