opencv 把3通道图像转成单通道_【3】OpenCV图像处理模块(13)Sobel边缘检测

dbb6f5d071c70e9f67cdedec75a23015.png

本节内容是Sobel边缘检测,用OpenCV的Sobel()函数来计算图像的一阶导数。另外,OpenCV还提供了一种更精确的计算方法,Scharr()函数,计算时核大小为3*3。


理论

前面的例子,已经接触到了图像卷积运算。最终要的卷积运算之一是用于计算图像的导数(或近似导数)。为什么图像中导数的计算很重要,看下面边缘检测的例子。

6ec2b665ff71d3822c8c9e77e03d3529.png

很容易观察到上面图像中像素灰度值变化没有规律。一种比较好的描述这种变化的方法是采用导数。其中梯度剧烈变化的地方代表图像灰度值变化强烈的地方,也就是边缘。

为了更好的说明,以1维图像(也就是图像的1行)为例。边缘出现在灰度值跳变的地方,如下图所示。

c53ed1b2bc300b228ed95081699e17ac.png

如果对上面的1维图像求导数,得到下图,可以很明显的看到边缘所在的位置。

d1c8198b515085a3aebc804cc96a37f0.png

从上面的解释,我们可以设置一个阈值,根据局部像素变化强烈程度获取图像边缘。

Sobel 算子

sobel算子是一个离散微分算子,计算得到的是图像梯度的近似值。sobel算子结合了高斯平滑和微分。

公式

假设输入图像是I,,核大小为3,通过下面运算分别计算水平方向和垂直方向的微分:

  • a.水平方向

  • b.垂直方向

结合上面结果可以计算出图像中一个点的近似梯度

或者表示为

需要注意的是,当核的大小为3时,也就是上面所示的Sobel核可能会产生明显的误差(毕竟Sobel只是微分的近似值)。Scharr() 函数提供了比标准Sobel函数更精确的计算结果。它使用了下面的核

代码

// @tutorials imgproc module 13

结果

可以看到X方向检测图像中垂直方向边缘,Y方向检测图像中水平方向边缘。

a4f243fdcc951d5810a65a53978996f8.png
X方向、Y方向、合成
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值