Hough Transform直线检测

本文原创,如转载请注明出处。

Hough Transform 是一种能提取图像中某种特定形状特征的方法,可以将其描述成一种把图像空间中的像素转换成Hough空间中直线或曲线的一种映射函数。通过利用Hough空间的一些性质,我们可以找到并识别一些有共同特性的点(如在同一条直线上)。这样我们就得到足够的信息去画出这些图形(如直线)。其输入图像通常为二值边缘图像。

1.原理:

图像空间是所有像素所属于的图像的空间。Hough空间是一种变量混合空间,实际上它与图像相关但是却不存在物理实质性。

我们可以把图像空间的坐标通过下式表达成Hough空间:

X = Ρ·cosΘ

Y = Ρ·sinΘ

where

P = sqrt(x2+y2) ,  是坐标原点到直线的距离

 ,是距离与x坐标轴的夹角

通常我们写成如下形式:

通过下图我们可以更加容易理解上述式子:

经过Hough变换我们将图像空间中的一个点映射到Hough空间,如下图我们得到了一条正弦曲线。

在这里正弦曲线的形状取决于,点到我们所定义原点的距离。通常,距离越大,正弦曲线的振幅越大,反之则会变小。为了使曲线显示我们把纵坐标设置成如上,当然我也可以用π表示。

以同样的方法我们可以再次映射一个点,而我们知道在图像空间中两个点总在一条直线上。而在Hough空间中我们可以看到两条正弦曲线可能会相交如下图:

在这里我们可以把每一个交点看成是一次投票,也就是

计算完所有边缘点后,我们可以设置一个阈值,投票大于这个阈值的点这是我们要找的直线。如下分别为原图,阈值为30,20时候检测到的直线。

   

对于大于阈值的点我们有其Hough space的参数对(p,Θ), 通过逆映射我们可以得到图像空间中的直线:

 2.opencv示例:

步骤如下:

1.载入图像

2.应用canny或其他边缘检测算子得到边缘的二值图像

3.应用Hough transform(Houghline())

4.在原图像上画出直线

void HoughLines(InputArray image, OutputArray lines, double rho, double theta, int threshold, double srn=0, double stn=0 )

 1 #include "opencv2/highgui/highgui.hpp"
 2 #include "opencv2/imgproc/imgproc.hpp"
 3 #include <iostream>
 4
 5 using namespace cv;
 6 using namespace std;
 7
 8 int main()
 9 {
10     Mat src = imread("building.jpg", 0);
11
12     Mat dst, cdst;
13     Canny(src, dst, 50, 200, 3);
14     cvtColor(dst, cdst, CV_GRAY2BGR);
15
16     vector<Vec2f> lines;
17     // detect lines
18     HoughLines(dst, lines, 1, CV_PI/180, 150, 0, 0 );
19
20     // draw lines
21     for( size_t i = 0; i < lines.size(); i++ )
22     {
23         float rho = lines[i][0], theta = lines[i][1];
24         Point pt1, pt2;
25         double a = cos(theta), b = sin(theta);
26         double x0 = a*rho, y0 = b*rho;
27         pt1.x = cvRound(x0 + 1000*(-b));
28         pt1.y = cvRound(y0 + 1000*(a));
29         pt2.x = cvRound(x0 - 1000*(-b));
30         pt2.y = cvRound(y0 - 1000*(a));
31         line( cdst, pt1, pt2, Scalar(0,0,255), 3, CV_AA);
32     }
33
34     imshow("source", src);
35     imshow("detected lines", cdst);
36
37     waitKey();
38     return 0;
39 }

结果:

 

时间: 2024-07-30 04:33:40

Hough Transform直线检测的相关文章

OpenCV2马拉松第22圈——Hough变换直线检测原理与实现

计算机视觉讨论群162501053 转载请注明:http://blog.csdn.net/abcd1992719g/article/details/27220445 收入囊中 Hough变换 概率Hough变换 自己实现Hough变换直线检测 葵花宝典 先看一下我实现的效果图 下面,我们进入Hough变换的原理讲解. 看上图,我们知道,经过一点(x0,y0)的直线可以表示成y0 = mox + b0 反过来看方程,b = –x0m + y0 ,于是我们从原来的坐标系转移到了Hough空间,m是横

Hough变换直线检测

