Opencv houghLines не обнаруживает линии - PullRequest
0 голосов
/ 14 января 2019

Я пытаюсь отфильтровать изображение, используя линии Hough, но что-то просто не работает.

Я создал следующую подпрограмму, которая была скопирована без изменений из документации:

def FilterLines(img):
    lines = cv2.HoughLines(img,1,np.pi/180,200)
    blank_image = np.zeros((img.shape[0], img.shape[1]), np.uint8)
    if (lines is None):
        return blank_image
    for rho,theta in lines[0]:
        a = np.cos(theta)
        b = np.sin(theta)
        x0 = a*rho
        y0 = b*rho
        x1 = int(x0 + 1000*(-b))
        y1 = int(y0 + 1000*(a))
        x2 = int(x0 - 1000*(-b))
        y2 = int(y0 - 1000*(a))

        cv2.line(blank_image,(x1,y1),(x2,y2),255,1)

    return blank_image

Затем я даю ему следующее тестовое изображение: enter image description here

Но функция enter image description here выводит:

Так что он вроде обнаружил пару строк внизу и ничего больше.

Почему функция не может обнаружить линии на таком простом изображении?

Ответы [ 2 ]

0 голосов
/ 30 июня 2019

Используйте этот код. В версиях openCV существует конфликт, который не позволяет нам выполнять вышеуказанную операцию таким образом.


import cv2
import numpy as np

img = cv2.imread('image.jpg')
gray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)
edges = cv2.Canny(gray,50,150,apertureSize = 3)

lines = cv2.HoughLines(edges,1,np.pi/180,200)
for line in lines:
    rho = line[0][0]
    theta = line[0][1]
    a = np.cos(theta)
    b = np.sin(theta)
    x0 = a*rho
    y0 = b*rho
    x1 = int(x0 + 1000*(-b))
    y1 = int(y0 + 1000*(a))
    x2 = int(x0 - 1000*(-b))
    y2 = int(y0 - 1000*(a))

    cv2.line(img,(x1,y1),(x2,y2),(0,0,255),2)

cv2.imwrite('houghlines3.jpg',img)

0 голосов
/ 15 января 2019

Проблема в этой строке for rho,theta in lines[0]:. Вы используете только одну строку, первую line[0].

Вам нужно изменить цикл for следующим образом:

    for x in range(0, len(lines)):    
        for rho, theta in lines[x]:

В этом случае весь код выглядит следующим образом (с дополнительными отладочными инструкциями, после того как я вставил их для тестирования):

import cv2
import os
import numpy as np

#path = os.path("D:\")
img = cv2.imread("D:\\oV1PG.png")

#cv2.imshow('image',img)
#cv2.waitKey(0)

img = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
#print(img)

'''height, width, channel = img.shape[:3]
size = img.size

print(height, width, channel, size)'''


if img is not None:
    lines = cv2.HoughLines(img, 1, np.pi / 180, 100)


    blank_image = np.zeros((img.shape[0], img.shape[1]), np.uint8)

    for x in range(0, len(lines)):    
        for rho, theta in lines[x]:
            a = np.cos(theta)
            b = np.sin(theta)
            x0 = a * rho
            y0 = b * rho
            x1 = int(x0 + 1000 * (-b))
            y1 = int(y0 + 1000 * (a))
            x2 = int(x0 - 1000 * (-b))
            y2 = int(y0 - 1000 * (a))

            cv2.line(blank_image, (x1, y1), (x2, y2), 255, 1)
            print(x1, y1, x2, y2)

        print("\n")

    cv2.imshow("out", blank_image)
    cv2.waitKey(0)
else:
    print("empty img. Cannot read file")

Вот так выглядит вывод на моем ПК:

enter image description here

...