数字图像处理学习笔记 第十章图像分割

10.1 点、线和边缘检测

        间断点检测包括点检测、线检测和边界检测三种,寻找间断最一般的方法是模板检测。计算模板所包围区域的灰度级与模板系数的乘积之和。图像中任意点的模板响应公式为:

R=w_{1}z_{1}+w_{2}z_{2}+...+w_{9}z_{9}=\sum_{i=1}^{9}w_{i}z_{i}

         其中z_{i}是与模板系数w_{i}相联系的像素的灰度级,R是相对于模板中心位置的像素的响应。

图10.1 一个普通的3*3空间滤波器掩膜

      10.1.1  孤立点的检测

         孤立点是指该点的灰度级与其背景的差异相当大,并且它所在的位置是一个均匀的或者近似均匀的区域。其基本思想就是如果一个孤立点与它周围的点很不相同,则很容易被上述模板检测到,在灰度级为常数的区域,模板响应R为0。

        拉普拉斯公式为:

\triangledown ^{2}f(x,y)=\frac{\partial ^{2}f}{\partial x^{2}}+\frac{\partial ^{2}f}{\partial y^{2}}

        其中,偏微分公式为:

\frac{\partial ^{2}f(x,y)}{\partial x^{2}}=f(x+1,y)+f(x-1,y)-2f(x,y)

\frac{\partial ^{2}f(x,y)}{\partial y^{2}}=f(x,y+1)+f(x,y-1)-2f(x,y)

        故拉普拉斯是

\triangledown ^{2}f(x,y)=f(x+1,y)+f(x-1,y)+f(x,y+1)+f(x,y-1)-4f(x,y)

        点检测的输出是使用如下表达式得到的:

        g(x,y)=\begin{cases} 1 & \text{ if } |R(x,y)|\geqslant T \\ 0 & \text{ if } else \end{cases}

图10.2 

        10.1.2 线检测

        复杂度更高的检测是线检测,对于线检测,可以预期二阶导数将导致更强的响应,并产生比一阶导更细的线,这样,我们可以使用拉普拉斯模板,二阶导数的双线效应必须做适当的处理。通常,我们的兴趣在于检测特定方向的线,假设使用第一个模板对一幅具有恒定背景并包含各种线的图像进行滤波,最大响应将出现在图像中通过该模板中间行的一条水平线上。实验表明,第二个模板对于45^{\circ }方向的线有最佳响应。

10.3  线检测模板
图10.4  (a)原图像;(b)拉普拉斯图像;(c)拉普拉斯的绝对值;(d)拉普拉斯的正值

        10.1.3  边缘模型

        由于两个具有不同灰度值的相邻区域之间总存在灰度边缘,而灰度边缘是灰度值不连续(或突变)的结果,这样这种不连续常常可以利用求导数来检测到。一般用一阶和二阶导数来检测边缘。

图10.5  理想垂直边缘分开的恒定灰度区域及其一阶导数和二阶导数

         当沿着剖面线从左到右经过时,在进入和离开斜面的变化点,一阶导数为正,在灰度级不变的区域一阶导为零。在边缘与黑色一边相关的跃变点二阶导数为正,在边缘与亮色一边相关的跃变点二阶导为负数,沿着斜坡和灰度为常数的区域为零。通过以上观察和分析,一阶导数可用于检测图像中的一个点是否是边缘点;二阶导数的符号可以用于判断一个边缘像素是在边缘亮的一边还是暗的一边。

        1.梯度算子——直接差分算子

        为了达到检测边缘的目的,可以通过计算图像的一阶导数来完成,该类技术为基本边缘检测技术,所采用的工具就是梯度。

        \bullet梯度可用于描述图像f(x,y)(x,y)位置处的边缘点的强度和方向,表示为\triangledown f

