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

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

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

NumPyはPythonのプログラミング言語の科学的と数学的なコンピューティングに関する拡張モジュールです。

Python

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

Q&A

解決済

1回答

519閲覧

画像の勾配 ||∇I(x, y)||

daodao

総合スコア13

NumPy

NumPyはPythonのプログラミング言語の科学的と数学的なコンピューティングに関する拡張モジュールです。

Python

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

0グッド

2クリップ

投稿2018/07/21 02:25

カラー画像の勾配(gradient)を求め、最終的にはしきい値からバイナリマスクを作成すると
論文に書いてあるのですが、以下の数式をNumpyでどう処理するのか分かりません。

Gk(x, y) = ||∇Ik(x, y)||

Gは、勾配
Iは、インプット画像
kは、チャンネル数(R,G,B)
x,yは、座標

この場合、各チャンネルの座標単位の勾配を求めていく、と理解しています。
どなたか実装例をご教授いただけないでしょうか。
よろしくお願い致します。

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

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

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

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

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

tachikoma

2018/07/21 02:54 編集

勾配を求める数式は分かりますか?
daodao

2018/07/21 04:29

出典は下記になります。
daodao

2018/07/21 04:32

上記PDFの「3.1. Vague shadow estimation」が今回の質問箇所となります。質問の意図とは異なるかもしれませんが、勾配の数式はhttps://ja.wikipedia.org/wiki/%E3%83%8A%E3%83%96%E3%83%A9#%E5%8B%BE%E9%85%8Dとなるのでしょうか。
daodao

2018/07/21 04:35

出典では対数画像に対して勾配をとると記載があるのですが、今回の質問からは除外しています。
guest

回答1

0

ベストアンサー

opencvのSobel関数を使った方法を示します。dx, dyを求める際にy方向, x方向へのスムージングがそれぞれかかるようなのですが、そこは必要に応じて調整してくださ。

python

1import matplotlib.pyplot as plt 2import cv2 3import numpy as np 4 5# サンプル画像の読み込み 6import scipy.misc 7img = scipy.misc.face() 8 9# グレー画像に変換 10gray = cv2.cvtColor(img, cv2.COLOR_RGB2GRAY) 11 12# 適当な大きさにリサイズ 13sz = np.array(img.shape[1::-1]) 14img = cv2.resize(img, tuple(sz//4)) 15 16# dx, dyを求める。処理内容はopencvのドキュメントを参照してください。 17dx = cv2.Sobel(gray, cv2.CV_64F, 1, 0, ksize=3) 18dy = cv2.Sobel(gray, cv2.CV_64F, 0, 1, ksize=3) 19 20# 比較のために画像を表示 21fig, ax = plt.subplots(2, 2, figsize=(12, 8)) 22 23# 元画像 24ax[0, 0].imshow(img) 25ax[0, 1].imshow(gray, cmap="gray") 26 27# dx 28m = np.max(np.abs(dx.ravel())) 29ax[1, 0].imshow(dx, cmap="gray", vmax=m, vmin=-m) 30 31# dy 32m = np.max(np.abs(dy.ravel())) 33ax[1, 1].imshow(dy, cmap="gray", vmax=m, vmin=-m) 34 35plt.show() 36 37# 求めたい勾配map 38plt.figure() 39grad_magnitude = np.sqrt(dx**2 + dy**2) 40plt.imshow(grad_magnitude, cmap="gray") 41plt.show()

投稿2018/07/22 02:38

tachikoma

総合スコア3601

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

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

daodao

2018/07/22 14:52

丁寧な解説ありがとうございました! 勾配の理解が不足しいたので、分かりづらい質問となってしまいましたが助かりました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問