数字图像处理--微分算子为什么也是空间滤波器

前面我们提到,可以用一阶微分算子和二阶微分算子来增强图像,由于是增强了图像中的物体边缘轮廓,起到了锐化图像的效果,因此这些算子操作可用于图像锐化。

我们在前面的图像模糊中,介绍了使用平滑空间滤波器来模糊图像,那么用微分算子来锐化图像能不能也使用空间滤波器的形式呢?

我们分别选一个一阶微分算子和一个二阶微分算子作为示例:Sobel算子和Laplacian算子。首先,还是给出图像像素的8领域:
数字图像处理--微分算子为什么也是空间滤波器

对于拉普拉斯算子,其二阶梯度表示是:
Laplacian=z8+z2+z6+z44z5 Laplacian = z_8 + z_2 + z_6 + z_4 - 4 *z_5
如果我们把8领域都考虑进去,其可以转换成如下的形式:

Laplacian=0z1+1z2+0z3+1z4+(4)z5+1z6+0z7+1z8+0z9\begin{aligned} Laplacian =& 0*z1 + 1*z2 + 0*z3 +\\& 1*z4 + (-4)*z5 + 1*z6+ \\ &0*z7 + 1*z8 + 0*z9 \end{aligned}
这和上面的式子是等价的。我们把上面的8领域像素的系数提取出来,形成一个系数矩阵,就是:

数字图像处理--微分算子为什么也是空间滤波器

那么对图像实施拉普拉斯算子操作,实质上就是用这个系数矩阵与图像中的任意一点的领域区域矩阵进行矩阵点乘,然后求点乘后矩阵的和。写出公式就是:

g(x,y)=a=nnb=nnw(a,b)f(x+a,y+b) g(x,y)=\sum_{a=-n}^{n}\sum_{b=-n}^{n}w(a,b)f(x+a,y+b)
其中w(a, b)就是上面的拉普拉斯算子矩阵。

我们注意到,这和前面文章中提到的空间滤波器形式是一模一样的。所以,像拉普拉斯算子这样的二阶微分算子,可以像平滑空间滤波器(图像降噪、图像模糊)那样,使用空间滤波器的形式,这为统一计算模型带来了极大方便。

同理,对于Sobel算子,其一阶梯度表示是:

S=(z7+2z8+z9)(z1+2z2+z3)+(z3+2z6+z9)(z1+2z4+z7) S=|(z_7+2*z_8+z_9)-(z_1+2*z_2+z_3)|+|(z_3+2*z_6+z_9)-(z_1+2*z_4+z_7)|
由于这里用了绝对值,我们需要分开来:
Sobel=gx+gygx=(z7+2z8+z9)(z1+2z2+z3)gy=(z3+2z6+z9)(z1+2z4+z7) Sobel = |gx|+|gy| \\ gx = (z_7+2*z_8+z_9)-(z_1+2*z_2+z_3)\\ gy = (z_3+2*z_6+z_9)-(z_1+2*z_4+z_7)

转换成等价形式:

gx=(1)z1+(2)z2+(1)z3+0z4+0z5+0z6+1z7+2z8+1z9gy=(1)z1+0z2+1z3+(2)z4+0z5+2z6+(1)z7+0z8+1z9 \begin{aligned} gx =&(-1)*z_1 + (-2)*z_2 + (-1)*z_3+\\ &0*z_4 + 0*z_5 + 0*z_6 +\\ &1*z_7 + 2*z_8 + 1*z_9 \\ gy =& (-1)*z_1 + 0*z_2 + 1*z_3 + \\ &(-2)*z_4 + 0*z_5 + 2*z_6 + \\ &(-1)*z_7 + 0*z_8 + 1*z_9 \\ \end{aligned}
提取出系数矩阵就是:

gx=[121000121],gy=[101202101] gx=\begin{bmatrix} -1&-2&-1 \\ 0&0&0 \\ 1&2&1 \end{bmatrix},gy=\begin{bmatrix} -1&0&1 \\ -2&0&2 \\ -1&0&1 \end{bmatrix}

由于使用了x方向和y方向梯度的绝对值的和来表示梯度幅值,因此Sobel算子需要使用2个这样的系数矩阵,也就是2个空间滤波器。

转载自:https://blog.****.net/saltriver/article/details/78990694