前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >HoughCircle找圆总结——opencv

HoughCircle找圆总结——opencv

作者头像
vv彭
发布于 2020-11-24 06:53:19
发布于 2020-11-24 06:53:19
1.4K0
举报
文章被收录于专栏:c#学习笔记c#学习笔记

Opencv内部提供了一个基于Hough变换理论的找圆算法,HoughCircle与一般的拟合圆算法比起来,各有优势:优势:HoughCircle对噪声点不怎么敏感,并且可以在同一个图中找出多个圆;反观拟合圆算法,单纯的拟合结果容易受噪声点的影响,且不支持一个输入中找多个圆 缺点:原始的Hough变换找圆,计算量很大,而且如果对查找圆的半径不加控制,不但运算量巨大,而且精度也不足,在输入噪声点不多的情况下,找圆效果远不如拟合找圆;为了提高找圆精度,相比拟合法,需要提供更多的参数加以控制,参数要求比较严格,且总体稳定性不佳 OpenCV内的HoughCircles对基础的Hough变换找圆做了一定的优化来提高速度,它不再是在参数空间画出一个完整的圆来进行投票,而只是计算轮廓点处的梯度向量,然后根据搜索的半径R在该梯度方向距离轮廓点距离R的两边各投一点,最后根据投票结果图确定圆心位置,其示意图如图1

图1是比较理想的情况,轮廓点1-6的梯度方向都经过了点7,因此都给点7投了一票,点7得分最高,也正是我们所要找的圆心;同时由此可以看出基于参数空间投票法来确定圆心,8-12点就算有投票,但由于投票太散,对整个投票结果也几乎不存在干扰,因而其天生抗干扰能力要比拟合法好 不过在这种思想优化下,也存在致命的缺陷,如图2:

实际情况是该点算出的梯度方向其实总是有误差的,有时因为图像原因或结构原因,偏差甚至超过30度;图2中由于梯度方向不精确,7点基本没有获得投票,反而不如ABC点。因此实际使用中HoughCircle的效果并没有想象中的理想,情况往往如下列所述: (参与投票的轮廓点如图3的右图,噪点非常多,比想要查找的轮廓本身还多,而且断断续续的,显然这种情况拟合法不适用) 1、半径范围限定不好时,如图3,可能找到的圆非常多且杂乱无章 2、在此情况下,如果只输出一个圆(Opencv的HoughCircle会默认按照投票结果的累加值排序),最好的圆是这样的,竟然差这么多

3、假设我们找的东西的半径我们是知道的,变化不大(+-8%),现在限定下半径。。。找出的排的靠前的圆是这样的;再看下默认最好的圆。。。

半径好像接近了一点,还是好坑爹啊。。。 4、常规来说,使用该函数的时候,为避免找到太多的几乎重合的圆,找圆的最小距离都设在一个比较合理的值(比如大于半径1/5),这样在找多个圆的时候,就不会找出太多重合的圆了;不过这里我试下不限制最小距离,如下,默认排序下得分最高的几个圆如左图:

貌似默认最好的圆并没有任何改善 很多初次使用该函数的看到这,或许就就觉得HoughCircles效果不咋地。。。本人刚开始使用时也感觉Opencv提供的这个算法太不稳定了,只能对某一个图调出相对好一点的效果,换一个图或者只改动其中某一个参数,找出来的圆就不知道跑哪去了,而且变化太大了

。。。 观察细心的可能发现了,第4步中的左图找出的众多圆其实已经比前面找出的圆靠谱很多了,而且这么多圆必定有一个圆就是我想要找的圆,只是按照投票分数排序下,最好的圆偏差较大。 但究其算法优化本身,轮廓梯度定位出来的圆心投票本来精度就低(如图2),自然找出来的圆会有很多是错误的,但如果轮廓点足够多,找出的正确的圆必定也是存在的,只是按照票数方法来评价可能排序会比较靠后,但毕竟也是出现了的;此处只需做个小小的优化,改下评价方法,优化下排序,结果就很接近了

这是经过优化排序方法后找出的最好的圆 找出来的圆中与实际轮廓重合度最高的圆一般就是我们要找的圆;因此我们可以通过HoughCircles来找出一批差不多的圆(如步骤4),然后画出这些圆,和实际轮廓比对一下,按实际重合像素的总数排序,这时分数最高的圆就如上面的结果图!HoughCircles优化一下还是很给力的! 附件为本算法优化源码,有兴趣的可以一起来进一步优化()

