目标

在这一章当中,

我们将了解霍夫变换的概念。

我们将看到如何使用它来检测图像中的线条。

我们将看到以下函数:cv.HoughLines(),cv.HoughLinesP()

理论

如果可以用数学形式表示形状,则霍夫变换是一种检测任何形状的流行技术。即使形状有些破损或变形,也可以检测出形状。我们将看到它如何作用于一条线。

一条线可以表示为y=mxcy = mx cy=mxc或以参数形式表示为ρ=xcosθysinθ\rho=xcosθ ysinθρ=xcosθysinθ,其中ρ\rhoρ是从原点到该线的垂直距离,而θ\thetaθ是由该垂直线和水平轴形成的角度以逆时针方向测量(该方向随您如何表示坐标系而变化。此表示形式在OpenCV中使用)。查看下面的图片:

因此,如果线在原点下方通过,则它将具有正的ρ\rhoρ且角度小于180。如果线在原点上方,则将角度取为小于180,而不是大于180的角度。ρ\rhoρ取负值。任何垂直线将具有0度,水平线将具有90度。

现在,让我们看一下霍夫变换如何处理线条。任何一条线都可以用(ρ,θ)(ρ,θ)(ρ,θ)这两个术语表示。因此,首先创建2D数组或累加器(以保存两个参数的值),并将其初始设置为000。让行表示ρρρ,列表示θθθ。阵列的大小取决于所需的精度。假设您希望角度的精度为1度,则需要180列。对于ρρρ,最大距离可能是图像的对角线长度。因此,以一个像素精度为准,行数可以是图像的对角线长度。

考虑一个100x100的图像,中间有一条水平线。取直线的第一点。您知道它的(x,y)值。现在在线性方程式中,将值θθθ= 0,1,2,… 180放进去,然后检查得到ρρρ。对于每对(ρ,θ)(ρ,θ)(ρ,θ),在累加器中对应的(ρ,θ)(ρ,θ)(ρ,θ)单元格将值增加1。所以现在在累加器中,单元格(50,90)= 1以及其他一些单元格。

现在,对行的第二个点。执行与上述相同的操作。递增(ρ,θ)(\rho,\theta)(ρ,θ)对应的单元格中的值。这次,单元格(50,90)=2。实际上,您正在对(ρ,θ)(ρ,θ)(ρ,θ)值进行投票。您对线路上的每个点都继续执行此过程。在每个点上,单元格(50,90)都会增加或投票,而其他单元格可能会或可能不会投票。这样一来,最后,单元格(50,90)的投票数将最高。因此,如果您在累加器中搜索最大票数,则将获得(50,90)值,该值表示该图像中的一条线与原点的距离为50,角度为90度。在下面的动画中很好地显示了该图片(图片提供:Amos Storkey)

这就是霍夫变换对线条的工作方式。它很简单,也许您可​​以自己使用Numpy来实现它。下图显示了累加器。某些位置的亮点表示它们是图像中可能的线条的参数。(图片由维基百科提供)

OpenCV中的霍夫曼变换

上面说明的所有内容都封装在OpenCV函数cv.HoughLines()中。它只是返回一个:math:(rho,theta)值的数组。ρρρ以像素为单位,θθθ以弧度为单位。第一个参数,输入图像应该是二进制图像,因此在应用霍夫变换之前,请应用阈值或使用Canny边缘检测。第二和第三参数分别是ρρρ和θθθ精度。第四个参数是阈值,这意味着应该将其视为行的最低投票。请记住,票数取决于线上的点数。因此,它表示应检测到的最小线长。

import cv2 as cv

import numpy as np

img = cv.imread(cv.samples.findFile('sudoku.png'))

gray = cv.cvtColor(img,cv.COLOR_BGR2GRAY)

edges = cv.Canny(gray,50,150,apertureSize = 3)

lines = cv.HoughLines(edges,1,np.pi/180,200)

for line in lines:

rho,theta = line[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))

cv.line(img,(x1,y1),(x2,y2),(0,0,255),2)

cv.imwrite('houghlines3.jpg',img)

检查下面的结果

概率霍夫变换

在霍夫变换中,您可以看到,即使对于带有两个参数的行,也需要大量计算。概率霍夫变换是我们看到的霍夫变换的优化。它没有考虑所有要点。取而代之的是,它仅采用随机的点子集,足以进行线检测。只是我们必须降低阈值。参见下图,比较了霍夫空间中的霍夫变换和概率霍夫变换。(图片提供:Franck Bettinger的主页)

OpenCV的实现基于Matas,J.和Galambos,C.和Kittler, J.V.使用渐进概率霍夫变换对行进行的稳健检测[145]。使用的函数是cv.HoughLinesP()。它有两个新的论点。

minLineLength - 最小行长。小于此长度的线段将被拒绝。

maxLineGap - 线段之间允许将它们视为一条线的最大间隙。

最好的是,它直接返回行的两个端点。在以前的情况下,您仅获得线的参数,并且必须找到所有点。在这里,一切都是直接而简单的。

import cv2 as cv

import numpy as np

img = cv.imread(cv.samples.findFile('sudoku.png'))

gray = cv.cvtColor(img,cv.COLOR_BGR2GRAY)

edges = cv.Canny(gray,50,150,apertureSize = 3)

lines = cv.HoughLinesP(edges,1,np.pi/180,100,minLineLength=100,maxLineGap=10)

for line in lines:

