[C++] opencv - HoughCircles(霍夫圆查找)函数介绍和使用场景

这篇具有很好参考价值的文章主要介绍了[C++] opencv - HoughCircles(霍夫圆查找)函数介绍和使用场景。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

HoughCircles函数

HoughCircles函数用于在灰度图像中使用霍夫变换查找圆。该函数通过修改霍夫变换来实现,通常可以很好地检测出圆的中心,但可能无法找到正确的半径。可以通过指定半径范围(minRadius和maxRadius)来协助该函数,或者在#HOUGH_GRADIENT方法中将maxRadius设置为负数以仅返回圆心而不进行半径搜索,并使用其他过程找到正确的半径。此外,还可以对图像进行一定程度的平滑处理,除非它已经很软。例如,可以使用7x7内核和1.5x1.5 sigma或类似的模糊处理来平滑图像。

函数原型:

CV_EXPORTS_W void HoughCircles(InputArray image, OutputArray circles, int method, double dp, double minDist, double param1 = 100, double param2 = 100, int minRadius = 0, int maxRadius = 0 );

参数说明:

image:输入图像,即源图像,8位单通道图像,如果使用彩色图像,需要先转换成灰度图像;

circles:用来存储HoughCircles的结果,类型为list,list中对象格式为x,y,r;
method:定义检测图像中圆的方法。目前唯一实现的方法是cv::HOUGH_GRADIENT;
dp:图像像素分辨率与参数空间分辨率的比值(官方文档上写的是图像分辨率与累加器分辨率的比值,它把参数空间认为是一个累加器,毕竟里面存储的都是经过的像素点的数量),dp=1,则参数空间与图像像素空间(分辨率)一样大,dp=2,参数空间的分辨率只有像素空间的一半大;#通过设置dp可以减少计算量
minDist:检测到的圆中心(x,y)坐标之间的最小距离。如果minDist太小,则会保留大部分圆心相近的圆。如果minDist太大,则会将圆心相近的圆进行合并(若两圆心距离 < minDist,则认为是同一个圆)。
param1:canny 边缘检测的高阈值,低阈值被自动置为高阈值的一半,默认为 100。;
param2:累加平面某点是否是圆心的判定阈值。大于该阈值才判断为圆。当值设置的很小是,检测到的圆越多。默认值为 100;
minRadius:半径的最小大小(以像素为单位)默认为 0;
maxRadius:半径的最大大小(以像素为单位)默认为 0。

使用场景

HoughCircles 是一种图像处理算法,用于检测图像中的圆。霍夫圆检测能检测出目标图像中存在的圆,但在实际使用中,参数调节存在很大的困难。

参数设置不合理会不仅导致计算量非常大,并且可能无法找不到你想保留的圆。

1)边缘噪声滤除

对图像进行 中值滤波 或者 均值滤波 或者 高斯滤波 优化,减少图像中存在的边缘噪声。

2)检测参数如何设定

a. 检索半径设定

通过观察原图初步确定的圆的像素半径范围(对应minRadius和maxRadius)。

b. 圆心累加值设定(对应参数param2)

因为累加圆心(圆弧上的在圆心上的累加值,累加值超过该阈值则被认为是一个圆)

c. 圆心距离设定(对应参数miniDist)

通过观察原图所有希望找出的圆,然后确定2个圆心之间最小的距离。

使用案例

#include <iostream>
#include <opencv2/opencv.hpp>

using namespace cv;
using namespace std;