\triangledown f=\left [ g_{x}, g_{y} \right ]^{T}=\left [ \frac{\partial f}{\partial x} ,\frac{\partial f}{\partial y}\right ]^{T}

        \bullet梯度的幅度描述了梯度向量最大变化率的值,表示为|\triangledown f||\triangledown f|=\sqrt{g{_{x}}^{2}+g{_{y}}^{2}}=\sqrt{( \frac{\partial f}{\partial x})^{2} +(\frac{\partial f}{\partial y})^{2}}

        \bullet梯度的方向由对于x轴(正x轴向下延伸,正y轴向右延伸)度量的角度给出,表示为\alpha (x,y)\alpha (x,y)=arctan\left [ \frac{g_{y}}{g_{x}} \right ]

        上述两个梯度分量的直接差分计算公式对所有x和y的有关值可用直接差分算子(模板)对f(x,y)的滤波来执行。例如图示各个位置处的像素点的梯度(以(x,y)处的像素为例)如下:

g_{x}=-1\times f(x,y)+0\times f(x,y+1)+1\times f(x+1,y)+0\times f(x+1,y+1)

g_{y}=-1\times f(x,y)+1\times f(x,y+1)+0\times f(x+1,y)+0\times f(x+1,y+1)

        2.梯度算子——Roberts算子

        Roberts算子是最早尝试使用具有对角优势的边缘检测器,其计算任意位置(x,y)处的像素点的梯度分量如下:

垂直梯度分量:g_{x}= f(x+1,y+1)- f(x,y)

水平梯度分量:g_{y}= f(x+1,y)- f(x,y+1)

        上述两个梯度分量的计算公式对所有x和y的有关值可以用Roberts模板对f(x,y)的滤波来执行。Roberts算子可用于检测对角线方向的边缘。

        3.梯度算子——Prewitt算子

        直接差分模板以及Roberts模板(均为2\times 2大小)在概念上很简单,但是忽略了中心点对端数据的性质。Prewitt算子考虑了中心点对端数据的性质,而且携带有关边缘方向的更多信息;其计算任意位置(x,y)处的像素点的梯度分量及滤波模板如下:

g_{x}=\left [ f(x+1,y-1)+f(x+1,y)+f(x+1,y+1) \right ]-\left [ f(x-1,y-1)+f(x-1,y)+f(x-1,y+1) \right ]

g_{y}=\left [ f(x-1,y+1)+f(x,y+1)+f(x+1,y+1) \right ]-\left [ f(x-1,y-1)+f(x,y-1)+f(x+1,y-1) \right ]

        4. 梯度算子——Sobel算子

        相对于Prewitt算子,Sobel算子通过增强模板中心点的重要性而实现某种程度的平滑效果(在完成边缘检测的同时,也较好地抑制了噪声),其计算任意位置(x,y)处的像素点的梯度分量及滤波模板如下:

    g_{x}=\left [ f(x+1,y-1)+2\times f(x+1,y)+f(x+1,y+1) \right ]-\left [ f(x-1,y-1)+2\times f(x-1,y)+f(x-1,y+1) \right ]

g_{y}=\left [ f(x-1,y+1)+2\times f(x,y+1)+f(x+1,y+1) \right ]-\left [ f(x-1,y-1)+2\times f(x,y-1)+f(x+1,y-1) \right ]

        5.梯度算子——用于检测对角边缘的Prewitt、Sobel算子

        为了实现对对角线方向边缘的检测,可以对上述的Prewitt模板和Sobel模板做出修改,以便它们沿着对角线方向有最大的响应,如下:

        Prewitt和Sobel算子相比较,Prewitt模板比Sobel模板简单,但Sobel模板能够有效抑制噪声。

       当使用上述各种梯度模板求解图像中每个像素位置处的梯度分量g_{x} 和g_{y}后,可以采用公式|\triangledown f|=\sqrt{g_{x}^{2}+g_{y}^{2}}计算梯度的幅值(即边缘的强度),也可以采用绝对值来近似梯度的幅值,即:|\triangledown f|=|g_{x}|+|g_{y}|。使用Sobel算子检测如图所示。