x1,y1,x2,y2 = line[0]

cv.line(img,(x1,y1),(x2,y2),(0,255,0),2)

cv.imwrite('houghlines5.jpg',img)

看到如下结果:

附加资源

Hough Transform on Wikipedia:http://en.wikipedia.org/wiki/Hough_transform

python 霍夫直线变换_OpenCV-Python 霍夫线变换 | 三十二相关推荐

  1. python建站部署_SpringBoot入门建站全系列(三十二)接入xxl-job分布式任务调度平台...

    SpringBoot入门建站全系列(三十二)接入xxl-job分布式任务调度平台 一.概述 XXL-JOB是一个轻量级分布式任务调度平台,其核心设计目标是开发迅速.学习简单.轻量级.易扩展.现已开放源 ...

  2. Android OpenCV(三十二):霍夫直线检测

    霍夫变换利用点与线之间的对偶性,将图像空间中直线上离散的像素点通过参数方程映射为霍夫空间中的曲线,并将霍夫空间中多条曲线的交点作为直线方程的参数映射为图像空间中的直线.给定直线的参数方程,可以利用霍夫 ...

  3. 霍夫直线检测python_opencv+python 霍夫直线检测

    参考:https://blog.csdn.net/fengjiexyb/article/details/78075888 霍夫变换(Hough Transform)是图像处理中的一种特征提取技术,它通 ...

  4. OpenCV-Python 霍夫线变换 | 三十二

    目标 在这一章当中, 我们将了解霍夫变换的概念. 我们将看到如何使用它来检测图像中的线条. 我们将看到以下函数:cv.HoughLines(),cv.HoughLinesP() 理论 如果可以用数学形 ...

  5. OpenCV系列之霍夫线变换 | 三十二

    目标 在这一章当中, 我们将了解霍夫变换的概念. 我们将看到如何使用它来检测图像中的线条. 我们将看到以下函数:cv.HoughLines(),cv.HoughLinesP() 理论 如果可以用数学形 ...

  6. python直线检测_opencv+python 开操作进行直线检测

    参考文章:https://blog.csdn.net/qq_25343557/article/details/78691828 原理: 行矩阵用来检测水平直线,列矩阵用来检测竖直直线. 代码如下: i ...

  7. python opencv视频处理教程_OpenCV+Python详细教程-图片+视频(一)-Go语言中文社区...

    环境 Python3以上的版本+OpenCV+PyCharm 图片 目标 读入,显示,保存图像 对应的函数:cv2.imread(),cv2.imshow(),cv.imwrite() 1.1读取图像 ...

  8. python怎么计算图像梯度_opencv python图像梯度实例详解

    这篇文章主要介绍了opencv python图像梯度实例详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 一阶导数与Soble算子 二阶导数与拉普 ...

  9. python 可视化 画直线_用Python画江苏省地图,实现各地级市数据可视化

    前言 万万没想到我昨天发布的用Python画中国地图,实现各省份数据可视化这篇文章获得了很多朋友的喜欢,目前已获得了66次转发,314次收藏,也让我涨了60个左右粉丝. 小嘚瑟 虽然这点成绩跟很多大V ...

最新文章

  1. 【Flutter】Flutter 混合开发 ( 关联 Android 工程与 Flutter 工程 | 安卓页面中嵌入 Flutter 页面 | 安卓中启动 Flutter 页面 )
  2. 用户请求接口信息日志记录
  3. Vs code自动生成Doxygen格式注释
  4. 各大券商进军人工智能 业内人士:应多措并举促发展
  5. python expect_python--pexpect
  6. 每日小记 2017 2.9
  7. ubuntu12.04 php环境搭建,Ubuntu12.04筹建php开发环境
  8. 《Python编程实战:运用设计模式、并发和程序库创建高质量程序》—— 导读
  9. EVE-NG模拟器综合
  10. Java实验报告(七)|IO编程
  11. CAN数据格式-ASC
  12. 常用的mysql sql语句_常用的SQL语句(MySQL)
  13. 在Win32程序中创建OpenGL渲染环境
  14. 【重识云原生】第六章容器基础6.4.9.6节——Service 与 Pod 的DNS
  15. “成本刺客”防不胜防,如何应用亚马逊云科技驾驭云成本
  16. 微信如何添加企业微信信息服务器地址,企业微信怎么添加管理员 设置方法介绍...
  17. 北京工作居住证办理条件及用途
  18. 最详解消息队列以及RabbbitMQ之HelloWorld
  19. 51单片机基础之DS18B20温度传感器
  20. Cosmos的里程碑2(Mile Stone 2)之RTL8139网卡芯片编程---- .net/C#开源操作系统学习系列八...

热门文章

  1. SAP UI5 初学者教程之二十五 - 使用代理服务器解决 SAP UI5 应用访问远端 OData 服务的跨域问题试读版
  2. ts-node 学习笔记 - 如何解决在 Windows10 下不能直接运行 ts-node 的问题
  3. 如何使用 jMeter CSV Data Set config
  4. 内容分发网络 - Content Delivery Network 学习笔记
  5. aria-required属性学习笔记
  6. Angular 依赖注入机制根据providers定义生成注入实例的框架代码
  7. cannot bind to cxOutlet since it is not a known property of ng template
  8. Angular应用里的tsconfig.app.json
  9. 使用java代码判断一个字符串里是否包含中文字符
  10. CRM产品主数据在行业解决方案industry solution中的应用