OpenCV 实现霍夫圆变换

返回:OpenCV系列文章目录(持续更新中......)

上一篇:OpenCV实现霍夫变换
下一篇:OpenCV 实现重新映射

目标

在本教程中,您将学习如何:

  • 使用 OpenCV 函数 HoughCircles()检测图像中的圆圈。

理论

Hough 圆变换

  • Hough Circle 变换的工作方式与上一教程中介绍的 Hough Line 变换大致相似。
  • 在线路检测情况下,一条线路由两个参数 (r,Q)定义。在圆的情况下,我们需要三个参数来定义一个圆:

    其中 (xcenter,ycenter)定义中心位置(绿点,),r是半径,这让我们可以完全定义一个圆,如下图所示:

  • 为了提高效率,OpenCV 实现了一种比标准 Hough 变换稍微棘手的检测方法:Hough 梯度方法,它由两个主要阶段组成。第一阶段涉及边缘检测和查找可能的圆心,第二阶段为每个候选中心找到最佳半径。有关更多详细信息,请查看《学习 OpenCV》一书或您最喜欢的计算机视觉参考书目
  • 这个程序是做什么的?

  • 加载图像并对其进行模糊处理以减少噪点
  • 将 Hough Circle 变换应用于模糊图像。
  • 在窗口中显示检测到的圆圈。

C++代码

我们将要解释的示例代码可以从这里下载。可以在此处找到一个稍微花哨的版本(显示用于更改阈值的跟踪栏)。

#include "opencv2/imgcodecs.hpp"
#include "opencv2/highgui.hpp"
#include "opencv2/imgproc.hpp"using namespace cv;
using namespace std;int main(int argc, char** argv)
{const char* filename = argc >=2 ? argv[1] : "smarties.png";// Loads an imageMat src = imread( samples::findFile( filename ), IMREAD_COLOR );// Check if image is loaded fineif(src.empty()){printf(" Error opening image\n");printf(" Program Arguments: [image_name -- default %s] \n", filename);return EXIT_FAILURE;}Mat gray;cvtColor(src, gray, COLOR_BGR2GRAY);medianBlur(gray, gray, 5);vector<Vec3f> circles;HoughCircles(gray, circles, HOUGH_GRADIENT, 1,gray.rows/16, // change this value to detect circles with different distances to each other100, 30, 1, 30 // change the last two parameters// (min_radius & max_radius) to detect larger circles);for( size_t i = 0; i < circles.size(); i++ ){Vec3i c = circles[i];Point center = Point(c[0], c[1]);// circle centercircle( src, center, 1, Scalar(0,100,100), 3, LINE_AA);// circle outlineint radius = c[2];circle( src, center, radius, Scalar(255,0,255), 3, LINE_AA);}imshow("detected circles", src);waitKey();return EXIT_SUCCESS;
}

解释

我们使用的图像可以在这里找到

加载图像:

 const char* filename = argc >=2 ? argv[1] : "smarties.png";// Loads an imageMat src = imread( samples::findFile( filename ), IMREAD_COLOR );// Check if image is loaded fineif(src.empty()){printf(" Error opening image\n");printf(" Program Arguments: [image_name -- default %s] \n", filename);return EXIT_FAILURE;}

将其转换为灰度:

 Mat gray;cvtColor(src, gray, COLOR_BGR2GRAY);

应用中值模糊以减少噪点并避免误圆检测:

 medianBlur(gray, gray, 5);

