画像処理における適応的二値化処理の原理や計算式についてまとめました。
適応的二値化処理
本ページの内容は以下動画で解説しています。
単純な二値化では、人が感覚的に閾値を決定する必要があります。その問題を改善するために登場したのが「適応2値化処理」です。
適応的二値化処理では、閾値を固定せず、注目画素と周囲にある画素の画素値の平均値を閾値とします。これにより、画素ごとに異なる閾値を設定できます。
以下のような全体的に緩やかに明るさが変化しているようなるような画像(不鮮明な写真や影が写り込んでいる写真など)に対して二値化処理するのに向いています。
■入力画像(左)と適応的二値化処理後の出力画像(右)


閾値の計算
入力画像の画素値を
とすると、その閾値
は以下の式で求まります。
(1) ![]()
計算例
次のような入力画像
が与えられた場合、
の閾値
を求めます。
(2) ![Rendered by QuickLaTeX.com \begin{eqnarray*} I= \left[ \begin{array}{ccccc} 100 & 200 & 150 \\ 110 & 120 & 120 \\ 190 & 230 & 200 \\ \end{array} \right] \end{eqnarray*}](https://algorithm.joho.info/wp-content/ql-cache/quicklatex.com-525e1420a244d3e407320b6055f9845f_l3.png)
※8近傍(注目画素+周囲8画素の画素値)の平均値で考えると
(3) ![]()
となります。
で、閾値
未満なので、二値化処理で画素値が
となります。
実装例
適応的二値化処理をプログラムで実装した例を下記事で解説しています。
https://algorithm.joho.info/programming/python/opencv-adaptive-thresholding-py/

【画像処理超入門】アルゴリズムの仕組みと実装方法を簡単に解説
画像処理超アルゴリズムの仕組みとプログラミングによる実装方法を簡単に解説します。

コメント