Hough变换直线检测 [email protected] http://blog.csdn.net/kezunhai 霍夫变换是图像变换中的经典算法之一,主要用来从图像中分离出具有某种相同特征的几何形状(如,直线,圆等).霍夫变换寻找直线与圆的方法相比与其它方法可以更好的减少噪声干扰.Hough变换的基本原理在于利用点与线的对偶性,将原始图像空间的曲线通过转换到参数空间的一个点. 从图中可以看到,x-y坐标和K-b坐标有点--线的对偶性.x-y坐标中的P1.P2对应于k-b坐标中的L1.L2:

灰度图像--图像分割 霍夫变换(Hough Transform)--直线

学习DIP第50天 转载请标明本文出处:http://blog.csdn.net/tonyshengtan ,出于尊重文章作者的劳动,转载请标明出处!文章代码已托管,欢迎共同开发:https://github.com/Tony-Tan/DIPpro 开篇废话 废话开始,要过年了,到处人心惶惶,沉下心写篇博客,下一篇就等农历新年以后了.马上新年了,希望自己在新年能提高技术,找到一份图像处理的好工作,也希望大家都能学习到更多的知识,做自己喜欢做的事情. 以前基本每天都写博客,坚持了三个月感觉确实有提

Hough transform(霍夫变换)

主要内容: 1.Hough变换的算法思想 2.直线检测 3.圆.椭圆检测 4.程序实现 一.Hough变换简介 Hough变换是图像处理中从图像中识别几何形状的基本方法之一.Hough变换的基本原理在于利用点与线的对偶性,将原始图像空间的给定的曲线通过曲线表达形式变为参数空间的一个点.这样就把原始图像中给定曲线的检测问题转化为寻找参数空间中的峰值问题.也即把检测整体特性转化为检测局部特性.比如直线.椭圆.圆.弧线等. 霍夫变换于1962年由Paul Hough 首次提出[53],后于1972年由

Python+OpenCV图像处理(十四)—— 直线检测

简介: 1.霍夫变换(Hough Transform) 霍夫变换是图像处理中从图像中识别几何形状的基本方法之一,应用很广泛,也有很多改进算法.主要用来从图像中分离出具有某种相同特征的几何形状(如,直线,圆等).最基本的霍夫变换是从黑白图像中检测直线(线段). 2.Hough变换的原理是将特定图形上的点变换到一组参数空间上,根据参数空间点的累计结果找到一个极大值对应的解,那么这个解就对应着要寻找的几何形状的参数(比如说直线,那么就会得到直线的斜率k与常熟b,圆就会得到圆心与半径等等) 3.霍夫线变

边缘提取与直线检测

计算机中的边缘算法主要是依靠梯度差来计算,常见的有sobel算子,lapacian算子等,在实现方法上都大同小异,OpenCV中对这类函数都有封装,使用起来很方便: 1.Sobel算子的边缘检测 我们先找一张灰度图像,这里用一张照片,取在HSV色域的V通道: sobel算子有两个方向: -1 -2 -1 0 0 0 1 2 1 -1 0 1 -2 0 2 -1 0 1 分别用来检测水平方向与竖直方向上的边缘, cv::Sobel(image, sobelX, CV_16S, 1, 0);//1,

【CImg】霍夫变换——直线检测

霍夫变换——直线检测 此处膜拜大神(学到很多):http://blog.csdn.net/jia20003/article/details/7724530 这个博客更了很多图像处理算法的底层实现解析,都很详细易懂,先mark ========================我是分割线============================= 霍夫变换:CV中常用的识别几何图形的方法,其中最简单的应用就是直线检测 主要原理是对于边缘的每一个像素点(x0,y0),把可能经过它的所有直线y=kx+b,

目标检测之hough forest---霍夫森林(Hough Forest)目标检测算法

 Hough Forest目标检测一种比较时兴的目标检测算法,Juergen Gall在2009的CVPR上提出. Hough Forest听上去像hough变换+Random Forest的结合体,其实,不完全是这样的.它更像是decision forest和regression forest的结合体再加上generalized hough transform:森林中每棵树即不是分类树也不是回归树,而是其中的每个节点可能为分类节点或者回归节点.分类节点最小化class-label uncert

opencv学习笔记霍夫变换——直线检测

参考大佬博文:blog.csdn.net/jia20003/article/details/7724530 lps-683.iteye.com/blog/2254368 openCV里有两个函数(比较常用)处理霍夫变换直线检测,有什么区别呢. CvHoughLine:是用于标准的霍夫变换方法 CvHoughLine2:可以使用三种霍夫变换的方法,分别是标准霍夫变换(SHT).多尺度标准霍夫变换(MSHT).累计概率霍夫变换(PPHT). 函数原型: CvSeq* cvHoughLines2( C