opencv基础43- 图像梯度-Laplacian 算子( cv2.Laplacian)边缘检测基础

63 篇文章 16 订阅
62 篇文章 53 订阅

Laplacian算子是一种图像处理中常用的边缘检测算子,它用于检测图像中的边缘和轮廓。该算子计算图像中每个像素点的二阶导数,从而突出图像中灰度值变化较大的区域,这些区域通常对应图像的边缘或者轮廓。

Laplacian(拉普拉斯)算子是一种二阶导数算子,其具有旋转不变性,可以满足不同方向
的图像边缘锐化(边缘检测)的要求。通常情况下,其算子的系数之和需要为零。

Laplacian算子的一种常用形式是二维离散Laplacian算子,表示为:

  0   1   0
  1  -4   1
  0   1   0

该算子是一个3x3的矩阵,它对应的是图像中每个像素点的上、下、左、右四个方向的像素值以及像素点本身的像素值之间的差值。

应用Laplacian算子的过程如下:

  • 将3x3的Laplacian算子依次对图像中的每个像素点进行卷积操作。
  • 将卷积结果作为图像的每个像素点的新像素值。
  • 对于卷积结果,如果像素值较大,则表示该像素点周围灰度值变化较大,可能是图像中的边缘或轮廓。

Laplacian 算子类似二阶 Sobel 导数,需要计算两个方向的梯度值。例如,在图 9-25 中:

  • 左图是 Laplacian 算子。
  • 右图是一个简单图像,其中有 9 个像素点。

在这里插入图片描述

计算像素点 P5 的近似导数值,如下:

P5lap = (P2 + P4 + P6 + P8) - 4·P5

图 9-26 展示了像素点与周围点的一些实例,其中:

  • 在左图中,像素点 P5 与周围像素点的值相差较小,得到的计算结果值较小,边缘不明显。
  • 在中间的图中,像素点 P5 与周围像素点的值相差较大,得到的计算结果值较大,边缘较明显。
  • 在右图中,像素点 P5 与周围像素点的值相差较大,得到的计算结果值较大,边缘较明显。

在这里插入图片描述
需要注意,在上述图像中,计算结果的值可能为正数,也可能为负数。所以,需要对计算结果取绝对值,以保证后续运算和显示都是正确的。

在 OpenCV 内使用函数 cv2.Laplacian()实现 Laplacian 算子的计算,该函数的语法格式为:

dst = cv2.Laplacian( src, ddepth[, ksize[, scale[, delta[, borderType]]]] )

式中:

  • dst 代表目标图像。
  • src 代表原始图像。
  • ddepth 代表目标图像的深度。
  • ksize 代表用于计算二阶导数的核尺寸大小。该值必须是正的奇数。
  • scale 代表计算 Laplacian 值的缩放比例因子,该参数是可选的。默认情况下,该值为 1,表示不进行缩放。
  • delta 代表加到目标图像上的可选值,默认为 0。
  • borderType 代表边界样式。

该函数分别对 x、y 方向进行二次求导,具体为:

在这里插入图片描述

上式是当 ksize 的值大于 1 时的情况。当 ksize 的值为 1 时,Laplacian 算子计算时采用的 3×3的核如下:

在这里插入图片描述
通过从图像内减去它的 Laplacian 图像,可以增强图像的对比度,此时其算子如图 9-27 所示。

在这里插入图片描述

代码示例:

使用函数 cv2.Laplacian()计算图像的边缘信息。

import cv2
o = cv2.imread('Laplacian.bmp',cv2.IMREAD_GRAYSCALE)
Laplacian = cv2.Laplacian(o,cv2.CV_64F)
Laplacian = cv2.convertScaleAbs(Laplacian)
cv2.imshow("original",o)
cv2.imshow("Laplacian",Laplacian)
cv2.waitKey()
cv2.destroyAllWindows()

运行结果:

在这里插入图片描述
左图为原始图像,右图为得到的边缘信息。

算子总结

Sobel 算子、Scharr 算子、Laplacian 算子都可以用作边缘检测,它们的核如图 9-29 所示。

在这里插入图片描述

Sobel 算子和 Scharr 算子计算的都是一阶近似导数的值。通常情况下,可以将它们表示为:

Sobel 算子= |左-右| / |下-上|
Scharr 算子= |左-右| / |下-上|

式中“|左-右|”表示左侧像素值减右侧像素值的结果的绝对值,“|下-上|”表示下方像素值减上方像素值的结果的绝对值。像素值的结果的绝对值。
Laplacian 算子计算的是二阶近似导数值,可以将它表示为:

Laplacian 算子= |左-右| + |左-右| + |下-上| + |下-上|

通过公式可以发现,Sobel 算子和 Scharr 算子各计算了一次“|左-右|”和“|下-上|”的值,而 Laplacian 算子分别计算了两次“|左-右|”和“|下-上|”的值。

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
好的,下面我来给出Sobel算子、Canny算子Laplacian算子等常见边缘检测算子的具体方程式: 1. Sobel算子:Sobel算子使用3x3的卷积核对图像进行卷积,可以检测图像中水平和垂直方向的边缘。Sobel算子的具体方程式如下: ![Sobel](https://latex.codecogs.com/svg.latex?G_%7Bx%7D%20%3D%20%5Cbegin%7Bbmatrix%7D%20-1%20%26%200%20%26%201%5C%5C%20-2%20%26%200%20%26%202%5C%5C%20-1%20%26%200%20%26%201%20%5Cend%7Bbmatrix%7D%20%2C%20%20G_%7By%7D%20%3D%20%5Cbegin%7Bbmatrix%7D%20-1%20%26%20-2%20%26%20-1%5C%5C%200%20%26%200%20%26%200%5C%5C%201%20%26%202%20%26%201%20%5Cend%7Bbmatrix%7D) 其中,Gx和Gy分别表示水平和垂直方向的Sobel算子。 2. Canny算子:Canny算子是一种广泛使用的边缘检测算子,它可以检测图像中的高质量边缘,并抑制噪声。Canny算子的具体方程式如下: - 使用高斯滤波器对图像进行平滑处理,以去除噪声; - 对平滑后的图像计算梯度,以检测边缘的强度和方向; -梯度进行非极大值抑制,以保留边缘的细节; - 使用双阈值算法对边缘进行二值化,以输出检测到的边缘。 3. Laplacian算子Laplacian算子也是一种常用的边缘检测算子,它可以检测图像中的所有边缘,包括弱边缘和噪声。Laplacian算子的具体方程式如下: ![Laplacian](https://latex.codecogs.com/svg.latex?%5Cbegin%7Bbmatrix%7D%200%20%26%201%20%26%200%5C%5C%201%20%26%20-4%20%26%201%5C%5C%200%20%26%201%20%26%200%20%5Cend%7Bbmatrix%7D) 其中,矩阵中心的-4表示当前像素点的权重,周围8个像素点的权重为1,用于检测图像中的边缘。 需要注意的是,以上算子的具体实现需要使用卷积运算和图像处理技术,可以使用现有的计算机视觉库(如OpenCV、Scikit-image等)进行实现。在使用时,还需要根据具体应用场景和需求,选择合适的算子和参数,以达到更好的边缘检测效果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小海聊智造

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值