🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Python

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

Q&A

解決済

1回答

1637閲覧

Python Augmentorのprobabilityの意味について

SuzuAya

総合スコア71

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Python

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

0グッド

0クリップ

投稿2019/11/12 11:58

Augmentorライブラリを使って画像を拡張する際、引数に必ずprobabilityを入れる必要があると思いますが、この意味がよく理解できていません。

例えば、p.rotate(probability=0.7, max_left_rotation=10, max_right_rotation=10)としたら、70%の確率で、rotateが実行されるということだと思うのですが、そこで以下の質問です。
①元画像の7割をrotateさせる=元画像の3割はrotateさせていないということでしょうか?
②つまり,この水増しにより,画像枚数は1.7倍に増えるということでしょうか?

基本的なことで恐れ入りますが、ご回答いただけますと幸いです。

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

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

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

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

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

guest

回答1

0

ベストアンサー

元画像の7割をrotateさせる=元画像の3割はrotateさせていないということでしょうか?

70%の確率で回転処理を実行するという意味です。裏を返せば、30%の確率で回転処理は実行されません。
あくまで確率なので、100枚あったら70枚は回転しているというわけではありません。

この水増しにより,画像枚数は1.7倍に増えるということでしょうか?

枚数はパイプラインを作成したあと、もとのサンプルと同じ数だけ生成する場合は process()、指定した枚数だけ生成する場合は sample(n) を呼び出します。

投稿2019/11/12 14:29

編集2019/11/12 14:30
tiitoi

総合スコア21956

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

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

SuzuAya

2019/11/13 07:57

>tiitoi様 早速ご回答いただき、誠にありがとうございます。 operationが実行される確率であるとのこと承知いたしました。 ただ、水増しされる枚数はどのように決まるのかがうまくイメージできておりません…。 例えば100枚のオリジナル画像があって、以下のように回転と左右反転のoperationを実行させて1万枚に水増しさせようとした場合、どういう風に画像は増えるのでしょうか。 どの処理をした画像がどれだけ増えたか把握できるのか、それともできないのかご教示いただくことは可能でしょうか。 import Augmentor p = Augmentor.Pipeline("/path/to/images") p.rotate(probability=0.7, max_left_rotation=10, max_right_rotation=10) p.flip_left_right(probability=0.8) p.sample(10000)
tiitoi

2019/11/13 08:15 編集

p.sample(n) とした場合、作成したパイプラインに画像を入れて変換し、保存するというのを n 回繰り返すことになります。 例えば、元の画像が100枚で p.sample(200) とした場合、2倍に水増しされることになります。その際にどのような変換が行われるかは確率によってランダムに決まるため、わかりません。 疑似コードでかくなら、 for img in images: new_img = f(img) # 設定したパラメータで変換 new_img.save() # 保存
SuzuAya

2019/11/13 09:52

>tiitoi様 ご丁寧なご回答ありがとうございます。 最後に、1つだけ追加質問させてください。 上記のように、回転と左右反転のパイプラインを作成し実行した場合、1枚の画像に対して2つの変換(回転と左右反転)が同時に施される可能性もあるのでしょうか?
tiitoi

2019/11/13 10:17 編集

あります。 1. 回転する。 2. 左右反転する。 という1→2で1つのパイプラインです。 パイプラインを構成している各処理ごとに確率でその処理を実行するかどうか決めるので、回転と左右反転の両方が1枚の画像に対して実行される可能性もあります。
SuzuAya

2019/11/13 10:25

>tiitoi様 なるほど、だからパイプラインと呼ぶのですね! 大変よく分かりました。ご丁寧なご回答、本当にありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問