2016-09-28 115 views
5

校正チェス盤のしきい値を取得しようとしています。私はマイクロチェス盤を観察するときにいくらかの埃があるので、チェス盤コーナーを直接検出することはできません。 私はいくつかの方法を試しています.HoughLinesPは最も簡単な方法です。しかし、結果は良くない、私の結果を改善する方法?Python OpenCVを使ってHoughLinesで画像の縦線と横線を検出する方法は?

import numpy as np 
import cv2 

img = cv2.imread('lines.jpg') 
gray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY) 
edges = cv2.Canny(gray,50,150,apertureSize = 3) 
print img.shape[1] 
print img.shape 
minLineLength=100 
lines = cv2.HoughLinesP(image=edges,rho=0.02,theta=np.pi/500, threshold=10,lines=np.array([]), minLineLength=minLineLength,maxLineGap=100) 

a,b,c = lines.shape 
for i in range(a): 
    cv2.line(img, (lines[i][0][0], lines[i][0][1]), (lines[i][0][2], lines[i][0][3]), (0, 0, 255), 3, cv2.LINE_AA) 
    cv2.imwrite('houghlines5.jpg',img) 

あなたが以下の図に見ることができるように、私は私のチェス盤を得るカント、ラインは方向がたくさん...(原画:https://s22.postimg.org/iq2b91xq9/droite_Image_00000.jpg)にプロットされている

enter image description here

+0

使用しきい値、または小さなポイント(拡張、侵食さ)を低減してみてください。 – linusg

+0

私はすでに試みていますが、ハッピーラインと結合していません。多分それは線を得るのを助けるかもしれませんか?あなたの地獄のおかげで;) – user3601754

+0

私は本当に別の試してthresholdingだろう! – linusg

答えて

15

rhoの値が小さすぎます。

import numpy as np 
import cv2 

gray = cv2.imread('lines.jpg') 
edges = cv2.Canny(gray,50,150,apertureSize = 3) 
cv2.imwrite('edges-50-150.jpg',edges) 
minLineLength=100 
lines = cv2.HoughLinesP(image=edges,rho=1,theta=np.pi/180, threshold=100,lines=np.array([]), minLineLength=minLineLength,maxLineGap=80) 

a,b,c = lines.shape 
for i in range(a): 
    cv2.line(gray, (lines[i][0][0], lines[i][0][1]), (lines[i][0][2], lines[i][0][3]), (0, 0, 255), 3, cv2.LINE_AA) 
    cv2.imwrite('houghlines5.jpg',gray) 

注意、外れ値を減らすためにロー値、PI値とmaxLineGapの変化 - :

は、以下のコードを試してみてください。

入力画像 Input Image

エッジイメージ Edges Image

出力画像 Output Image

+0

赤い線なしで画像を保存する方法は?私はすべての行が全くないイメージを持っていたいと思います。お返事ありがとうございます – Link

+1

@Link - 私はあなたがラインなしのイメージで何を意味するか分かりません。元のイメージを出力するだけでよい場合は、ハフラインを描画する前に 'cv2.imwrite( 'imagename.jpg'、gray)'を使って、 'cv2.line'コマンドを実行して、ループの外で' imwrite'を実行してください。 – saurabheights

0

Iむしろこれをコメントとして書きますが、残念ながら私はできません。 minLineLengthとminLineGapを変更する必要があります。または、あなたが見つけなければならないものがあれば、私はすべての線を得て、それらの間の角度をチェックして、四角に沿った線だけを得るでしょうか?私は以前にHoughLinePで作業していましたが、これは上記の2つの引数にかなり基づいています。さらに、バイラテラルフィルタリングを使用してみてください。メジアンフィルターを使用したシャープニングが役に立たないときは、私は本当に役に立ちます。彼らはあなたがエッジ検出のために行く前に、フィルターなどを通過する必要がありますいくつかの役割をしている画像を処理中

Bilateral Filter

-1

、あなたの条件にほこりがあなたがフィルタによって削除する必要がちょうどノイズ、gausseを使用しています私は間違っていない場合はthreshholdingを使用して、その後、キーポイントのために行くことができます..これらの手順を実行し、結果を参照してください

関連する問題