注:如果编译通过,但运行时崩溃,通常原因是库版本不对!一般OpenCV官方给出的库版本分x86,x64,而每个平台下又有vc10,vc11,vc12,分别对应VS2010,VS2012,VS2013;其下还分debug版和release版,必须严格与编译环境和使用的配置相对应,否则会在运行过程中出错,且非常不好排查原因 另该优化目前只能做到减少HoughCirlcles找错圆且错的比较离谱的几率,但无法真正提高精度,找出来的圆与实际圆稍有偏差还是有可能的;若需要高精度定位,建议采用该方法做粗定位,采用拟合圆做精定位(类似各商业算法中的环形区域找圆)

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-11-20 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
Python opencv图像处理基础总结(六) 直线检测 圆检测 轮廓发现
我还有改变的可能性 一想起这一点 我就心潮澎湃 文章目录 一、直线检测 使用霍夫直线变换做直线检测,前提条件:边缘检测已经完成 # 标准霍夫线变换 cv2.HoughLines(image, rho, theta, threshold, lines=None, srn=None, stn=None, min_theta=None, max_theta=None) image:经过边缘检测的输出图像,8位,单通道二进制源图像 rho:距离步长 theta:角度步长 threshold:阈值,只有
叶庭云
2020/09/17
8.6K0
Python opencv图像处理基础总结(六) 直线检测 圆检测 轮廓发现
C++ OpenCV霍夫变换--圆检测
霍夫圆变换的基本思路是认为图像上每一个非零像素点都有可能是一个潜在的圆上的一点,跟霍夫线变换一样,也是通过投票,生成累积坐标平面,设置一个累积权重来定位圆。如下图:
Vaccae
2019/07/24
2.8K0
OpenCV 图像分析之 —— 霍夫变换(Hough Transform)
Hough(霍夫)变换是一种用于检测线、圆或者图像中其他简单形状的方法。最初Hough变换是一种线变换,这是一种相对较快的检测二值图像中直线的方法,可以进一步推广到除简单线之外的情况。
为为为什么
2022/08/09
5.3K0
OpenCV 图像分析之 —— 霍夫变换(Hough Transform)
【计算机视觉】【图像处理综合应用】路沿检测
用python的OpenCV实现视频文件的处理,用videoCapture打开视频文件,读取每一帧进行处理,然后用videoWriter保存成视频。
叶茂林
2023/11/27
4660
【计算机视觉】【图像处理综合应用】路沿检测
OpenCV 圆检测
OpenCV 的 HoughCircles() 函数可以用来在一张单通道图像里检测圆形物体。下面是各参数的介绍:
用户6021899
2019/09/08
2.3K0
Python+opencv 机器视觉 - 基于霍夫圈变换算法检测图像中的圆形实例演示
这个是设定半径范围 50-70 后的效果,因为原图稍微大一点,半径也大了一些。
小蓝枣
2022/01/11
1.5K0
Python+opencv 机器视觉 - 基于霍夫圈变换算法检测图像中的圆形实例演示
终于可以摆脱OpenCV中Hough圆调参的烦恼了
OpenCV图像项目中,圆的检测很常见。 例如:检测烂苹果的个数,寻找目标靶心,人眼,嘴巴识别等。 其中用到的关键技术是OpenCV中集成的霍夫圆检测函数。 HoughCircles( InputArray image, // 输入图像 ,必须是8位的单通道灰度图像 OutputArray circles, // 输出结果,发现的圆信息 Int method, // 方法 - HOUGH_GRADIENT Double dp,
用户9831583
2022/06/16
2.8K0
终于可以摆脱OpenCV中Hough圆调参的烦恼了
计算机视觉 OpenCV Android | 基本特征检测之 霍夫圆检测
霍夫圆变换与霍夫直线变换的原理类似,也是将圆上的每个点转换到霍夫空间, 其转换的参数方程如下: 对于圆来说,θ的取值范围在0~360°,这样就有了三个参数, 另外两个参数是圆心(x
凌川江雪
2019/03/04
1.6K0
hough变换检测圆原理(定位变换后的面如何变成实体)
Hough变换是由Paul Hough于1962年提出的一种检测圆的算法,它的基本思想是将图像从原图像空间变换到参数空间,在参数空间中,使用大多数边界点都满足的某种参数形式作为图像中的曲线的描述,它通过设置累加器对参数进行累积,其峰值对应的点就是所需要的信息。
全栈程序员站长
2022/07/25
1.7K0
hough变换检测圆原理(定位变换后的面如何变成实体)
用 OpenCV 给图像 “挑挑拣拣”,找出关键信息!
在当今数字化信息爆炸的时代,图像和视频数据海量增长。从这些视觉数据中提取关键信息变得尤为重要。OpenCV(Open Source Computer Vision Library)是一个强大的开源计算机视觉库,它提供了各种工具和算法,能帮助我们从图像和视频里提取出我们想要的关键词信息。这就好比在一堆杂乱的拼图中,快速找出关键的几块。接下来,让我们一起走进 OpenCV 关键词提取的奇妙世界。
羑悻的小杀马特.
2025/04/08
1430
用 OpenCV 给图像 “挑挑拣拣”,找出关键信息!
OpenCV:霍夫直线变换和霍夫圆变换
如果可以用数学形式表示形状,则霍夫变换是检测任何形状的一种比较流行的技术。即使形状有些破损或变形,也可以检测出形状。本文将讲解如何将它何作用于一条线。
用户3578099
2023/09/01
7410
OpenCV:霍夫直线变换和霍夫圆变换
基于Python利用OpenCV实现Hough变换的形状检测
在我们开始对图像应用霍夫变换之前,我们需要了解霍夫空间是什么,我们将通过一个例子来进行了解。
小白学视觉
2022/02/14
2.5K0
基于Python利用OpenCV实现Hough变换的形状检测
基于Opencv的图像处理软件
在制造业中,需要对产品表面进行检测,通过图像处理技术可以快速准确地识别出产品表面的缺陷,从而提高产品质量。例如在汽车制造过程中,对车身零部件表面的划痕、凹坑等缺陷进行检测。
Srlua
2024/11/27
1730
基于Opencv的图像处理软件
OpenCV学习+常用函数记录③:霍夫变换与轮廓提取
OpenCV 霍夫变换与轮廓提取 3. 霍夫变换 3.1 霍夫直线 3.2 霍夫圆 4. 轮廓提取 4.1 查找轮廓 4.2 绘制轮廓 3. 霍夫变换 首先放上霍夫变换官方文档:[霍夫直线变换官网文档] 3.1 霍夫直线 import cv2 as cv import matplotlib.pyplot as plt import numpy as np # 1. 将图片以灰度的方式读取进来 img = cv.imread("../img/weiqi.jpg", cv.IMREAD_COLOR) gr
小黑鸭
2020/11/24
9950
前端 + AI —— 走进无码时代
导语:前端智能化,就是通过AI/CV技术,使前端工具链具备理解能力,进而辅助开发提升研发效率,比如实现基于设计稿智能布局和组件智能识别等。
Y.one
2020/09/01
1.3K0
前端 + AI —— 走进无码时代
我用Python合成大西瓜!
这周五没漂亮妹妹带我出去玩了呜呜,无聊在家扣手机,发现大家都在合成大西瓜 。作为一个未来年轻无为的计算机科学家(或许是人民艺术家),我是不屑于玩这种浪费时间又无聊的游戏的(因为玩了四小时才合成了第一个大西瓜),但为了投身到人民群众中去,我决定尝试写一个程序挂机跑一下。
Datawhale
2021/02/05
6380
我用Python合成大西瓜!
OpenCV图像处理(十九)---霍夫变换
内能(internal energy) 从微观的角度来看,是分子无规则运动能量总和的统计平均值。分子无规则运动的能量包括分子的动能、分子间相互作用势能以及分子内部运动的能量。物体的内能不包括这个物体整体运动时的动能和它在重力场中的势能。
用户5410712
2022/06/01
6970
OpenCV图像处理(十九)---霍夫变换
OpenCV与图像处理(四)
以下代码均在python3.6,opencv4.2.0环境下试了跑一遍,可直接运行。
Must
2020/07/28
6810
OpenCV与图像处理(四)
无人驾驶之车道线检测简易版
本文介绍了如何使用计算机视觉技术检测车道线,主要包括使用高斯模糊、Canny边缘检测、Hough变换等方法对车道线进行检测,以及通过这些方法对车道线进行提取、拟合和展示。同时,还介绍了一种基于ROI(Region of Interest)的车道线检测方法,该方法通过边缘检测、Canny边缘检测、Hough变换等步骤对车道线进行检测,并通过拟合、平滑等处理提取出车道线。最后,通过实验验证了该方法的可行性和有效性。
用户1147754
2018/01/02
2.6K0
无人驾驶之车道线检测简易版
2.霍夫变换
霍夫变换是检测直线或者圆的一种比较简单的方法。霍夫变换检测直线是比较简单的,做完以后是一个二维平面上的许多曲线,通过统计平面上交点的个数,就可以得出哪些点事处于同一条直线上的。
和蔼的zhxing
2018/09/04
6980
2.霍夫变换
相关推荐
Python opencv图像处理基础总结(六) 直线检测 圆检测 轮廓发现
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档