• 霍夫线变换


    霍夫线变换

    目标

    在这个部分您将学习到:

    原理

    Note

     

    以下原理的说明来自书籍 学习OpenCV 作者Bradski和Kaehler.

    霍夫线变换

    1. 霍夫线变换是一种用来寻找直线的方法.
    2. 是用霍夫线变换之前, 首先要对图像进行边缘检测的处理,也即霍夫线变换的直接输入只能是边缘二值图像.

    它是如何实现的?

    1. 众所周知, 一条直线在图像二维空间可由两个变量表示. 例如:

      1. 在 笛卡尔坐标系: 可由参数: (m,b) 斜率和截距表示.
      2. 在 极坐标系: 可由参数: (r,	heta) 极径和极角表示
      Line variables

      对于霍夫变换, 我们将用 极坐标系 来表示直线. 因此, 直线的表达式可为:

      y = left ( -dfrac{cos 	heta}{sin 	heta} 
ight ) x + left ( dfrac{r}{sin 	heta} 
ight )

      化简得: r = x cos 	heta + y sin 	heta

    2. 一般来说对于点 (x_{0}, y_{0}), 我们可以将通过这个点的一族直线统一定义为:

      r_{	heta} = x_{0} cdot cos 	heta  + y_{0} cdot sin 	heta

      这就意味着每一对 (r_{	heta},	heta) 代表一条通过点 (x_{0}, y_{0}) 的直线.

    3. 如果对于一个给定点 (x_{0}, y_{0}) 我们在极坐标对极径极角平面绘出所有通过它的直线, 将得到一条正弦曲线. 例如, 对于给定点 x_{0} = 8 and y_{0} = 6 我们可以绘出下图 (在平面 	heta - r):

      Polar plot of a the family of lines of a point

      只绘出满足下列条件的点 r > 0 and 0< 	heta < 2 pi.

    4. 我们可以对图像中所有的点进行上述操作. 如果两个不同点进行上述操作后得到的曲线在平面 	heta - r 相交, 这就意味着它们通过同一条直线. 例如, 接上面的例子我们继续对点: x_{1} = 9y_{1} = 4 和点 x_{2} = 12y_{2} = 3 绘图, 得到下图:

      Polar plot of the family of lines for three points

      这三条曲线在 	heta - r 平面相交于点 (0.925, 9.6), 坐标表示的是参数对 (	heta, r) 或者是说点 (x_{0}, y_{0}), 点 (x_{1}, y_{1}) 和点 (x_{2}, y_{2}) 组成的平面内的的直线.

    5. 那么以上的材料要说明什么呢? 这意味着一般来说, 一条直线能够通过在平面 	heta - r 寻找交于一点的曲线数量来 检测. 越多曲线交于一点也就意味着这个交点表示的直线由更多的点组成. 一般来说我们可以通过设置直线上点的 阈值 来定义多少条曲线交于一点我们才认为 检测 到了一条直线.

    6. 这就是霍夫线变换要做的. 它追踪图像中每个点对应曲线间的交点. 如果交于一点的曲线的数量超过了 阈值, 那么可以认为这个交点所代表的参数对 (	heta, r_{	heta}) 在原图像中为一条直线.

    标准霍夫线变换和统计概率霍夫线变换

    OpenCV实现了以下两种霍夫线变换:

    1. 标准霍夫线变换
    • 原理在上面的部分已经说明了. 它能给我们提供一组参数对 (	heta, r_{	heta}) 的集合来表示检测到的直线
    • 在OpenCV 中通过函数 HoughLines 来实现
    1. 统计概率霍夫线变换
    • 这是执行起来效率更高的霍夫线变换. 它输出检测到的直线的端点 (x_{0}, y_{0}, x_{1}, y_{1})
    • 在OpenCV 中它通过函数 HoughLinesP 来实现
  • 相关阅读:
    MongoDB学习
    Linux 硬盘分区、分区、删除分区、格式化、挂载、卸载
    openstack中数据库连接数太多--pymysql.err.OperationalError,1040, u'Too many connections'
    openstack各服务端口使用情况
    linux常用命令
    云计算---OpenStack Neutron详解
    shell---数据流重定向
    云计算---openstack创建虚拟机过程
    SpringMvc面试题
    Linux 本机/异机文件对比
  • 原文地址:https://www.cnblogs.com/fag888/p/5789173.html
Copyright © 2020-2023  润新知