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.mzph.cn/diannao/3528.shtml

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

相关文章

Cgicc搭建交叉编译环境(移植到arm)

Cgicc GUN Project官网连接&#xff1a;Cgicc- GNU Project - Free Software Foundation 1. 下载源码 Cgicc下载地址&#xff1a; [via http] Index of /gnu/cgicc [via FTP] ftp://ftp.gnu.org/gnu/cgicc/ 目前最新版&#xff1a;3.2.20 2. 源码构建原理 一般&#xff…

在VSCode中调试其他软件执行的python文件

在VSCode中调试其他软件执行的python文件 0. 实际场景 我有一段python代码想在Metashape中运行&#xff0c;但是又想在中间某一步停下来查看变量值。由于Metashape的python环境不容易在vscode中配置&#xff0c;所以直接用vscode调试单个文件的方式无法实现这个想法。还好&am…

42. UE5 RPG 实现火球术伤害

上一篇&#xff0c;我们解决了火球术于物体碰撞的问题&#xff0c;现在火球术能够正确的和攻击目标产生碰撞。接下来&#xff0c;我们要实现火球术的伤害功能&#xff0c;在火球术击中目标后&#xff0c;给目标造成伤害。 实现伤害功能的思路是给技能一个GameplayEffect&#x…

3DTiles生产流程与规范

一篇19年整理的比较老的笔记了。更多精彩内容尽在数字孪生平台。 瓦片切分 标准的四叉树切分对于均匀分布的地理数据切片非常有效&#xff0c;但是这样均等的切分不适用于随机分布、不均匀分布的地理数据&#xff0c;当地理数据稀疏分布的时候&#xff0c;均等的四叉树就不再高…

跟着Datawhale重学数据结构与算法(3)---排序算法

开源链接&#xff1a;【 教程地址 】【电子网站】 【写博客的目的是记录自己学习过程&#xff0c;方便自己复盘&#xff0c;专业课复习】 数组排序&#xff1a; #mermaid-svg-F3iLcKsVv8gcmqqC {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16p…

jenkins自动化工具简介

Jenkins 是一个开源的自动化服务器&#xff0c;它允许您自动化各种任务&#xff0c;包括构建、测试和部署软件。它是一个用Java编写的应用程序&#xff0c;可以运行在任何支持Java的平台上。Jenkins 通过其插件系统提供了大量的功能&#xff0c;使其成为一个非常灵活和强大的工…

PHP项目搭建与启动

1、拉取项目 2、安装phpstudy 下载地址&#xff1a; Windows版phpstudy下载 - 小皮面板(phpstudy) (xp.cn) 软件安装&#xff1a; Apache2.4.39、Nginx1.15.11、MySQL8.0.12、 composer2.5.8 添加伪静态 将下面代码写入到伪静态配置文本域框内&#xff1a; location ~* (ru…

redis模糊查询redis中的key

redis模糊查询redis中的key 方式一&#xff1a;使用keys命令 /*** 查找匹配的key** param pattern* return*/ public Set<String> keys(String pattern) {return redisTemplate.keys(pattern); }方式二&#xff1a;使用san命令 /*** 查找匹配的key** param pattern* r…

【Qt 学习笔记】Qt常用控件 | 输入类控件 | Text Edit的使用及说明

博客主页&#xff1a;Duck Bro 博客主页系列专栏&#xff1a;Qt 专栏关注博主&#xff0c;后期持续更新系列文章如果有错误感谢请大家批评指出&#xff0c;及时修改感谢大家点赞&#x1f44d;收藏⭐评论✍ Qt常用控件 | 输入类控件 | Text Edit的使用及说明 文章编号&#xff…

VScode使用cmake编译

一&#xff1a;输入 ctrlshiftp打开用于命令执行的输入框 二&#xff1a;输入cmake&#xff0c;选择quick start 模式 三&#xff1a;选择版本最高的gcc版本 四&#xff1a;输入项目名称 选择C 五&#xff1a;选择executable 这样便创建好了最简单的cmake例程&#xff0c;一个…

