首页 > 编程语言 > 详细

OpenCV_Python —— (8)图像梯度

时间:2020-06-19 19:59:57      阅读:74      评论:0      收藏:0      [点我收藏+]

I是图像像素的值(如:RGB值)
一阶导数:
x的梯度:Gx = I(x+1,y)-I(x,y)
y的梯度:Gy = I(x,y+1)-I(x,y)

二阶导数:
x的梯度:I(x+1,y)+I(x-1,y)-2I(x,y)
y的梯度:I(x,y+1)+I(x,y-1)-2I(x,y)
OpenCV 提供了三种不同的梯度滤波器,或者说高通滤波器: Sobel,Scharr 和 Laplacian。Sobel, Scharr 其实就是求一阶或二阶导数。 Scharr 是对 Sobel的优化。Laplacian 是求二阶导数。
梯度大小和方向的公式为:

\[G=\sqrt{(G_x^2+G_y^2 )} \]

\[\theta=tan^{-1}(\frac{G_x}{G_y}) \]

梯度的方向一般总是与边界垂直。梯度方向被归为四类:垂直,水平,和两个对角线。
技术分享图片

Sobel算子和Scharr算子:

Sobel 算子是高斯平滑与微分操作的结合体,所以它的抗噪声能力很好。你可以设定求导的方向(xorder 或 yorder)。还可以设定使用的卷积核的大小(ksize)。
技术分享图片

如果 ksize=-1,会使用 3x3 的 Scharr 滤波器,它的的效果要比 3x3 的 Sobel 滤波器好(而且速度相同,所以在使用 3x3 滤波器时应该尽量使用 Scharr 滤波器)。 3x3 的 Scharr 滤波器卷积核如下:
技术分享图片

Laplacian算子:

拉普拉斯算子使用的卷积核:
技术分享图片

技术分享图片

def gradient(image):
    image = cv2.cvtColor(image, cv2.COLOR_RGB2GRAY)
    # cv2.CV_64F输出图像的深度(数据类型),64位float类型,因为梯度可能是正也可能是负
    laplacian = cv2.Laplacian(image, cv2.CV_64F)
    # 1, 0表示在x方向求一阶导数,最大可以求2阶导数(把1,0改成2,0即可)
    sobelx = cv2.Sobel(image, cv2.CV_64F, 1, 0, ksize=3)
    # 0, 1表示在y方向求一阶导数,最大可以求2阶导数
    sobely = cv2.Sobel(image, cv2.CV_64F, 0, 1, ksize=3)
    titles = [‘Original‘, ‘Laplacian‘, ‘SobelX‘, ‘SobelY‘]
    images = [image,laplacian,sobelx,sobely]
    plt.figure(figsize=(10,5))
    for i in range(4):
        plt.subplot(2,2,i+1)
        plt.imshow(images[i],‘gray‘)
        plt.title(titles[i])
        plt.axis(‘off‘)
    plt.show()

技术分享图片

OpenCV_Python —— (8)图像梯度

原文:https://www.cnblogs.com/long5683/p/13164524.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!