当前位置:   article > 正文

图像处理------图像锐化(微分法)_罗伯茨梯度

罗伯茨梯度

取自孙明的"数字图像处理与分析基础"
考察正弦函数sin2πax,它的微分为2πacos2πax,微分后频率不变,幅度上升2πa倍.空间频率越高,幅值增加就越大.这表明微分可以通过加强高频成分,使图像轮廓变清晰.最常用的微分方法视梯度法.设有一副图像f(x,y),它的梯度采用数学概念描述时是一个向量,定义为

G[f(x,y)]=[fx fy]T.................(0)

可见,梯度具有以下两个重要性质:

  • 梯度的方向在函数f(x,y)最大变化率的方向上.
  • 该梯度向量的模为 G[f(x,y)]=[(f/x)2+(f/y)2]12

G[f(x,y)]称为图像f(x,y)的梯度,实际上视图像f(x,y)的梯度图像.
从数学上说,梯度的数值为f(x,y)在其最大变化率方向上的单位距离所增加的量.对于数学图像,可用差分来近似微分.

几种常见差分算法

(1)梯度算法
按照差分运算近似的梯度表达式为
G[f(x,y)]=[(f(x,y)f(x+1,y))2+(f(x,y)f(x,y+1))2]12....(1)
其中,各个像素f(x,y)f(x+1,y)f(x,y+1)之间的位置关系为

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

(2)罗伯茨(Roberts)梯度算法
另一种常用的梯度算法称为罗伯茨梯度算法,它是一种交叉差分的计算方法,定义为
G[f(x,y)]=[(f(x,y)f(x+1,y+1))2+(f(x+1,y)f(x,y+1))2]12....(2)
其中,各个像素f(x,y)f(x+1,y+1)f(x+1,y)f(x,y+1)之间的位置关系为

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

(3)索伯尔(Sobel)算法
索伯尔算法的差分可表示为
G[f(x,y)]=[d1f(x,y)]2+d2f(x,y)]2.........(3)
其中,d1f(x,y)=(a2+ca3+a4)(a0+ca7+a6)d2f(x,y)=(a0+ca1+a2)(a6+ca5+a4),而a0,a1,……,a7之间的位置关系如图1(a)所示,d1d为图1(b)和(c)所示的模板,其中常数c=2.

a0a1a2
a7(x,y)a3
a6a5a4

图1(a) a0,a1,……,a7之间的位置关系

10 1
c0 c
10 1

图1(b) d1

1 c1
0 0 0
1c1

图1(b) d2
上面三图是索伯尔和普瑞维特算法模板
(4)普瑞维特(Prewitt)算法
普瑞维特算法的方程与索伯尔算法相同,只是常数c=1,如图(1)所示.与索伯尔算法方程相同的算法还有Sethi算法,这种算法的常数c=3;以及各向同性索伯尔(Isotropic Sobel)算法,次算法的常数c=2.后者的特点是沿不同方向锐化时梯度幅值一致.
上述采用平方根的算法运算较费时,为更适合计算机实现,采用下面的绝对差分算法.
梯度算法:
G[f(x,y)]|f(x,y)f(x+1,y)|+|f(x,y)f(x,y+1)|
罗伯茨梯度算法:
G[f(x,y)]|f(x,y)f(x+1,y+1)|+|f(x+1,y)f(x,y+1)|
索伯尔和普瑞维特算法:
G[f(x,y)]|d1f(x,y)|+|d2f(x,y)|
(5)拉普拉斯算法(二阶差分)
拉普拉斯算法的差分可表示为
G2[f(x,y)]=Δ12f(x,y)+Δ12f(x,y)=f(x+1,y)+f(x1,y)+f(x,y+1)+f(x,y1)4f(x,y)(4)
其模板如下图所示,这个模板可作为拉普拉斯1模板,常用的其它拉普拉斯模板入表1所示.
这里写图片描述
表1如下
这里写图片描述

(6)LoG算法
LoG边缘检测器的基本特征是,平滑滤波器是高斯滤波器,加强步骤采用二阶差分(拉普拉斯算法).LoG算子的输出是通过卷集运算得到的:
h(x,y)=G2[g(x,y)f(x,y)]..................(5)
根据卷积微分法有:
h(x,y)=[G2g(x,y)]f(x,y)..................(6)
其中

G2g(x,y)=(x2+y22σ2σ4)ex2+y22σ2

直接实现LoG算法如图3所示,这是一个5*5拉普拉斯高斯模板.
这里写图片描述
对N*N数字图像,不可能在最后一行(x=N)和最后一列(y=N)像素上计算梯度值.一种补救办法视用前一行(x=N-1)和前一列(y=N-1)对应的像素的梯度值.
某像素上的梯度值视该像素与相邻像素的灰度差值的单调递增函数,具有以下特点:

  • 图像轮廓上,像素灰度右陡然变化,梯度值很大.
  • 图像灰度 变化平缓区域,梯度值很小.
  • 等灰度区域,梯度值为零.

后续会加入scipy库中相关函数处理的程序
未完待续......

本文内容由网友自发贡献,转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号