pythonを用いてhough変換で直線検出を行おうとしています。
このとき、画像上のすべての直線を検出したいのではなく、最も強く現れる(最大投票数の)直線のみを検出したいと考えています。
以下のコードだと、すべての直線が検出されてしまいます。
どのようにすれば最大投票数の直線のみの検出が可能でしょうか?
該当のソースコード
python
1import cv2 2import numpy as np 3 4img = cv2.imread('.jpg') 5gray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY) 6edges = cv2.Canny(gray, 220, 250, apertureSize = 3) 7lines = cv2.HoughLines(edges, rho=1, theta=np.pi/180, threshold=200) 8 9print lines 10if lines is not None: 11 for line in lines: 12 rho, theta = line[0] 13 a = np.cos(theta) 14 b = np.sin(theta) 15 x0 = a*rho 16 y0 = b*rho 17 x1 = int(x0 + 1000*(-b)) 18 y1 = int(y0 + 1000*(a)) 19 x2 = int(x0 - 1000*(-b)) 20 y2 = int(y0 - 1000*(a)) 21 22 cv2.line(img,(x1,y1),(x2,y2),255,2) 23 cv2.imshow('frame', img)
試したこと
ここに問題に対して試したことを記載してください。
補足情報(FW/ツールのバージョンなど)
ここにより詳細な情報を記載してください。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。