気になる質問をクリップする
クリップした質問は、後からいつでもMYページで確認できます。
またクリップした質問に回答があった際、通知やメールを受け取ることができます。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
回答1件
0
ベストアンサー
ハフ変換の返り値として、直線を表すパラメータ (rho, theta) のリストが得られるので、
python
1lines = list(filter(lambda x: abs(x[1] - np.pi / 2) <= np.deg2rad(5), lines))
として、theta が 90° 付近のものだけ抽出すればよいと思います。
角度はラジアンなので注意してください。
python
1import cv2 2import numpy as np 3 4img = cv2.imread("sample.jpeg") 5 6gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) 7 8edges = cv2.Canny(gray, 150, 300, L2gradient=True) 9 10# ハフ変換で直線検出する。 11lines = cv2.HoughLines(edges, 1, np.pi / 180, 200) 12lines = lines.squeeze(axis=1) 13 14# 直線の角度がほぼ90°(-85° ~ 95°) のものだけ抽出する。 15lines = list(filter(lambda x: abs(x[1] - np.pi / 2) <= np.deg2rad(5), lines)) 16 17 18# 直線を描画する。 19def draw_line(img, theta, rho): 20 h, w = img.shape[:2] 21 if np.isclose(np.sin(theta), 0): 22 x1, y1 = rho, 0 23 x2, y2 = rho, h 24 else: 25 calc_y = lambda x: rho / np.sin(theta) - x * np.cos(theta) / np.sin(theta) 26 x1, y1 = 0, int(calc_y(0)) 27 x2, y2 = w, int(calc_y(w)) 28 29 cv2.line(img, (x1, y1), (x2, y2), (0, 0, 255), 2) 30 31 32for rho, theta in lines: 33 draw_line(img, theta, rho) 34 35 print(theta) 36imshow(img)
投稿2020/04/05 13:16
編集2020/04/05 13:16総合スコア21956
あなたの回答
tips
太字
斜体
打ち消し線
見出し
引用テキストの挿入
コードの挿入
リンクの挿入
リストの挿入
番号リストの挿入
表の挿入
水平線の挿入
プレビュー
質問の解決につながる回答をしましょう。 サンプルコードなど、より具体的な説明があると質問者の理解の助けになります。 また、読む側のことを考えた、分かりやすい文章を心がけましょう。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2020/04/05 21:16
2020/04/06 01:12
2020/04/06 01:13