1、数字信号处理图像边缘检测与提取1、图像边缘的定义所谓图像边缘(Edlge)是指图像局部特性的不连续性,例如,灰度级的突变,颜色的突变,纹理结构的突变等。边缘广泛存在于目标与目标、物体与背景、区域与区域(含不同色彩)之间,它是图像分割所依赖的重要特征。本为主要讨论几种典型的图像灰度值突变的边缘检测方法,其原理也是用于其他特性突变的边缘检测。图像的边线通常与图像灰度的一阶导数的不连续性有关。图像灰度的不连续性可分为两类:阶跃不连续,即图像灰度再不连续出的两边的像素的灰度只有明显的差异,如图 1.1 所示,线条不连续,即图像灰度突然从一个值变化到另一个值,保持一个较小的行程又返回到原来的值。在实际中
2、,阶跃和线条边缘图像是较少见的,由于空间分辨率(尺度空间)、图像传感器等原因会使阶跃边缘变成斜坡形边缘,线条边缘变成房顶形边缘。它们的灰度变化不是瞬间的而是跨越一定距离的。2、经典的边缘检测算子边缘检测的实质是采用某种算法来提取出图像中对象与背景间的交界线。我们将边缘定义为图像中灰度发生急剧变化的区域边界。图像灰度的变化情况可以用图像灰度分布的梯度来反映,因此我们可以用局部图像微分技术来获得边缘检测算子。经典的边缘检测方法,是对原始图像中像素的某小邻域来构造边缘检测算子。以下是对几种经典的边缘检测算子进行理论分析,并对各自的性能特点作出了比较和评价不妨记: (x,y)= + 为图像的梯度, (
3、x,y)包含灰度变化信息fixfjyf记: (x,y)= 为 (x,y)的梯度,e(x,y)可以用作边缘检测算子。为了简化计算,ef2f也可以将 e(x, y)定义为偏导数 与 的绝对值之和:xy=| |+| |),(yxe),(fx),(fy以这些理论为依据,提出了许多算法,常用的边缘检测方法有:Roberts 边缘检测算子、Sobel 边缘检测算子、Prewitt 边缘检测算子、Canny 边缘检测算子、Laplace 边缘检测算子等等。3、 Sobel 边缘检测算子对数字图像 (i,j)的每个像素,考察它上、下、左、右邻点灰度的加权差,与之接近的邻点的f权大。据此.定义 Sobel 算子
4、如下:| |+| |),(jisfxfy|( +2 + )-( +2 + )|+|( (i-1,j-1,f),(ji)1,(ji )1,(jif),(jif)1,(jiff1)+2 (i,j-1)+ (i+1.j-1)-( i-1,j+1)+2 (i,j+1)+ (i+1.j+1)|ff其卷积算子 , fx102fy120图 1-4 Sobel 边缘检测算子方向模板适当取门限 TH,作如下判断: TH, (i, j)为阶跃状边缘点, 为边),(jis ),(jis缘图像。Sobel 算子很容易在空间上实现,Sobel 边缘检测器不但产生较好的边缘检测效果,而且受噪声的影响也比较小。当使用大的领
5、域时,抗噪声特性会更好,但这样做会增加计算量,并且得出的边缘也较粗。Sobel 算子利用像素点上下、左右邻点的灰度加权算法,根据在边缘点处达到极值这一现象进行边缘的检测。Sobel 算子对噪声具有平滑作用,提供较为精确的边缘方向信息,但它同时也会检测出许多的伪边缘,边缘定位精度不够高。当对精度要求不是很高时,是一种较为常用的边缘检测方法。适当取门限 TH,作如下判断: (i,j) TH, (i, j)为阶跃状边缘点。 (i,j)为边缘图像。4、Laplacian of Gaussian(LoG)算子正如上面所提到的,利用图像强度二阶导数的零交叉点来求边缘点的算法对噪声十分敏感,所以,希望在边缘
6、增强前滤除噪声为此,Marr 和 Hildreth146将高斯滤波和拉普拉斯边缘检测结合在一起,形成 LoG(Laplacian of Gaussian, LoG)算法,也称之为拉普拉斯高斯算法LoG 边缘检测器的基本特征是:1 平滑滤波器是高斯滤波器2 增强步骤采用二阶导数(二维拉普拉斯函数) 3 边缘检测判据是二阶导数零交叉点并对应一阶导数的较大峰值4 使用线性内插方法在子像素分辨率水平上估计边缘的位置这种方法的特点是图像首先与高斯滤波器进行卷积(高斯滤波器在 66 节中将详细讨论) ,这一步既平滑了图像又降低了噪声,孤立的噪声点和较小的结构组织将被滤除由于平滑会导致边缘的延展,因此边缘检
7、测器只考虑那些具有局部梯度最大值的点为边缘点这一点可以用二阶导数的零交叉点来实现拉普拉斯函数用作二维二阶导数的近似,是因为它是一种无方向算子为了避免检测出非显著边缘,应选择一阶导数大于某一阈值的零交叉点作为边缘点LoG 算子的输出 是通过卷积运算得到的:hxy(,)hxygxyf(,)(,),2根据卷积求导法有 f(,)(,)(,)2其中: 22242gxyexy(,)滤波(通常是平滑)、增强、检测这三个边缘检测步骤对使用 LoG 边缘检测仍然成立,其中平滑是用高斯滤波器来完成的;增强是将边缘转换成零交叉点来实现的;边缘检测则是通过检测零交叉点来进行的可以看到,零交叉点的斜率依赖于图像强度在穿
8、过边缘时的变化对比度剩下的问题是把那些由不同尺度算子检测到的边缘组合起来在上述方法中,边缘是在特定的分辨下得到的为了从图像中得到真正的边缘,有必要把那些通过不同尺度算子得到的信息组合起来01026010图 1-7 拉普拉斯高斯模板 55、实验过程(1)用 edge_sobel 算法提取边缘:对于 lena256,当 th=150,160,170,180,190,200 时当 th=180 时,效果最好对于 lena256n,加入噪声后,th=150,170,190,210,230,250 时当 th=230 时,效果最好对于 peppers512,th=50,70,75,90,100,110
9、时当 th=75 时,效果最好对于 peppers512n,th=130.150,170,180,190,200 时当 th=180 时,效果最好在加入噪声之后,th 取值要高于未加入噪声时的值(2)用 LOG 算法当 N=3,sig=0.4,th=150,170,190,210,230,250 变化时由上图,当 N=3,sig=0.4,th=210 时,效果最好对于 lena256n当 N=5,sig=0.9,th=15,20,25,30,35,40 时由图可知,当 N=5,sig=0.9,th=30 时效果最好对于 peppers512 N=3,sig=0.6,th=25,30,35,40,45,50 时由图可知,当 N=3,sig=0.6,th=50 时效果最好对于 peppers512n,N=5,sig=0.9,th=15,20,25,30,35,40由图可知,当 N=5,sig=0.9,th=30 时效果最好对于该算法,当 sig 取值增大时,要想获得与之同样效果的图,需要把 th 减小6、结果分析无噪声时,两种方法对比(左边为用 Sobel 边缘检测算子)用 Sobel 边缘检测算子效果好有噪声时也是用 Sobel 边缘检测算子效果好。综上,Sobel 边缘检测算子比 Laplacian of Gaussian(LoG)算子适用性强,效果好。