详解利用python+opencv识别图片中的圆形(霍夫变换)
作者:智元元 时间:2023-12-07 18:17:50
在图片中识别足球
先补充下霍夫圆变换的几个参数知识:
dp,用来检测圆心的累加器图像的分辨率于输入图像之比的倒数,且此参数允许创建一个比输入图像分辨率低的累加器。上述文字不好理解的话,来看例子吧。例如,如果dp= 1时,累加器和输入图像具有相同的分辨率。如果dp=2,累加器便有输入图像一半那么大的宽度和高度。
minDist,为霍夫变换检测到的圆的圆心之间的最小距离,即让我们的算法能明显区分的两个不同圆之间的最小距离。这个参数如果太小的话,多个相邻的圆可能被错误地检测成了一个重合的圆。反之,这个参数设置太大的话,某些圆就不能被检测出来了。
param1,有默认值100。它是method设置的检测方法的对应的参数。对当前唯一的方法霍夫梯度法,它表示传递给canny边缘检测算子的高阈值,而低阈值为高阈值的一半。
param2,也有默认值100。它是method设置的检测方法的对应的参数。对当前唯一的方法霍夫梯度法,它表示在检测阶段圆心的累加器阈值。它越小的话,就可以检测到更多根本不存在的圆,而它越大的话,能通过检测的圆就更加接近完美的圆形了。
minRadius,默认值0,表示圆半径的最小值。
maxRadius,也有默认值0,表示圆半径的最大值。
源代码:
# -*- coding: utf-8 -*-
"""
Created on Tue Sep 26 23:15:39 2017
@author: tina
"""
import cv2
import numpy as np
import matplotlib.pyplot as plt
img = cv2.imread('C:\\Users\\tina\\Pictures\\ahh\\ball.jpg')
gray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)
plt.subplot(121),plt.imshow(gray,'gray')
plt.xticks([]),plt.yticks([])
circles1 = cv2.HoughCircles(gray,cv2.HOUGH_GRADIENT,1,
600,param1=100,param2=30,minRadius=80,maxRadius=97)
circles = circles1[0,:,:]
circles = np.uint16(np.around(circles))
for i in circles[:]:
cv2.circle(img,(i[0],i[1]),i[2],(255,0,0),5)
cv2.circle(img,(i[0],i[1]),2,(255,0,255),10)
cv2.rectangle(img,(i[0]-i[2],i[1]+i[2]),(i[0]+i[2],i[1]-i[2]),(255,255,0),5)
print("圆心坐标",i[0],i[1])
plt.subplot(122),plt.imshow(img)
plt.xticks([]),plt.yticks([])
原图:
识别后效果:
来源:https://blog.csdn.net/qq_41352018/article/details/79939775
标签:python,opencv,识别圆形,霍夫变换
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
python解析html开发库pyquery使用方法
2021-08-28 18:18:57
如何从ASP连接到Oracle Server?
2009-11-15 19:52:00
浅说相册图片详情页面中大图的浏览方式
2009-02-01 18:34:00
![](https://img.aspxhome.com/file/UploadPic/20092/1/12-79.jpg)
手把手教你用python绘制热度图(heatmap)
2023-07-01 21:03:03
![](https://img.aspxhome.com/file/2023/6/131636_0s.png)
python接口调用已训练好的caffe模型测试分类方法
2021-08-11 18:31:04
![](https://img.aspxhome.com/file/2023/7/70107_0s.jpg)
Python中win32com模块的使用
2021-01-22 11:46:52
Mysql主从延时图解方法
2024-01-24 04:26:29
![](https://img.aspxhome.com/file/2023/8/126308_0s.png)
判断浏览器是否接受 Cookie
2009-07-28 17:52:00
Python实现文件信息进行合并实例代码
2021-04-12 01:50:33
![](https://img.aspxhome.com/file/2023/2/112142_0s.png)
Python集合的增删改查操作
2023-09-30 00:48:18
详解Go-JWT-RESTful身份认证教程
2024-02-17 07:44:56
![](https://img.aspxhome.com/file/2023/2/105112_0s.jpg)
详解Golang中select的使用与源码分析
2024-05-09 14:52:08
![](https://img.aspxhome.com/file/2023/8/127388_0s.png)
详解Python GUI工具取色器
2021-01-23 10:12:04
![](https://img.aspxhome.com/file/2023/4/87764_0s.gif)
CNN卷积函数Conv2D()各参数的含义及用法解读
2022-03-12 05:35:21
![](https://img.aspxhome.com/file/2023/4/76954_0s.png)
vue 巧用过渡效果(小结)
2024-04-10 10:33:28
![](https://img.aspxhome.com/file/2023/2/139762_0s.png)
MySQL之批量插入的4种方案总结
2024-01-19 16:13:11
![](https://img.aspxhome.com/file/2023/2/109802_0s.png)
Python网页解析利器BeautifulSoup安装使用介绍
2021-06-12 05:00:00
![](https://img.aspxhome.com/file/2023/0/92090_0s.png)
Pytorch神经网络参数管理方法详细讲解
2023-04-04 14:07:26
两种oracle创建字段自增长的实现方式
2024-01-15 09:47:44
Python读取指定日期邮件的实例
2023-05-28 17:20:01