int main()
{
    // 读取原始图像
    Mat src = imread("3480e7ce_mk_tk_a_c2_6400_4480.png", IMREAD_COLOR);
    if (src.empty())
    {
        cout << "无法读取图像" << endl;
        return -1;
    }

    // 转换为灰度图像
    Mat grayImage;
    cvtColor(src, grayImage, COLOR_BGR2GRAY);
    imshow("灰度图", grayImage);
    waitKey(0);

    // 使用滤波器去噪
    Mat blurImage;
    // GaussianBlur(grayImage, blurImage, Size(9, 9), 2, 2); // 高斯滤波
    // medianBlur(grayImage, blurImage, 7); // 中值滤波
    blur(grayImage, blurImage, Size(7,7)); // 均值滤波
    imshow("模糊滤波", blurImage);
    waitKey(0);

    // 使用 Canny 边缘检测
    Mat edgesImage;
    Canny(blurImage, edgesImage, 50, 100);
    imshow("边缘检测", edgesImage);
    waitKey(0);
    
    clock_t t1 = clock();
    // 使用 HoughCircles 检测圆
    vector<Vec3f> circles;
    // 设置Hough变换参数
    int minDist = 30;   // 最小距离
    int param1 = 100;     // Canny边缘检测高阈值  # 保持和和前面Canny的阈值一致
    int param2 = 15;     // Hough变换高阈值
    int minRadius = 10;   // 最小半径
    int maxRadius = 100;   // 最大半径
    HoughCircles(blurImage, circles, HOUGH_GRADIENT, 1, minDist,  param1, param2, minRadius, maxRadius);
    clock_t t2 = clock();
    // 在原图上绘制检测到的圆
    for (size_t i = 0; i < circles.size(); i++)
    {
        Point center(cvRound(circles[i][0]), cvRound(circles[i][1]));
        int radius = cvRound(circles[i][2]);
        circle(src, center, 3, Scalar(0, 255, 0), -1, 8, 0); // 绘制圆心
        circle(src, center, radius, Scalar(0, 0, 255), 3, 8, 0); //绘制空心圆
    }
    clock_t t3 = clock();
    double timeForHoughCircle = (double) (t2 - t1) / CLOCKS_PER_SEC * 1000;
	double timeForDrawCircle = (double) (t3 - t2) / CLOCKS_PER_SEC * 1000;
	cout << "HoughCircles:" << timeForHoughCircle << "ms, DrawCircle:" << timeForDrawCircle << "ms" <<endl;

    // 显示结果
    imshow("霍夫圆检测", src);
    waitKey(0);

    return 0;
}

灰度图:

[C++] opencv - HoughCircles(霍夫圆查找)函数介绍和使用场景,opencv,C++,c++,opencv 模糊滤波:

[C++] opencv - HoughCircles(霍夫圆查找)函数介绍和使用场景,opencv,C++,c++,opencv 边缘检测:

[C++] opencv - HoughCircles(霍夫圆查找)函数介绍和使用场景,opencv,C++,c++,opencv 

霍夫圆检测结果:

[C++] opencv - HoughCircles(霍夫圆查找)函数介绍和使用场景,opencv,C++,c++,opencv 

参考资料

opencv 十一 霍夫圆检测原理及高级使用案例(含优化步骤)

 文章来源地址https://www.toymoban.com/news/detail-774084.html

