Canny 是一种常用的边缘检测算法. 其是在 1986 年 John F.Canny 提出的.
Canny 是一种 multi-stage 算法,分别如下:
具体流程:
高斯滤波最重要的还是卷积核核,通常使用高斯平滑滤波器卷积降噪,这里以size=3的高斯内核为例:这里做了归一化处理(元素和为 1)
高斯去噪其实就是一个低通滤波器,滤除高频噪声。
计算方法:
这里 是指水平方向的掩码模板,是指垂直方向的掩码模板。根据上面的模板可以计算出图像梯度幅值和方向。
非极大值抑制是进行边缘检测的重要步骤,通俗的来说,就是获取局部的最大值,将非极大值所对应的灰度值设置为背景像素点。像素邻近区域满足梯度值的局部最优值判断为该像素的边缘,对非极大值相关信息进行抑制。利用这个准则可以剔除大部分的非边缘点。
简单的说呢?就是保留梯度大的像素点点,对于那些在边缘旁边的杂散点,梯度相对较小,利用非极大值抑制就可以很好的去除杂散点。
这里的双阈值并不是说介于阈值之间的像素保留,外面的的去除。这里的阈值检测有所不同。
分析:
根据上面的分析,我们可以得出来:A, D点位边界; B, C点不是边界。
注意:
具体这两个值怎么设置,我们就要分析两个值变化对图像的影响。
下面以 video = cv2.Canny(img, 80, 250) 为例:分别增大minVal和maxVal。
增大minVal: (边界出现缺损)
增大maxVal: (边界出现成片消失,边界信息完整)
总结:
在实际应用中,观察梯度图像,如果边界信息缺损,那么适当的减小minVal;如果有不想要的区域出现,那么适当的增加MaxVal。
OpenCV 提供了 cv2.canny() 函数.
edge = cv2.Canny(image, threshold1, threshold2[, edges[, apertureSize[, L2gradient ]]])
具体代码:
import cv2 import numpy as np import matplotlib.pyplot as plt img = cv2.imread('test.jpg', 0) edges = cv2.Canny(img, 100, 200) plt.subplot(121), plt.imshow(img, cmap='gray') plt.title('Original Image'), plt.xticks([]), plt.yticks([]) plt.subplot(122),plt.imshow(edges,cmap = 'gray') plt.title('Edge Image'), plt.xticks([]), plt.yticks([]) plt.show()
带 minVal 和 maxVal 滑动条的使用:
import numpy as np import cv2 def nothing(x): pass img=cv2.imread('test.jpg',0) cv2.namedWindow('res') cv2.createTrackbar('min','res',0,25,nothing) cv2.createTrackbar('max','res',0,25,nothing) while(1): if cv2.waitKey(1) & 0xFF == 27: break maxVal=cv2.getTrackbarPos('max','res') minVal=cv2.getTrackbarPos('min','res') canny=cv2.Canny(img,10*minVal,10*maxVal) cv2.imshow('res',canny) cv2.destroyAllWindows()
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
长按识别二维码并关注微信
更方便到期提醒、手机管理