10.2更先进的边缘检测技术

        10.2.1Marr-Hildreth边缘检测器

        图像f在x+y位置处的拉普拉斯变换定义:

\triangledown ^{2}f(x,y)=f(x+1,y)+f(x-1,y)+f(x,y+1)+f(x,y-1)-4f(x,y)

        拉普拉斯变换可以利用零交叉的性质进行边缘定位,也可以确定一个像素是在边缘暗的一边还是亮的一边。同时,它也存在缺点,即对噪声具有名感性,幅值产生双边缘,不能检测边缘的方向。

        用于边缘检测的算子应该具备的两个显著特点:

        \bullet边缘检测算子应该是一个能计算图像中每一点处的一阶导数或二阶导数的数字近似的微分算子;

        \bullet边缘检测算子应该能被“调整”以便在任何期望的尺寸上起作用(大尺寸的算子可用于检测模糊边缘,小尺寸的算子可用于检测锐度集中的精细边缘。)

        满足上述要求的算子是\triangledown ^{2}G(高斯拉普拉斯算子,简称LoG算子),其中:

       \bullet \triangledown ^{2}是拉普拉斯算子(\partial ^{2}/\partial x^{2}+\partial ^{2}/\partial y^{2})

       \bulletG是标准差为\sigma的二维高斯函数:G(x,y)=e^{-\frac{x^{2}+y^{2}}{2\sigma ^{2}}}

      则  \triangledown ^{2}G(x,y)=\frac{\partial ^{2}G(x,y)}{\partial x^{2}}+\frac{\partial ^{2}G(x,y)}{\partial y^{2}}=\frac{\partial }{\partial x}\left [ \frac{-x}{\sigma ^{2}} e^{-\frac{x^{2}+y^{2}}{2\sigma ^{2}}}\right ]+\frac{\partial }{\partial y}\left [ \frac{-y}{\sigma ^{2}} e^{-\frac{x^{2}+y^{2}}{2\sigma ^{2}}}\right ]

                                =\left [ \frac{x^{2}}{\sigma ^{4}}-\frac{1}{\sigma ^{2}} \right ]e^{-\frac{x^{2}+y^{2}}{2\sigma ^{2}}}+\left [ \frac{y^{2}}{\sigma ^{4}}-\frac{1}{\sigma ^{2}} \right ]e^{-\frac{x^{2}+y^{2}}{2\sigma ^{2}}}=\left ( \frac{x^{2}+y^{2}-2\sigma ^{2}}{\sigma ^{4}} \right )e^{-\frac{x^{2}+y^{2}}{2\sigma ^{2}}}

        Marr-Hildreth边缘检测算法由LoG滤波器与输入图像f(x,y)卷积组成,即

g(x,y)=\left [ \triangledown ^{2}G(x,y) \right ]\cdot f(x,y)

        然后,寻找的零交叉来确定f(x,y)中边缘的位置。由于微分、卷积运算都是现线性操作,故上式可表示为:

