Canny边缘检测
Posted 小龙呀
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Canny边缘检测相关的知识,希望对你有一定的参考价值。
总体步骤:
1) 使用高斯滤波器,以平滑图像,滤除噪声。
2) 计算图像中每个像素点的梯度强度和方向。
3) 应用非极大值(Non-Maximum Suppression)抑制,以消除边缘检测带来的杂散响应。
4) 应用双阈值(Double-Threshold)检测来确定真实的和潜在的边缘。
5) 通过抑制孤立的弱边缘最终完成边缘检测。
1:高斯滤波器
2:梯度和方向
3:非极大值抑制
4:双阈值检测
代码实现:
import cv2
import numpy as np
img = cv2.imread("XTU.jpg",cv2.IMREAD_GRAYSCALE)
v1 = cv2.Canny(img,120,250) #120,250分别为minVal,maxVal
v2 = cv2.Canny(img,50,100)
def cv_show(name,img):
cv2.imshow(name,img) #第一个参数表示窗口名称
cv2.waitKey(0) #等待时间,毫秒,0表示任意键终止
cv2.destroyAllWindows()
res = np.hstack((v1,v2))
cv_show('res',res)
本文为学习笔记:b站网课链接
如有错误或者不足之处,欢迎大家留言指正!
以上是关于Canny边缘检测的主要内容,如果未能解决你的问题,请参考以下文章