zoukankan      html  css  js  c++  java
  • OpenCV_Python —— (8)图像梯度

    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 )} ]

    [ heta=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()
    

    在这里插入图片描述

  • 相关阅读:
    Lua之math
    Lua之table
    Unity shader学习之轮廓效果
    c#之根据出生日期获得星座信息
    unity之复制文本到剪贴板
    Unity shader学习之屏幕后期处理效果之运动模糊
    Unity之如何从fbx提取Animation clip文件
    c#如何判断字符串是否含中文
    c#之如何转换文本文件编码格式为utf-8
    《Photon》
  • 原文地址:https://www.cnblogs.com/long5683/p/13164524.html
Copyright © 2011-2022 走看看