当前位置:   article > 正文

OpenCV实践之路——Hough变换检测猫眼_猫眼探测 算法

猫眼探测 算法


本文由@星沉阁冰不语出品,转载请注明作者和出处。

文章链接:http://blog.csdn.net/xingchenbingbuyu/article/details/50793235

微博:http://weibo.com/xingchenbing 


Hough变换

Hough变换是图像处理中的一种特征提取技术,它通过一种投票算法检测具有特定形状的物体。

霍夫变换于1962年由Paul Hough 首次提出,后于1972年由Richard Duda和Peter Hart推广使用,经典霍夫变换用来检测图像中的直线,后来霍夫变换扩展到任意形状物体的识别,多为圆和椭圆。

Hough变换是一种使用表决原理的参数估计技术。其原理是利用图像空间和Hough参数空间的点-线对偶性,把图像空间中的检测问题转换到参数空间

我们知道,在x-y坐标系内直线的方程可以用y=k*x+b 来表示,其中k和b是参数,分别是斜率和截距。若已知k和b的值,则直线确定。那么可以说,在k-b坐标系中的一点(k,b)确定了x-y坐标系中的一条直线,即y = k * x+b。反之亦然,即在x-y坐标系的一点(x,y)确定了k-b坐标系中的一条直线,即b=-x*k+y。

即参数空间一点确定图像空间的一条直线,图像空间一点确定参数空间一条直线。图像空间中共线的点在参数空间对应的直线相交于一点。

由于Hough直线检测时参数调整太耗时了,所以这个时候先给出一个检测Hough圆的例子。等什么时候把直线调参研究的差不多了再补充检测直线的程序。仍然是这只高冷的喵。

程序如下:

  1. #include<opencv.hpp>
  2. using namespace std;
  3. using namespace cv;
  4. int main()
  5. {
  6. Mat img = imread("miao.jpg");
  7. Mat gray;
  8. Mat gray1,edge1,dst;
  9. cvtColor(img, gray, 6);
  10. vector<Vec3f> circles;
  11. HoughCircles(gray, circles, CV_HOUGH_GRADIENT, 1, 5, 10, 53, 20,50);
  12. for (size_t i = 0; i < circles.size(); i++)
  13. {
  14. Point center(round(circles[i][0]), round(circles[i][1]));
  15. int radius = round(circles[i][2]);
  16. circle(img, center, 3, Scalar(0, 255, 0), -1, 8, 0);
  17. circle(img, center, radius, Scalar(155, 50, 255), 3, 8, 0);
  18. }
  19. imshow("circle",img);
  20. waitKey(0);
  21. return 0;
  22. }

效果图很是风情万种:




最近开通了微信公众号,感兴趣的同学可以扫码在微信上交流。






声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Guff_9hys/article/detail/998587
推荐阅读
相关标签
  

闽ICP备14008679号