【问题标题】:Simple images will detect but complex images wont get detected by HoughLine modified code简单的图像会被检测到,但复杂的图像不会被 HoughLine 修改的代码检测到
【发布时间】:2016-06-15 06:00:01
【问题描述】:

我正在做一个需要检测屋顶的项目。目前,我正在检测斜线。经过一番尝试,我想出了一个检测屋顶的解决方案。但是,当我用各种类型的屋顶平面(复杂的一种)对其进行测试时,进行检测并不准确。

这是我使用的代码,

import cv2
import numpy as np
import matplotlib.pyplot as plt

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

lines = cv2.HoughLines(edges,1,np.pi/180,100)
count =0
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))

    plt.scatter(x1, y1)
    plt.scatter(x2, y2)

    if( 20 < 180*theta/np.pi < 88):
        cv2.line(img, (x1, y1), (x2, y2), (0, 0, 255),3)
        plt.scatter(x1, y1)
        plt.scatter(x2, y2)
    if (160 > 180 * theta / np.pi > 93):
        cv2.line(img, (x1, y1), (x2, y2), (0, 0, 255),3)
        plt.scatter(x1, y1)
        plt.scatter(x2, y2)

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

这是我使用的简单屋顶平面图以及为此获得的结果,

但是当我使用复杂的(真实的)计划时,我会得到什么输出,

我尝试了另一个代码,这给了我一个令人愉快的输出。下面我附上了代码和输出。

import cv2.cv as cv
import numpy as np
import math

im=cv.LoadImage('h1.jpg', cv.CV_LOAD_IMAGE_GRAYSCALE)

pi = math.pi #Pi value

dst = cv.CreateImage(cv.GetSize(im), 8, 1)

cv.Canny(im, dst, 200, 200)
cv.Threshold(dst, dst, 100, 255, cv.CV_THRESH_BINARY)

#---- Probabilistic ----
color_dst_proba = cv.CreateImage(cv.GetSize(im), 8, 3)
cv.CvtColor(im, color_dst_proba, cv.CV_GRAY2BGR) # idem


rho=1
theta=pi/180
thresh = 100
minLength= 120 # Values can be changed approximately to fit your image edges
maxGap= 50

lines = cv.HoughLines2(dst, cv.CreateMemStorage(0), cv.CV_HOUGH_PROBABILISTIC, rho, theta, thresh, minLength, maxGap)
for line in lines:
    cv.Line(color_dst_proba, line[0], line[1], cv.CV_RGB(255, 0, 0), 3, 8)

cv.ShowImage("Hough Probabilistic", color_dst_proba)
cv.WaitKey(0)
cv.SaveImage("output.jpg",color_dst_proba)

结果,

这也有水平线和垂直线。我只需要有角度的线就可以了。 谁能帮我解决这个问题?提前谢谢!

【问题讨论】:

  • 尝试调整 theta 值。
  • 如果你想使用第一个版本,你应该显示图像edges并调整canny的参数,直到你得到一个合适的边缘图像。
  • 我建议先将图像转换为边缘图。你应该使用 sobel,而不是使用 Canny。更好的阈值算法也会创造奇迹。除了使用 Hough 之外,您应该使用 LineSegmentDetector(LSD) 这是一种更好且优化的算法。获得这些行后,您可以对其进行迭代并删除不需要的行。

标签: python opencv image-processing hough-transform


【解决方案1】:

在您的第一个版本中,您有这部分代码:

for rho,theta in lines[0]:
    if( 20 < 180*theta/np.pi < 88):
        cv2.line(img, (x1, y1), (x2, y2), (0, 0, 255),3)
         plt.scatter(x1, y1)
         plt.scatter(x2, y2)
     if (160 > 180 * theta / np.pi > 93):
         cv2.line(img, (x1, y1), (x2, y2), (0, 0, 255),3)
         plt.scatter(x1, y1)
         plt.scatter(x2, y2)

在您刚刚拥有的第二个版本中

for line in lines:
    cv.Line(color_dst_proba, line[0], line[1], cv.CV_RGB(255, 0, 0), 3,8)

尝试以与第一个代码示例相同的方式绘制线条。由于您使用的是概率 HoughLine 函数,因此您需要自己计算角度。

How to calculate the angle between a line and the horizontal axis? 中给出了如何做到这一点的答案

我在 python 方面不是那么有经验,但应该是这样的:

for line in lines:
    dy = line[1].y - line[0].y
    dx = line[1].x - line[0].x
    angle = atan2(dy,dx) * 180/np.pi
    if(20 < angle < 88)
        cv.Line(color_dst_proba, line[0], line[1], cv.CV_RGB(255, 0, 0),3,8)
    if(160 > angle > 93)
        cv.Line(color_dst_proba, line[0], line[1], cv.CV_RGB(255, 0, 0),3,8)

如果这不起作用,请尝试https://stackoverflow.com/a/32963819/2393191 计算角度。

【讨论】:

  • 这是我需要指导解决的问题。因为第二种方法,我使用的是 cv,第一种是 cv2。
  • 啊好的。我看到你使用概率变体。在那里你可以/必须先自己计算角度。您可以在stackoverflow.com/questions/7586063/… 中了解如何计算直线的角度
  • 您编辑的代码是我发布的第二个代码对吗?
  • 是的,在第二个代码中你必须自己计算线的角度,因为你只给出了起点和终点
  • 但是先生,当我使用该代码段时,它无法获取 y 和 x 值。 dy = line[1].y - line[0].y AttributeError: 'tuple' object has no attribute 'y'
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2016-01-20
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2012-03-03
  • 1970-01-01
相关资源
最近更新 更多