基于MATLAB边缘检测与提取的几种方法的比较.doc
《基于MATLAB边缘检测与提取的几种方法的比较.doc》由会员分享,可在线阅读,更多相关《基于MATLAB边缘检测与提取的几种方法的比较.doc(7页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、【精品文档】如有侵权,请联系网站删除,仅供学习与交流基于MATLAB边缘检测与提取的几种方法的比较.精品文档.基于MATLAB边缘检测与提取的几种方法的比较数字图像边缘检测(Digital Image Processing)又称为计算机图像边缘检测,它是指将图像信号转换成数字信号并利用计算机对其进行处理的过程。由于图像边缘是图像最基本的特征之一,往往携带着一幅图像的大部分信息。而边缘存在于图像的不规则结构和不平稳现象中,也即存在于信号的突变点处,这些点给出了图像轮廓的位置,这些轮廓常常是我们在图像边缘检测时所需要的非常重要的一些特征条件,这就需要我们对一幅图像检测并提取出它的边缘。在通常情况下
2、,我们可以将信号中的奇异点和突变点认为是图像中的边缘点,其附近灰度的变化情况可从它相邻像素灰度分布的梯度来反映。根据这一特点,提出了多种边缘检测算子:如 Robert算子、Sobel 算子、Prewitt 算子、Laplacian 算子,Canny算子等。这些方法多是以待处理像素为中心的邻域作为进行灰度分析的基础,实现对图像边缘的提取并已经取得了较好的处理效果。经典的边界提取技术大都基于微分运算。首先通过平滑来滤除图像中的噪声,然后进行一阶微分或二阶微分运算,求得梯度最大值或二阶导数的过零点,最后选取适当的阈值来提取边界。本文主要介绍几种经典的边缘提取算法,选取两种用MATLAB语言编程实现,
3、对提取结果进行比较和分析。图像边缘检测的基本步骤:(1)滤波。边缘检测主要基于导数计算,但受噪声影响。但滤波器在降低噪声的同时也导致边缘强度的损失。(2)增强。增强算法将邻域中灰度有显著变化的点突出显示。一般通过计算梯度幅值完成。(3)检测。但在有些图像中梯度幅值较大的并不是边缘点。最简单的边缘检测是梯度幅值阈值判定。(4)定位。精确确定边缘的位置。几种边缘算子的比较以柚子的图片为例1、Roberts算子是一种利用局部差分算子寻找边缘的算子,Roberts算子边缘定位准,但是对噪声敏感。适用于边缘明显而且噪声较少的图像分割,在应用中经常用Roberts算子来提取道路。程序如下:I=imread
4、(D:研一阳建宏信号作业柚子.jpg); %读取图像 J=rgb2gray(I); %转化为灰度图像 K=imadjust(J,40/255 1); %调整灰度值 BW=edge(K, roberts); %边缘检测 figure(1);imshow(BW); %显示图像2、Sobel边缘算子:图像中的每个像素都用这核做卷积。这两个核分别对垂直边缘和水平边缘响应最大,两个卷积的最大值作为该点的输出位。运算结果是一幅边缘幅度图像。Sobel算子认为邻域的像素对当前像素产生的影响不是等价的,所以距离不同的像素具有不同的权值,对算子结果产生的影响也不同。一般来说,距离越大,产生的影响越小。程序如下:
5、I=imread(D:研一阳建宏信号作业柚子.jpg); %读取图像 J=rgb2gray(I); %转化为灰度图像 K=imadjust(J,40/255 1); %调整灰度值 BW=edge(K, sobel); %边缘检测 figure(1);imshow(BW); %显示图像3、Prewitt算子在一个方向求微分,而在另一个方向求平均,因而对噪声相对不敏感,有抑制噪声作用。但是像素平均相当于对图像的低通滤波,所以Prewitt算子对边缘的定位不如Roberts算子。程序如下:I=imread(D:研一阳建宏信号作业柚子.jpg); %读取图像 J=rgb2gray(I); %转化为灰度
6、图像 K=imadjust(J,40/255 1); %调整灰度值 BW=edge(K, prewitt); %边缘检测 figure(2);imshow(BW); %显示图像这是未经滤波的效果图。4、Laplacian算子利用二阶导数信息,具有各向同性,即与坐标轴方向无关,坐标轴旋转后梯度结果不变。使得图像经过二阶微分后,在边缘处产生一个陡峭的零交叉点,根据这个对零交叉点判断边缘。Laplacian算子对噪声比较敏感,Laplacian算子有一个缺点是它对图像中的某些边缘产生双重响应。所以图像一般先经过平滑处理,通常把Laplacian算子和平滑算子结合起来生成一个新的模板。5、Log(La
7、placian of Gassian )算法:将高斯滤波和拉普拉斯检测算子结合在一起进行边缘检测的方法。也称之为拉普拉斯高斯算法。该算法的主要思路和步骤是:滤波(滤波函数根据人类视觉特性选为高斯函数)、增强(对平滑图像进行拉普拉斯运算)、检测(边缘检测判据是二阶导数的零交叉点并对应一阶导数的较大峰值)。这种方法的特点是图像首先与高斯滤波器进行卷积,这样既平滑了图像又降低了噪声,孤立的噪声点和较小的结构组织将被滤除。但是由于平滑会造成图像边缘的延伸,因此边缘检测器只考虑那些具有局部梯度最大值的点为边缘点。高斯-拉普拉斯算子把高斯平滑滤波器和拉普拉斯锐化滤波器结合起来,先平化掉噪声,再进行边缘检测
8、,所以效果更好。程序如下:I=imread (D:研一阳建宏信号作业柚子.jpg);J=rgb2gray(I); %转化为灰度图像K=imadjust(J,40/255 1); %调整灰度值BW1=edge(K,log,0.01); figure(1);subplot(3,2,1);imshow(BW1);title(阈值为0.01的LOG算子边缘检测图像);BW11=edge(K,log,0.001);subplot(3,2,5);imshow(BW11);title(阈值为0.001的LOG算子边缘检测图像);BW2= edge(K,log,0.005);subplot(3,2,4);im
9、show(BW2);title(阈值为0.005的LOG算子边缘检测图像);BW20= edge(K,log,0.007);subplot(3,2,3);imshow(BW20);title(阈值为0.007的LOG算子边缘检测图像);BW22= edge(K,log,0.009);subplot(3,2,2);imshow(BW22);title(阈值为0.009的LOG算子边缘检测图像);BW23= edge(K,log,0.0001);subplot(3,2,6);imshow(BW23);title(阈值为0.0001的LOG算子边缘检测图像);结果分析:如图所示采用的阈值越小则图像的
10、边缘处理效果越清晰,且边缘点条理显著。但是当阈值超过0.0001时图像边缘的处理效果越模糊如图5.20所示,但是仍能进行边缘的判断!6、Canny算子类似与Marr(LOG)边缘检测方法,也属于先平滑后求导数的方法。采用二维高斯函数的任意方向上的一阶方向导数为噪声滤波器,通过与图像卷积进行滤波;然后对滤波后的图像寻找图像梯度的局部最大值,以此来确定图像边缘。根据对信噪比与定位乘积进行测度,得到最优化逼近算子。这就是Canny边缘检测算子。用双阈值算法检测和连接边缘。检测方法的优点:低误码率,很少把边缘点误认为非边缘点;高定位精度,即精确地把边缘点定位在灰度变化最大的像素上;抑制虚假边缘。程序如
11、下:I=imread (D:研一阳建宏信号作业柚子.jpg);J=rgb2gray(I); %转化为灰度图像K=imadjust(J,40/255 1); %调整灰度值BW1=edge(K,canny,0.01); figure(2);subplot(3,2,1);imshow(BW1);title(阈值为0.01的Canny算子边缘检测图像);BW11=edge(K,canny ,0.009);subplot(3,2,2);imshow(BW11);title(阈值为0.009的Canny算子边缘检测图像);BW2= edge(K,canny,0.007);subplot(3,2,3);im
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 基于 MATLAB 边缘 检测 提取 方法 比较
限制150内