Python+OpenCVでPrewittフィルタを「NumPy」「cv2.filter2D」で実装し、輪郭検出する方法をソースコード付きで解説します。
【Python】Prewittフィルタで輪郭検出
プレヴィットフィルタ(Prewitt Filter)は、輪郭を検出できる空間フィルタです。
プレヴィットフィルタの原理と計算式については下記事で紹介しています。
【画像処理】プレヴィットフィルタの原理・特徴・計算式
画像処理におけるPrewitt(プレヴィット)フィルタの原理や特徴、計算式についてまとめました。
このアルゴリズムは、NumPyだけでも簡単に実装できます。
また、OpenCVの「cv2.filter2D」メソッドを使えば、より簡単に実装できます。
書式
dst = cv2.filter2D(src, -1, kernel)
パラメータ名 | 説明 |
---|---|
src | 入力画像 |
kernel | フィルタのカーネル(※NumPy配列で与える) |
dst | 出力画像 |
今回は、処理を以下の2通りの方法で実装してみました。
方法①・・・NumPyでアルゴリズムを書いて実装(原理の理解を深めるため)
方法②・・・cv2.filter2Dで実装
ソースコード(Python3+OpenCV3)
サンプルプログラムのソースコードです。
方法①
方法②
実行結果
サンプルプログラムの実行結果です。
■入力画像(左)と出力画像(右)
関連ページ
先程のの出力画像は正の勾配(黒→白)のみ白色になっています。
負の勾配(白→黒)も白色に塗って出力する方法は下記ページで紹介しています。
【Python/OpenCV】微分フィルタの注意点(負の値の処理)
Python版OpenCVの微分フィルタ(Sobelなど)を利用する時の注意点についてソースコード付きで解説します。
また、Python版OpenCV全般については以下ページで解説しています。
【Python版OpenCV超入門】使い方とサンプルコードを解説
Python版OpenCVで画像処理プログラミングを行う方法を入門者向けにソースコード付きで解説するページです。
コメント