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

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

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

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

Python

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

Q&A

解決済

2回答

1610閲覧

Python OpenCV 領域抽出

退会済みユーザー

退会済みユーザー

総合スコア0

OpenCV

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

Python

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

0グッド

0クリップ

投稿2020/08/24 04:25

OpenCVを用いて領域抽出しているのですが、
顔検出で検出された顔のサイズの幅を何倍、高さを何倍にして、
上半身や下半身を領域抽出することは可能なのでしょうか。

調べてもなんて調べていいか分からず困っています。

分かる方助けてください。

画像はこのようにして検出できています

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

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

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

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

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

guest

回答2

0

ベストアンサー

顔検出で検出された顔のサイズの幅を何倍、高さを何倍にして、

上半身や下半身を領域抽出することは可能なのでしょうか。

人によって身長は様々なので、顔の大きさから上半身や下半身を検出するのは無理があるのではないでしょうか。


OpenCV の上半身のカスケード検出器の精度で満足できないのであれば、体のパーツごとにセグメンテーションできるモデルを使うか、もしくは姿勢推定モデルで出てきたキーポイントを使うなど考えられますね。

kevinlin311tw/CDCL-human-part-segmentation: Repository for Paper: Cross-Domain Complementary Learning Using Pose for Multi-Person Part Segmentation (TCSVT20)

microsoft/human-pose-estimation.pytorch: The project is an official implement of our ECCV2018 paper "Simple Baselines for Human Pose Estimation and Tracking

いずれにしてもここでサンプルコードを出せるタスク量ではないので、参考情報として記載しておきます。

追記

先ほどの回答のimg[y:y + faceH * 3, x:x + faceW * 6] というのはどのようなコードを書けば検出されるのでしょうか。

例えば、以下のような感じです。

python

1import cv2 2import os 3 4# 正面の顔を検出するカスケード分類器を作成する。 5cascade_path = os.path.join( 6 cv2.data.haarcascades, "haarcascade_frontalface_default.xml" 7) 8face_cascade = cv2.CascadeClassifier(cascade_path) 9 10# 画像を読み込む。 11img = cv2.imread("sample.jpg") 12 13# グレースケールに変換する。 14gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) 15 16# 検出する。 17faces = face_cascade.detectMultiScale(gray) 18 19# 矩形を画像に描画する。 20for x, y, w, h in faces: 21 cv2.rectangle(img, (x, y), (x + w, y + h), color=(0, 255, 0), thickness=2) 22 23 tl = x - w, y + h # 上半身の左上の座標 24 br = x + 2 * w, y + h * 5 # 上半身の右下の座標 25 cv2.rectangle(img, tl, br, color=(0, 0, 255), thickness=2)

イメージ説明

イメージ説明

投稿2020/08/24 04:32

編集2020/08/24 05:40
tiitoi

総合スコア21956

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

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

退会済みユーザー

退会済みユーザー

2020/08/24 04:40

人それぞれだということを除外して顔のサイズの何倍の領域を抽出するということは可能なのでしょうか。
tiitoi

2020/08/24 04:45

顔のサイズの n 倍の領域を切り出すということは、例えば、左上の座標を (x, y) として、顔の大きさを (faceW, faceH) としたとき、img[y:y + faceH * 3, x:x + faceW * 6] とかすれば切り出すことはできるでしょうね それが上半身と一致するかは別問題ですが、、
退会済みユーザー

退会済みユーザー

2020/08/24 04:53

左上の座標というのはどのようなことですか。初歩的なことでしたらすいません。
tiitoi

2020/08/24 04:58

画像を矩形で切り出すということは、矩形の左上の座標が必要になりますよね 左上の座標というのはそのことです。例えば、上半身が顔のすぐ真下にあり、顔1個分左にずらした座標が上半身の左端だと仮定するなら、(x, y) = (FaceX - FaceW, FaceY + FaceH) となるかと思います。
退会済みユーザー

退会済みユーザー

2020/08/24 05:07

そういうことですね。わかりました。いろいろ調べてやってみます。
退会済みユーザー

退会済みユーザー

2020/08/24 05:33

先ほどの回答のimg[y:y + faceH * 3, x:x + faceW * 6] というのはどのようなコードを書けば検出されるのでしょうか。
tiitoi

2020/08/24 05:40

追記しました。あくまで例です。
退会済みユーザー

退会済みユーザー

2020/08/24 05:56

ありがとうございます。 やってみたらこのようなエラーが起きてしまうのですがどのようなエラーなのでしょうか。 argument for rectangle() given by name ('color') and position (3)
退会済みユーザー

退会済みユーザー

2020/08/24 06:00

その後やったらできました。小数点だとできないんですね。
tiitoi

2020/08/24 06:52

小数点は受け付けてないので、int() にキャストする必要がありますね
guest

0

上半身や下半身を領域抽出する

「抽出する」の具体的な意味によります.
とりあえず足がかりとしての「(Coarseな)推定」の1つとは言えるかもしれません.

投稿2020/08/24 04:46

fana

総合スコア11996

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問