使用MySQL和SQL Server生成最近七天的日期

在数据处理和报表生成过程中&#xff0c;经常需要生成最近一段时间内的数据。本文将介绍如何在MySQL和SQL Server数据库中使用SQL编写代码来生成最近七天的日期数据。 MySQL示例 在MySQL中&#xff0c;可以使用日期函数和临时表来生成最近七天的日期。以下是一个示例代码&…

企业微信代开发应用登录操作

首先声明&#xff1a;企微的文档写得真烂&#xff01;&#xff01;&#xff01;有一些问题&#xff0c;官方情愿在问答区给用户一个个解答&#xff0c;也不愿意在文档写清楚&#xff0c;生怕自己工作量不饱和被优化。 概念说明 代开发应用&#xff0c;是相对于自建应用来说的。…

【后端学习笔记·Golang】邮箱邮件验证

文章目录 邮箱登陆验证生成随机验证码向用户邮箱发送验证码接口获取验证码校验验证码 邮箱登陆验证 流程&#xff1a; 接收用户请求后生成随机验证码&#xff0c;并将验证码存入Redis中&#xff0c;并设置TTL 通过gomail发送验证码给用户邮箱 接收用户输入的验证码&#xff…

[Swift]组件化开发

一、组件化开发基础 1.组件定义 在软件开发中&#xff0c;一个组件是指一个独立的、可替换的软件单元&#xff0c;它封装了一组相关的功能。组件通过定义的接口与外界交互&#xff0c;并且这些接口隔离了组件内部的实现细节。在Swift语言中&#xff0c;组件可以是一个模块、一…

CVaR模型

CVaR模型&#xff08;Conditional Value at Risk&#xff09;是一种风险管理工具&#xff0c;用于衡量金融资产或投资组合在不同市场条件下的风险。CVaR模型衡量的是在某个置信水平下&#xff08;通常是95%或99%&#xff09;资产或投资组合在损失情况下的平均损失。与VaR&#…

车企如何利用数据技术,指导汽车全生命周期的业务运营?

引言&#xff1a;数据正作为重点&#xff0c;为行业提供不可或缺的指导 《汽车数据发展研究报告&#xff08;2023&#xff09;》指出&#xff0c;汽车行业正由传统硬件制造向“电动化、智能化、网联化”方向转变。德勤预测&#xff0c;到 2025 年&#xff0c;汽车行业 20%的利…

K8s: 部署 kubernetes dashboard

部署 Dashboard K8s 官方有一个项目叫 dashboard&#xff0c;通过这个项目更方便监控集群的状态 官方地址: https://github.com/kubernetes/dashboard 通常我们通过命令行 $ kubectl get po -n kube-system 能够查看到集群所有的组件&#xff0c;但这样的方式比较不太直观 …

【JavaScript】内置对象 ③ ( Math 内置对象 | Math 内置对象简介 | Math 内置对象的使用 )

文章目录 一、Math 内置对象1、Math 内置对象简介2、Math 内置对象的使用 二、代码示例1、代码示例 - Math 内置对象的使用2、代码示例 - 封装 Math 内置对象 一、Math 内置对象 1、Math 内置对象简介 JavaScript 中的 Math 内置对象 是一个 全局对象 , 该对象 提供了 常用的 数…

通过 QEMU 试用 ESP32-C3 的安全功能

概述 ESP32-C3 系列芯片支持可信启动、flash 加密、安全存储等多种安全功能&#xff0c;还有专用外设来支持 HMAC 和数字签名等用例。这些功能所需的私钥和配置大多存储在 ESP32-C3 的 eFuse 存储器中。 启用安全功能时需要谨慎&#xff0c;因为使用到的 eFuse 存储器是一次…

安卓studio插件开发(一)本地搭建工程

下载idea 社区版本 建立IDE Plugin工程 点击create就行&#xff0c;新建立的工程长这样 比较重要的文件 build.gradle&#xff1a;配置工程的参数 plugin.xml&#xff1a;设置插件的Action位置 build.gradle.kts内容如下&#xff1a; plugins {id("java")id(&quo…