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

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

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

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

Python

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

解決済

水槽内のメダカの重心を求めるプログラムについて

sincere
sincere

総合スコア3

OpenCV

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

Python

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

2回答

0評価

1クリップ

839閲覧

投稿2021/12/07 07:45

編集2022/01/12 10:55

python初心者です
水槽内のメダカの軌跡を見るためにメダカの重心の値を求めるプログラムを作っています.(動画orリアルタイムで)
現状だと2値化して映ったものすべてに重心が出てしまうので対処法がわかりません(水槽内のごみなどにも)
メダカの重心のみを出すにはどうすればいいでしょうか.また光を当てている影響でメダカの体にも影ができてしまっているのでメダカの体をすべて映せるようにする方法も教えてくださるとうれしいです.

環境:Spyder(anaconda3),opencv4.5.4-dev

import cv2 import time import numpy as np movie = cv2.VideoCapture('sample3.mp4') before = None # 前回の画像を保存する変数 fps = int(movie.get(cv2.CAP_PROP_FPS)) #動画のFPSを取得 while True: /画像を取得 ret, frame = movie.read() /再生が終了したらループを抜ける if ret == False: break gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY) if before is None: before = gray.astype("float") continue /現在のフレームと移動平均との差を計算 cv2.accumulateWeighted(gray, before, 0.6) frameDelta = cv2.absdiff(gray, cv2.convertScaleAbs(before)) /frameDeltaの画像を2値化 thresh = cv2.threshold(frameDelta, 6, 255, cv2.THRESH_BINARY)[1] label = cv2.connectedComponentsWithStats(thresh) /オブジェクト情報を項目別に抽出 n = label[0] - 1 data = np.delete(label[2], 0, 0) center = np.delete(label[3], 0, 0) /ラベリング結果書き出し用に二値画像をカラー変換 color_src = cv2.cvtColor(gray, cv2.COLOR_GRAY2BGR) /オブジェクト情報を利用してラベリング結果を表示 for i in range(n): x1 = data[i][0] + data[i][2] y1 = data[i][1] + data[i][3] /各オブジェクトの重心座標をに黄文字で表示 cv2.putText(color_src, "X: " + str(int(center[i][0])), (x1-10 , y1+15),cv2.FONT_HERSHEY_PLAIN, 1, (0, 255, 255)) cv2.putText(color_src, "Y: " + str(int(center[i][1])), (x1-10 , y1+30),cv2.FONT_HERSHEY_PLAIN, 1, (0, 0, 255)) time.sleep(0.25/fps) cv2.imshow('movie',color_src) cv2.imshow('target_bh', thresh) /Enterキーが押されたらループを抜ける if cv2.waitKey(1) == 13: break cv2.destroyAllWindows() # ウィンドウを破棄

イメージ説明
2値化した状態
イメージ説明
重心を割り出している状態

良い質問の評価を上げる

以下のような質問は評価を上げましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

  • プログラミングに関係のない質問
  • やってほしいことだけを記載した丸投げの質問
  • 問題・課題が含まれていない質問
  • 意図的に内容が抹消された質問
  • 過去に投稿した質問と同じ内容の質問
  • 広告と受け取られるような投稿

評価を下げると、トップページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

1T2R3M4

2021/12/07 07:56

インデントをつけていただけませんか。
sincere

2021/12/07 08:07

ご指摘ありがとうございます
fana

2021/12/07 08:17

画像を示す場合,それぞれの画像が何なのか(何のために提示しているのか)という説明が要るのではないでしょうか. ※また,2つの画像は別のシーン(フレーム)のものであるように見えますが,そうであればあえて別にする意図も. (ある画像に関する各処理の過程を例示するのであれば,同一フレームでの絵を貼ると思うので)
sincere

2021/12/07 08:35

ご指摘ありがとうございます。 画像の方はこちらの都合により同フレームではないですが近いフレームに直しました。申し訳ありません。

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

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

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

同じタグがついた質問を見る

OpenCV

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

Python

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