从零开始详解OpenCV硬币检测

从零开始详解OpenCV硬币检测

码农世界 2024-05-23 后端 60 次浏览 0个评论

前言

在上一篇中我们介绍了车道线检测,在本篇中我们将使用类似的做法来实现对应硬币的检测。

从零开始详解OpenCV硬币检测

详解

打开并转换成灰度图

img = cv2.imread('coin.png')
gray_image = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
plt.imshow(img)

从零开始详解OpenCV硬币检测

二值化

thresh, output = cv2.threshold(gray_image, 80, 255, cv2.THRESH_BINARY)
output = cv2.GaussianBlur(output, (9, 9), 2)
plt.imshow(output, cmap=plt.cm.gray)

从零开始详解OpenCV硬币检测

边缘检测

output = cv2.Canny(output, 200, 255)
plt.imshow(output, cmap='gray')

从零开始详解OpenCV硬币检测

霍夫变换

在之前的文章中我们使用霍夫变换获取到了直线,而这次我们需要的是圆形。

cv2.HoughCircles 是 OpenCV 库中的一个函数,用于在图像中检测圆形。这个函数基于霍夫变换(Hough Transform)的原理,在灰度图像中检测圆形物体。

circles = cv2.HoughCircles(output, cv2.HOUGH_GRADIENT, 1, 50, param1=100, param2=30, minRadius=25)
circles = np.uint16(np.around(circles))
for i in circles[0, :]:
    cv2.circle(img, (i[0], i[1]), i[2], (0, 255, 0), 2)
    cv2.circle(img, (i[0], i[1]), 2, (0, 0, 255), 3)
plt.imshow(img)

从零开始详解OpenCV硬币检测

语法:
	cv2.HoughCircles(image, method, dp, minDist[, circles[, param1[, param2[, minRadius[, maxRadius]]]]]) -> circles
参数:
	image:输入的单通道灰度图像,函数将在该图像中进行圆检测。
	method:定义检测图像中圆的方法。默认是cv2.HOUGH_GRADIENT
	dp:图像分辨率与累加器分辨率的比值。这个值可以理解为累加器分辨率与图像分辨率的反比。
		例如,如果 dp=1,则累加器与图像具有相同的分辨率。
		如果 dp=2,累加器分辨率是图像分辨率的一半。
	minDist:检测到的圆的中心之间的最小距离。
		如果 minDist 太小,可能会导致检测到多个相邻的圆。
		如果 minDist 太大,则可能会漏掉一些圆。
	param1:Canny 边缘检测的高阈值。
		Canny 边缘检测是 cv2.HoughCircles 函数中用于寻找边缘的一个步骤。
	param2:累加器阈值。这个阈值用于判断一个圆是否应该被检测出来。
		值越小,检测出的圆越多,但可能会包括一些假圆。
	minRadius:需要检测的最小圆半径。
	maxRadius:需要检测的最大圆半径。
返回值:
	circles 是一个 NumPy 数组,包含检测到的圆的圆心坐标 (x, y) 和半径 r。
		数组的形状为 (n, 3),其中 n 是检测到的圆的数量。

转载请注明来自码农世界,本文标题:《从零开始详解OpenCV硬币检测》

百度分享代码,如果开启HTTPS请参考李洋个人博客
每一天,每一秒,你所做的决定都会改变你的人生!

发表评论

快捷回复:

评论列表 (暂无评论,60人围观)参与讨论

还没有评论,来说两句吧...

Top