Sobel算子的解释

本来不想写这个博客的,但是看见很多篇介绍sobel算子的博客都没有把本质解释出来,所以我想尝试写一些把。

soble算子我们都知道的是:

              它对X方向求导的卷积核为:

-101
-202
-101

可是为什么是这样的呢?

        原因如下:

                我们知道,图像求到是用差分近似的。

                        如:f(x,y) - f(x-1,y)

                                f(x+1,y)-f(x,y)

                                f(x+1,y) - f(x-1,y)

                sobel 算子采用的第三种 f(x+1,y) - f(x-1,y)。

                也就是:

-101

那它现在还是和一开始那个算子不一样啊,接着看:

                我们一开始并不知道图像到底是不是平滑的,有没有噪声。如果不是平滑的,那么我们在求导时,得到的结果将非常差。所以我们要提前给这个图像进行滤波后再进行求导。

                即:                ​​​​​​​        ​​​​​​​        ​​​​​​​        ​​​​​​​        ​​​​​​​        \frac{d}{dx}(f cov g)

                其实本质上求导也是求卷积,这样操作不就要执行两边卷积吗,而且卷积是很浪费时间的操作。我们利用卷积的性质可以将上式变为:

                                                                                f cov (\frac{d}{dx}g)

这样我们就可以只对卷积核g求导让其成为另一种卷积核,之后只用这个卷积核与f进行卷积就可以了。

             实际上:

                        求导为:

-101

                        g为(对x方向进行高斯滤波):

1
2
1

        这两个乘起来不就是才开始那个算子吗?

我现在解释下为什么g是这个样子的。

我们看一个经典的高斯核:

121
242
121

它可以写为:

\begin{pmatrix} 1\\ 2\\ 1\\ \end{pmatrix}   *  \bigl(\begin{smallmatrix} 1 &2 &1 \end{smallmatrix}\bigr)   

其中\begin{pmatrix} 1\\ 2\\ 1\\ \end{pmatrix} 就是对x方向的高斯滤波,另一个是对y的。

不信可以试验一下:

\bigl(\begin{smallmatrix} 1 &2 &1 \\ 2&4 &2 \\ 1 &2 &1 \end{smallmatrix}\bigr) cov\bigl(\begin{smallmatrix} 2&3 &3 \\ 3& 5 &5 \\ 4& 4 &6 \end{smallmatrix}\bigr) =  65

\begin{pmatrix} 1\\ 2\\ 1\\ \end{pmatrix} cov\bigl(\begin{smallmatrix} 2&3 &3 \\ 3& 5 &5 \\ 4& 4 &6 \end{smallmatrix}\bigr) = \bigl(\begin{smallmatrix} 12 &17 &19 \end{smallmatrix}\bigr)

\bigl(\begin{smallmatrix} 1 &2 &1 \end{smallmatrix}\bigr) cov​​​​​​​\bigl(\begin{smallmatrix} 12 &17 &19 \end{smallmatrix}\bigr)=65

所以宗上:

sobel算子对x方向求导:

\begin{pmatrix} 1\\ 2\\ 1\\ \end{pmatrix} * \bigl(\begin{smallmatrix} -1 & 0 & 1 \end{smallmatrix}\bigr)  =  \begin{bmatrix} -1 & 0& 1\\ -2& 0 & 2\\ -1& 0& 1 \end{bmatrix}  

对y方向也一样算。

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

苹果香蕉柠檬c

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

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

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

打赏作者

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

抵扣说明:

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

余额充值