g(x,y)=\triangledown ^{2}\left [ G(x,y)\cdot f(x,y) \right ]

        即,可以先使用一个高斯滤波器平滑图像,然后对该结果执行拉普拉斯变换。因此,Marr-Hildreth边缘检测算法的实现步骤如下:

        \bullet使用高斯滤波器对输入图像进行平滑滤波;

        \bullet计算由第一步骤得到的图像的拉普拉斯变换;

        \bullet寻找第二步骤所得图像的零交叉(由此得到的边缘一个像素宽)。

        判定图像g(x,y)的任意像素p是否为零交点的一种方法如下:

        \bullet在图像g(x,y)中找到一个以p为中心的3\times 3邻域;

        \bulletp像素为零交叉点意味着至少有两个相对的邻域像素的符号不同,有4种要测试的情况:左/右、上/下和两个对角;

        \bullet如果相对的两个邻域像素的符号不同,而且它们的像素值与p的像素值的绝对差值超过指定的阙值。那么,p即为一个零交叉像素。

        10.2.2  Canny(坎尼)边缘检测器

        Canny边缘检测器的目标实现一个最优的边缘检测算法,其准则包含以下三方面:

        \bullet低错误率:所有边缘都应被找到,并且应该没有伪响应;

        \bullet边缘点应被很好地定位:已定位的边缘必须尽可能接近真实边缘。也就是由检测器标记为边缘的点和真实边缘的中心之间的距离应该最小;

        \bullet单一的边缘点响应:对于真实的边缘点,检测器仅应返回一个点。也就是在仅存一个单一边缘点的位置,检测器不应输出多个边缘像素。

        实现步骤:

        \bullet用一个大小为n\times n 高斯滤波器平滑输入图像(其中,n的取值应为大于或等于6倍高斯滤波器的标准差的最小奇整数);

        \bullet计算滤波后图像的梯度幅值和方向角度;

        \bullet对梯度幅值图像执行非极大值抑制(剔除伪边缘点,保留候选边缘点);

        \bullet对非极大值抑制的结果使用双阈值检测边缘(从候选边缘点选择真实边缘点);

        \bullet采用连接分析对双阈值边缘检测结果进行连接(得到连续完整的边缘)。

        非极大值抑制仅保留梯度幅值图像M(x,y)的极大值(严格地说,保留梯度方向上的极大值点),以此实现边缘的细化。局部极值周围存在相近数值的点,通过非极大值抑制选择合适的极值点作为边缘点。

        非极大值抑制的实现步骤:(假设仅保留梯度幅值极大值的结果为N(x,y)

        \bulletN(x,y)初始化为原始的梯度幅值图像M(x,y)

        \bullet对于每个点N(x,y),在梯度方向和反梯度方向各找n个像素点;若N(x,y)不是这些点中的最大点,则将N(x,y)置零,否则保持N(x,y)不变。

        需要注意的是,N(x,y)的边缘比原始的梯度边缘细,但任然保持了比1个像素粗的边缘,可采用形态学细化方法加以解决。此外,对于非极大值抑制,阈值选取不当,可能导致产生伪边缘点,丢失有效的边缘点。

        对非极大值抑制结果使用双阈值检测边缘,对于上述得到的N(x,y)使用单阈值进行边缘检测可能会导致下述结果的出现:

        \bullet若使用大的阈值,结果仅能得到少量的边缘点,且存在较多空隙;

        \bullet若使用小的阈值,结果虽然能得到大量的边缘点,但会产生较多的错误检测。

        对上述得到的N(x,y)使用双阈值进行边缘检测过程如下:

        \bullet指定两个阈值T_{H}T_{L}T_{H}>T_{L}(建议:高阈值与低阈值的比率应为2:1或3:1)

        \bullet使用高阈值T_{H}检测边缘,得到高阈值边缘图E_{H}(x,y)(边缘点少,但可靠);

        \bullet使用低阈值T_{L}检测边缘,得到低阈值边缘图E_{L}(x,y)(边缘点多,但错误检测率高)

        使用连接分析对双阈值边缘检测结果进行边缘连接

        \bullet将高阈值边缘图E_{H}(x,y)中相连的边缘点输出为一幅边缘图像E(x,y)

        \bullet对于E(x,y)中每条边,从端点出发在低阈值边缘图E_{L}(x,y)中寻找其延长的部分,直至与E(x,y)中另外一条边的端点相连(8连通性),否则认为E_{L}(x,y)中没有它延长的部分;

        \bulletE(x,y)作为结果输出。

        如上图所示,检测出了大多数的主要边缘(房屋的角落、入口、窗户、屋顶等),同时过滤掉了不重要的细节(砖块和瓦片屋顶的纹理),边缘检测结果由于LoG算子,如屋顶的纹理去除更干净;同时,房屋入口的左边缘被清晰地检测到,而LoG算子无法检测出该边缘。


参考文献:数字图像处理(第四版)冈萨雷斯

  • 10
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值