はじめに
skimage.filtersのthreshold_otsuによるしきい値処理について説明する。
コード
![](https://sabopy.com/wp/wp-content/uploads/2019/09/Eseeds_otsu-800x300.jpg)
解説
モジュールのインポート
画像データの読み込み
Epithelantha属の月世界の種子を用いる。rgb2grayによりグレースケール画像とする。
![](https://sabopy.com/wp/wp-content/uploads/2019/09/Epithelantha_seed-800x800.jpg)
大津の2値化によるしきい値処理
threshold_otsu(image)でimageに大津の2値化を適用したときのしきい値を得ることができる。
そのしきい値でimage > threshのようにすればTrueとFalseのバイナリ画像が得られる。不等号を>から<にすれば、TrueとFalseが入れ替わるので、画像は白黒が反転する。
大津の2値化については下記が詳しい。
![](https://qiita-user-contents.imgix.net/https%3A%2F%2Fcdn.qiita.com%2Fassets%2Fpublic%2Farticle-ogp-background-412672c5f0600ab9a64263b751f1bc81.png?ixlib=rb-4.0.0&w=1200&mark64=aHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTk3MiZoPTM3OCZ0eHQ9JUU1JUE0JUE3JUU2JUI0JUE1JUUzJTgxJUFFJUU0JUJBJThDJUU1JTgwJUE0JUU1JThDJTk2JUUzJTgxJUEzJUUzJTgxJUE2JUUzJTgxJUFBJUUzJTgyJTkzJUUzJTgxJUEwJUUyJTgwJUE2JUUzJTgxJUEzJUUzJTgxJUE2JUUzJTgxJUFBJUUzJTgxJUEzJUUzJTgxJTlGLiZ0eHQtYWxpZ249bGVmdCUyQ3RvcCZ0eHQtY29sb3I9JTIzMUUyMTIxJnR4dC1mb250PUhpcmFnaW5vJTIwU2FucyUyMFc2JnR4dC1zaXplPTU2JnM9OWI5YTFiMTljZjg4MjJhZmI0Y2VmYzM2YzU2ZWVmNDE&mark-x=142&mark-y=57&blend64=aHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZoPTc2Jnc9NzcwJnR4dD0lNDBoYXJ1MTg0MyZ0eHQtY29sb3I9JTIzMUUyMTIxJnR4dC1mb250PUhpcmFnaW5vJTIwU2FucyUyMFc2JnR4dC1zaXplPTM2JnR4dC1hbGlnbj1sZWZ0JTJDdG9wJnM9M2U3ZmU0NmNkNjM0M2M2OTZjYjI5OGM0MGI3MmY2YTE&blend-x=142&blend-y=486&blend-mode=normal&s=b4a4ff3e8f102f16aa1df81a36bc22e0)
大津の二値化ってなんだ…ってなった. - Qiita
はじめにOpenCVを利用して二値化を行う際, 「とりあえずcv2.THRESH_OTSUやっとけばええやろ, ぽいー」って感じでテキトーに二値化してました.「とりあえずいい感じに動く」って認識…
ヒストグラムと画像の表示
左にオリジナル画像、中央にヒストグラム、右にしきい値処理した画像を示す。
ヒストグラムについては下記で説明した。
![](https://sabopy.com/wp/wp-content/uploads/2019/02/hist-160x90.png)
[matplotlib] 6.ヒストグラム
matplotlibでヒストグラムを作成することのできるplt.hist()について説明する。
異なるしきい値処理を一度に試す
try_all_thresholdで下記の方法でしきい値処理した結果を表示することができる。
skimage.filters.thresholding.threshold_isodata skimage.filters.thresholding.threshold_li skimage.filters.thresholding.threshold_mean skimage.filters.thresholding.threshold_minimum skimage.filters.thresholding.threshold_otsu skimage.filters.thresholding.threshold_triangle skimage.filters.thresholding.threshold_yen
![](https://sabopy.com/wp/wp-content/uploads/2019/09/Eseeds_threth_tryall.jpg)
参考
Thresholding — skimage 0.24.0 documentation
skimage.filters — skimage 0.24.0 documentation
skimage.filters — skimage 0.24.0 documentation
コメント