继续应用 Hough Circle 变换:

 vector<Vec3f> circles;HoughCircles(gray, circles, HOUGH_GRADIENT, 1,gray.rows/16, // change this value to detect circles with different distances to each other100, 30, 1, 30 // change the last two parameters// (min_radius & max_radius) to detect larger circles);
  • 带有参数:
    • 灰色:输入图像(灰度)。
    • circles:存储 3 个值集的向量:xc1,yc1 对于每个检测到的圆。
    • HOUGH_GRADIENT:定义检测方法。目前,这是 OpenCV 中唯一可用的。
    • dp = 1:分辨率的倒比。
    • min_dist = gray.rows/16:检测到的中心之间的最小距离。
    • param_1 = 200:内部 Canny 边缘检测器的上限阈值。
    • param_2 = 100*:中心检测的阈值。
    • min_radius = 0:要检测的最小半径。如果未知,则将零作为默认值。
    • max_radius = 0:要检测的最大半径。如果未知,则将零作为默认值。

绘制检测到的圆圈:

 for( size_t i = 0; i < circles.size(); i++ ){Vec3i c = circles[i];Point center = Point(c[0], c[1]);// circle centercircle( src, center, 1, Scalar(0,100,100), 3, LINE_AA);// circle outlineint radius = c[2];circle( src, center, radius, Scalar(255,0,255), 3, LINE_AA);}

你可以看到,我们将用红色画圆圈,用一个小绿点画中心

显示检测到的圆圈并等待用户退出程序:

 imshow("detected circles", src);waitKey();

结果

使用测试图像运行上述代码的结果如下所示:


参考文献:

1、《Hough Circle Transform》------Ana Huamán

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/313550.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

L2-052 吉利矩阵

题目描述 题解思路 这个道题就是很简单&#xff0c;就跟n皇后问题一样&#xff0c;给矩阵填数&#xff0c;使得矩阵满足一个什么条件&#xff0c;最后求方案数或者方案。很容易想到回溯法&#xff0c;根据数据范围&#xff0c;应该能够确定回溯法是没有问题的。 我们只需要枚举…

Python实现线性拟合及绘图

Python实现线性拟合及绘图 当时的数字地形实验&#xff0c;使用matplotlib库绘制了一张图表表示不同地形类别在不同分辨率下的RMSE值&#xff0c;并分别拟合了一条趋势线。现在来看不足就是地形较多时&#xff0c;需要使用循环更好一点&#xff0c;不然太冗余了。 代码逻辑 …

80个在线小游戏源码

源码简介 搭建80个在线小游戏网站源码&#xff0c;解压即可食用&#xff0c;支持在本地浏览器打开。 安装教程 纯HTML&#xff0c;直接将压缩包上传网站目录解压即可 首页截图 源码下载 80个在线小游戏源码-小8源码屋

vscode 打代码光标特效

vscode 打代码光标特效 在设置里面找到settings 进入之后在代码最下方加入此代码 "explorer.confirmDelete": false,"powermode.enabled": true, //启动"powermode.presets": "fireworks", // 火花效果// particles、 simple-rift、e…

STM32_舵机的实战

一、配置相应的管脚 二、写代码

ASP.NET集成客户关系管理的企业网站的设计与开发

摘 要 企业要在激烈的市场竞争中立于不败之地&#xff0c;就必须找一种全新的管理理念和管理手段&#xff0c;对其内部和外部资源进行有效的整合。新一代ERP产品正在向客户端和供应端延伸&#xff0c;客户端的延伸即是客户关系管理。对于每个企业来说客户管理的完善程度将直接…

大语言模型(LLM)漏洞爆发,AI模型无一幸免

本文概述了人工智能初创公司Anthropic于2024年04月03日发表的一篇针对人工智能安全的论文&#xff0c;该公司在本论文中宣布的一种新的“越狱”技术&#xff0c;名为Many-shot Jailbreaking&#xff08;多轮越狱&#xff09;。文章详细描述了目前大语言模型&#xff08;LLM&…

IOS恢复

1、实验目的 通过本实验可以掌握&#xff1a; copy方式恢复IOS的步骤。TFTPDNLD方式恢复IOS的步骤。Xmodem方式恢复IOS的步骤。 2、实验拓扑 路由器IOS恢复的实验拓扑如下图所示。 3、实验步骤 如果工作中不慎误删除路由器IOS&#xff0c;或者升级了错误版本的IOS&#xff…

目标检测网络YOLO进化之旅

yolo系列网络在目标检测领域取得了巨大的成功&#xff0c; 尤其是在工程实践中&#xff0c; 以其出色的性能优势获得了广泛的应用落地。 YOLO的前3个版本是由同一个作者团队出品&#xff0c; 算是官方版本。 之后的版本都是各个研究团队自己改进的版本&#xff0c; 之间并无明…

【华为 ICT HCIA eNSP 习题汇总】——题目集17

1、以下哪项不属于网络层安全威胁&#xff1f; A、DDos攻击 B、钓鱼攻击 C、IP Spoofing D、IP地址扫描 考点&#xff1a;网络安全 解析&#xff1a;&#xff08;B&#xff09; 钓鱼攻击通常被认为是应用层的安全威胁&#xff0c;也有在网络层进行伪装实施钓鱼攻击&#xff0c;…

Android驱动开发之如何编译和更换内核

编译内核可以使用图形化的界面配置,也可以直接使用脚本。在X86_64模拟器环境下,不用交叉编译,而交叉编译工具很容易出现兼容问题,一般也只能使用芯片厂商提供的工具,而不是GNU提供的工具。 android内核开发流程以及架构变化了很多,详情请看 内核官网 内核版本选择 由…

揭秘区块链的魅力:了解其功能与区块链项目的媒体宣发策略

在数字化的今天&#xff0c;区块链这一先进的技术逐渐成为公众的焦点。然而&#xff0c;许多人对于区块链能干什么&#xff0c;以及如何为区块链项目进行媒体宣发这两大问题抱着疑惑。接下来&#xff0c;让我们一起揭开这个迷雾。 我们先来了解下区块链究竟能做什么。简单地说&…

Tensorflow AutoGraph 的作用和功能

&#x1f349; CSDN 叶庭云&#xff1a;https://yetingyun.blog.csdn.net/ TensorFlow AutoGraph 是 TensorFlow 中的一个重要特性&#xff0c;它允许开发者使用普通的 Python 语法编写高效的 TensorFlow 图&#xff08;graph&#xff09;。这意味着开发者可以利用 Python 的易…

Nginx基本使用 反向代理与负载均衡

什么是Nginx Nginx (engine x) 是一个高性能的HTTP和反向代理web服务器。 其特点是占有内存少&#xff0c;并发能力强&#xff0c;nginx的并发能力在同类型的网页服务器中表现较好&#xff0c;而且几乎可以做到7*24不间断运行&#xff0c;即使运行数个月也不需要重新启动。 …

多客圈子交友系统 uniapp+thinkphp6适配小程序/H5/app/api全开源,多款插件自选,支持个性定制!

网上交友的优点包括&#xff1a; 1. 方便&#xff1a;网上交友可以随时随地进行&#xff0c;不受时间和空间的限制&#xff0c;方便且高效。 2. 匿名性&#xff1a;网上交友可以实现匿名性&#xff0c;用户可以匿名地搜索、聊天或交换信息&#xff0c;保护个人隐私和安全。 3.…

WEB服务的配置与使用 Apache HTTPD

目录 Web 访问过程&#xff1a; HTTP请求报文&#xff08;请求行、请求头、请求体&#xff09;以及响应报文&#xff1a; 补充&#xff1a; Apache HTTPD服务器的安装与配置 安装&#xff1a; 配置&#xff1a; 修改首页&#xff1a; 打开目录权限 &#xff1a; 重启&#xff1…

(九)Pandas表格样式 学习简要笔记 #Python #CDA学习打卡

目录 一. Pandas表格样式 1&#xff09;举例数据 2&#xff09;字体颜色 3&#xff09;背景高亮 4&#xff09;极值背景高亮 &#xff08;a&#xff09;高亮最大值 highlight_max() &#xff08;b&#xff09;高亮最小值 highlight_min() &#xff08;c&#xff09;同时…

记一次中间件宕机以后持续请求导致应用OOM的排查思路(server.max-http-header-size属性配置不当的严重后果)

一、背景 最近有一次在系统并发比较高的时候&#xff0c;数据库突然发生了故障&#xff0c;导致大量请求失败&#xff0c;在数据库宕机不久&#xff0c;通过应用日志可以看到系统发生了OOM。 二、排查 初次看到这个现象的时候&#xff0c;我还是有点懵逼的&#xff0c;数据库…

Qt : 禁用控件默认的鼠标滚轮事件

最近在写一个模拟器&#xff0c;在item中添加了很多的控件&#xff0c;这些控件默认是支持鼠标滚动事件的。在数据量特别大的时候&#xff0c;及容易不小心就把数据给修改了而不自知。所有&#xff0c;我们这里需要禁用掉这些控件的鼠标滚轮事件。 实现的思想很简单&#xff0c…

OceanBase单机版安装体验

前情提要 上周OceanBase开发者大会过后&#xff0c;作为观察员也来体验一下OB的安装。业内有某个国产安装用了两周&#xff0c;这种其实有点劝退了。话说就是10年前&#xff0c;没搞过Oracle的人也不用两周安装一个数据库啊。今天看看OB的&#xff08;一体化&#xff09;安装。…