Hough变换(openCV的cvHoughLines2)

cvHoughLines2

功能:

利用Hough变换在二值图像中寻找直线。

函数原型:

   CvSeq* cvHonghLines2(CvArr* image,void* line_storage,int mehtod,double rho,

double theta,int threshold,double param1 =0,double param2 =0);

参数说明:

  image

  输入8-比特、单通道(二值)图像,当用CV_HOUGH_PROBABILISTIC方法检测的时候其内容会被函数改变。

  line_storage

  检测到的线段存储仓.可以是内存存储仓(此种情况下,一个线段序列在存储仓中被创建,并且由函数返回),或者是包含线段参数的特殊类型(见下面)的具有单行/单列的矩阵(CvMat*)。矩阵头为函数所修改,使得它的 cols/rows 将包含一组检测到的线段。如果 line_storage 是矩阵,而实际线段的数目超过矩阵尺寸,那么最大可能数目的线段被返回(线段没有按照长度、可信度或其它指标排序).

  method

  Hough 变换变量,是下面变量的其中之一:

  CV_HOUGH_STANDARD - 传统或标准 Hough 变换每一个线段由两个浮点数 (ρ, θ) 表示,其中 ρ 是直线与原点(0,0) 之间的距离,θ 线段与 x-轴之间的夹角。因此,矩阵类型必须是 CV_32FC2 type.

  CV_HOUGH_PROBABILISTIC- 概率 Hough 变换(如果图像包含一些长的线性分割,则效率更高). 它返回线段分割而不是整个线段。每个分割用起点和终点来表示,所以矩阵(或创建的序列)类型是 CV_32SC4.

  CV_HOUGH_MULTI_SCALE - 传统 Hough 变换的多尺度变种。线段的编码方式与 CV_HOUGH_STANDARD 的一致。

  rho

  以象素为单位的距离精度,一般取1

  theta

  以弧度为单位角度精度,一般取CV_PI/180

  threshold

阈值参数。当在一条直线上的像素点数大于threshold时,才将该直线作为检测结果显示出来。该值越大,得到直线越少。

  param1

  对传统 Hough 变换,不使用(0).

  对概率Hough变换,它是最小线段长度.即当线段长度大于param1时,才将该线段作为检测结果显示。与上一参数类似,不过上一参数为像素数,而该参数为线段长度。

  对多尺度 Hough 变换,它是距离精度 rho 的分母 (大致的距离精度是 rho 而精确的应该是 rho / param1 ).

  param2

  对传统 Hough 变换,不使用 (0).

  对概率 Hough 变换,这个参数表示在同一条直线上进行碎线段连接的最大间隔值(gap), 即当同一条直线上的两条碎线段之间的间隔小于param2时,将其合二为一条长直线。

  对多尺度 Hough 变换,它是角度精度 theta 的分母 (大致的角度精度是 theta 而精确的角度应该是 theta / param2).

以下代码为OpenCV教程自带的代码:

[cpp]  view plain copy
  1. #include<cv.h>  
  2. #include <highgui.h>  
  3. #include <math.h>  
  4.   
  5. int main(void)  
  6. {  
  7.     IplImage *src = cvLoadImage("D:\\xgmiao\\image\\1.jpg",0);  
  8.     if (src)  
  9.     {  
  10.         IplImage *dst = cvCreateImage(cvGetSize(src),8,1);  
  11.         IplImage *color_dst = cvCreateImage(cvGetSize(src),8,3);  
  12.         CvMemStorage *storage = cvCreateMemStorage();  
  13.         CvSeq *lines = 0;  
  14.         int i ;  
  15.         cvCanny(src,dst,50,200,3);  
  16.       
  17.         cvCvtColor(dst,color_dst,CV_GRAY2BGR);  
  18.     #if 0  
  19.         lines = cvHoughLines2(dst,storage,CV_HOUGH_STANDARD,1,CV_PI/180,150,0,0);  
  20.           
  21.         for (i=0;i<lines->total;i++)  
  22.         {  
  23.             float *line = (float *)cvGetSeqElem(lines,i);  
  24.             float rho = line[0];  
  25.             float theta = line[1];  
  26.             CvPoint pt1,pt2;  
  27.             double a = cos(theta);  
  28.             double b = sin(theta);  
  29.             if (fabs(a)<0.001)  
  30.             {  
  31.                 pt1.x = pt2.x = cvRound(rho);  
  32.                 pt1.y = 0;  
  33.                 pt2.y = color_dst->height;  
  34.             }  
  35.             else if (fabs(b)<0.001)  
  36.             {  
  37.                 pt1.y = pt2.y = cvRound(rho);  
  38.                 pt1.x = 0;  
  39.                 pt2.x = color_dst->width;  
  40.             }  
  41.             else  
  42.             {  
  43.                 pt1.x = 0;  
  44.                 pt1.y = cvRound(rho/b);  
  45.                 pt2.x = cvRound(rho/a);  
  46.                 pt2.y = 0;  
  47.             }  
  48.   
  49.             cvLine(color_dst,pt1,pt2,CV_RGB(255,0,0),1,8);  
  50.         }  
  51.     #else  
  52.         lines = cvHoughLines2(dst,storage,CV_HOUGH_PROBABILISTIC,1,CV_PI/180,80,30,5);  
  53.         for (i=0;i<lines->total;i++)  
  54.         {  
  55.             CvPoint *line = (CvPoint *)cvGetSeqElem(lines,i);  
  56.             cvLine(color_dst,line[0],line[1],CV_RGB(255,0,0),1,CV_AA);  
  57.         }  
  58.     #endif  
  59.         cvNamedWindow("Source");  
  60.         cvShowImage("Source",src);  
  61.   
  62.         cvNamedWindow("Hough");  
  63.         cvShowImage("Hough",color_dst);  
  64.   
  65.         cvWaitKey(0);  
  66.   
  67.         cvReleaseImage(&src);  
  68.         cvReleaseImage(&dst);  
  69.         cvReleaseImage(&color_dst);  
  70.         cvReleaseMemStorage(&storage);  
  71.           
  72.         cvDestroyAllWindows();  
  73.           
  74.         return 1;  
  75.     }  
  76. }  
结果如下图:

Hough变换(openCV的cvHoughLines2)_第1张图片Hough变换(openCV的cvHoughLines2)_第2张图片


本文PDF版下载地址:http://pan.baidu.com/share/link?shareid=1751675784&uk=4213349809

主题推荐
opencv 存储 math.h 编码 内存
猜你在找
查看评论
3楼  nihate 2013-11-26 17:28发表 [回复]
cvCanny(src,dst,50,200,3); cvCvtColor(dst,color_dst,CV_GRAY2BGR); 
这两条语句的先后顺序不对吧,而且里面的参数也不对
Re:  u010102899 2013-12-06 15:18发表 [回复]
回复nihate:cvCanny求出线条,然后需要转换成三通道图。
因为hough需要在三通道上面绘制
Re:  u010102899 2013-12-06 15:17发表 [回复]
回复nihate:没什么问题吧
2楼  u010679550 2013-11-22 16:04发表 [回复]
我想知道怎么用Hough变换检测直线还有好多没检测到的呢?而且投票数我也设的足够小了。。。。
1楼  yyeric11 2013-04-02 18:31发表 [回复] [引用] [举报]
问下使用的是哪个版本的opencv?
Re:  xgmiao 2013-04-03 18:59发表 [回复] [引用] [举报]
回复yyeric11:2.3.1

你可能感兴趣的:(Hough变换(openCV的cvHoughLines2))