[opencv教程(十二)]图像梯度
Sobel,Scharr,Laplacian算子解析和对比
·
预备知识
梯度
梯度方向是该点方向上变化最快的方向,沿着梯度方向可以找到最大值
整理后得到
矩阵卷积
- 将滤波器翻转180度。
- 将翻转后的滤波器与图像重叠。
- 计算重叠区域中滤波器和图像对应元素的乘积之和。
- 将计算结果存储在输出图像中与滤波器中心对应的位置。
- 将滤波器沿着图像移动,重复步骤2-4,直到覆盖整个图像。
具体例子 可以查看这一篇原来卷积是这么计算的 - 知乎 (zhihu.com)
简介
图像梯度是指图像中每个像素点的灰度值与其周围像素点灰度值之间的变化率。它可以用来检测图像中的边缘和纹理信息。
注意
图像梯度和形态学梯度是两个概念。形态学梯度是膨胀-腐蚀所得到的差,而图像梯度是点与周围灰度值的变化,图像梯度是x和y方向上的偏导得到的
Sobel算子
sobel滤波矩阵 当内核为3时
函数解析
cv2.Sobel(src,ddepth,dx,dy,ksize)
- ddepth:图像深度
- dx,dy:水平和竖直方向
- ksize:内核大小
图片

案例
lenaGary = cv2.imread('Picture/Lena.png',cv2.IMREAD_GRAYSCALE)
#cv2.CV_64F,因为在计算梯度的时候会涉及到负值,
#如果单纯设置为-1
#则会把负值改为0,显然是不符合梯度要求的,
#所以一般设置为cv2.cv_64f返回结果就可以是64位的一个数值,就是[-255, 255],
#这样如果出现负梯度,我们就把负梯度也保留了
sobelX = cv2.Sobel(lenaGary,cv2.CV_64F,1,0,ksize = 3)
sobelY = cv2.Sobel(lenaGary,cv2.CV_64F,0,1,ksize = 3)
#在Sobel中 白到黑为正数,黑到白为负数,负数会被截断为0
#导致边缘缺少,所以进行绝对值保留边缘信息
sobelX = cv2.convertScaleAbs(sobelX)
sobelY = cv2.convertScaleAbs(sobelY)
sobel = cv2.addWeighted(sobelX,0.5,sobelY,0.5,0)
cv2.imshow('Sobels',sobel)
cv2.waitKey(0)
cv2.destroyAllWindows()

注意
如果dx和dy都设置为1 有可能会出现重影 断链等现象
Scharr算子
简介
思想和Sobel算子相同 但是Sobel算子差异性的增强,对边缘更加敏感
因为思想相同,所以函数解析也是一样的
案例
#Scharr算子
lenaGary = cv2.imread('Picture/Lena.png',cv2.IMREAD_GRAYSCALE)
scharrX = cv2.Scharr(lenaGary,cv2.CV_64F,1,0,3)
scharrY = cv2.Scharr(lenaGary,cv2.CV_64F,0,1,3)
scharrX = cv2.convertScaleAbs(scharrX)
scharrY = cv2.convertScaleAbs(scharrY)
scharr = cv2.addWeighted(scharrX,0.5,scharrY,0.5,0)
cv2.imshow('Scharr',scharr)
cv2.waitKey(0)
cv2.destroyAllWindows()

Laplacian算子
简介
之前在讲空间域的线性滤波的时候就提到过了 laplacian滤波不是为了去噪,而是为了边缘检测,laplacian其实在边缘检测的时候也不是特别好,因为会受到 噪音的影响,一般是和其他工具搭着使用
案例
#Laplacian算子
lenaGary = cv2.imread('Picture/Lena.png',cv2.IMREAD_GRAYSCALE)
laplacian = cv2.Laplacian(lenaGary,cv2.CV_64F)
laplacian = cv2.convertScaleAbs(laplacian)
cv2.imshow('Laplacian',laplacian)
cv2.waitKey(0)
cv2.destroyAllWindows()

对比
plt.subplot(131),plt.imshow(sobel,'gray'),plt.title('Sobel'),plt.xticks([]),plt.yticks([])
plt.subplot(132),plt.imshow(scharr,'gray'),plt.title('Scharr'),plt.xticks([]),plt.yticks([])
plt.subplot(133),plt.imshow(laplacian,'gray'),plt.title('Laplacian'),plt.xticks([]),plt.yticks([])
plt.show()

更多推荐

所有评论(0)