到了这里,关于[C++] opencv - HoughCircles(霍夫圆查找)函数介绍和使用场景的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • [C++] opencv - drawContours(绘制轮廓)函数介绍和使用场景

    OpenCV中的drawContours函数用于在图像上绘制轮廓。其函数原型如下: 比较复制插入新建 参数说明: image: 输出图像,即绘制轮廓后的图像。 contours: 轮廓集合,每个轮廓由一系列点组成。 contourIdx: 轮廓索引数组,指定要绘制哪些轮廓。如果为NULL,则绘制所有轮廓。 contourC

    2024年01月19日
    浏览(56)
  • [C++] opencv - Mat::convertTo函数介绍和使用场景

    Converts an array to another data type with optional scaling.    该函数主要用于数据类型的相互转换。 The method converts source pixel values to the target data type. saturate_cast is applied at the end to avoid possible overflows: m(x,y)=saturate_castrtype(α(∗this)(x,y)+β)    这是函数底层算法实现公式,了解算法方便我们

    2024年01月18日
    浏览(52)
  • [C++] opencv - approxPolyDP(多边形拟合)函数介绍和使用场景

    OpenCV中的 approxPolyDP() 函数用于对形状进行逼近,以减少多边形的顶点数,可以用于对图像轮廓点进行多边形拟合。 函数原型如下: 其中, curve 是输入的点集,类型为 InputArray, 可以是 Mat 、 vectorPoint 等; approxCurve是输出的点集,类型为 OutputArray, 也是 Mat 类型; epsilon 是精

    2024年03月14日
    浏览(70)
  • [C++] opencv - fillPoly(填充多边形)函数介绍和使用场景

    fillPoly() 函数是OpenCV中用于绘制填充多边形的函数。函数原型如下: fillPoly() 函数适用于需要绘制填充多边形的场景,例如在图像上绘制一个封闭的图形、制作一个简单的遮罩等。   fillPoly() 函数是OpenCV中用于绘制填充多边形的函数。可以用来绘制实心三角形,实心矩形,实

    2024年02月19日
    浏览(131)
  • 【OpenCV-Python】——边缘和轮廓&Laplacian/Sobel/Canny边缘检测&查找/绘制轮廓及轮廓特征&霍夫直线/圆变换

    目录 前言: 1、边缘检测 1.1 Laplacian边缘检测  1.2 Sobel边缘检测  1.3 Canny边缘检测 2、图像轮廓 2.1 查找轮廓  2.2 绘制轮廓 2.3 轮廓特征 3、霍夫变换 3.1 霍夫直线变换  3.2 霍夫圆变换 总结: 图像的边缘是指图像中灰度值急剧变化的位置,边缘检测的目的是为了绘制边缘线条。

    2024年01月23日
    浏览(48)
  • opencv 十一 霍夫圆检测原理及高级使用案例(含优化步骤)

    霍夫圆检测能检测出目标图像中存在的圆,但在实际使用中,参数调节存在很大的困难,故在本博文中对霍夫圆检测的原理、参数列表、优化经验进行分析总结。详细的列出了各个参数的调节依据,实现了在复杂背景下的霍夫圆检测。 相关知识: 霍夫圆检测与霍夫变换密切

    2024年02月04日
    浏览(66)
  • 基于Python OpenCV、使用霍夫变换的小车视觉循线识别

            近期在做一个小车视觉循线的项目。小车将沿着一条线行驶,并用自带的摄像头拍摄道路前方的道路,行驶过程会遇到钝角拐弯、弧线拐弯、直角拐弯这些特殊元素,小车需要在识别元素之后进行合理地转弯。         在网上看到大部分的循线方法主要是二值化

    2024年02月16日
    浏览(48)
  • Opencv中inRange函数使用介绍

    inRange是OpenCV中的图像阈值函数,用于将图像中的像素值限制在指定的范围内。它的输入和输出如下所述: 输入值: src:输入图像,可以是灰度图像或彩色图像。 lowerb:表示下界的阈值,可以是一个标量值或与输入图像通道数相同的数组。对于灰度图像,lowerb是一个标量值。

    2024年02月05日
    浏览(48)
  • [C++] opencv - copyTo函数介绍和使用案例

    copyTo 函数是OpenCV库中的一个成员函数,用于将一个Mat对象的内容复制到另一个Mat对象中。 函数原型: 参数说明: m: 输出数组,即目标Mat对象,用于存储源Mat对象的内容。 mask: 图像掩膜,用选定的图像作为遮挡,来控制图像处理的区域; 在这个例子中,我们首先读取了一张

    2024年01月18日
    浏览(41)
  • [C++] opencv - resize函数介绍和使用案例

    C++ OpenCV中的resize函数用于调整图像的大小。它可以根据指定的尺寸和插值方法对图像进行缩放。函数原型如下: 参数说明: src :输入图像,通常为 cv::Mat 类型。 dst :输出图像,与输入图像具有相同的类型。 size :目标图像的尺寸,表示为 (width, height) 。 fx :沿水平轴的缩放因子

    2024年04月11日
    浏览(39)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包