欢迎来到天天文库
浏览记录
ID:59129345
大小:163.00 KB
页数:10页
时间:2020-09-12
《边缘检测算子的边缘提取及Hough变换.doc》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、题目边缘检测算子的边缘提取及Hough变换学院:信息科学与技术学院专业:控制科学与工程学生:XX指导教师:XXX2014年12月14日1、边缘检测算子简介图像边缘(或边沿)是指周围像素灰度有阶跃性变化或“屋顶”变化的那些像素的集合。在图像处理中通过边缘算子能够较好的提取出数字图像的边缘,常用的边缘检测算子主要分为以下几类:一、基于一阶导数的边缘检测算子包括Roberts算子、Sobel算子、Prewitt算子、Kirsch算子等,在算法实现过程中,通过2x2(Roberts算子)或者3x3模板作为核与图像中的每个像素点做卷积和运算,然
2、后选取合适的阈值以提取边缘。二、基于二阶导数的边缘检测算子,该算子对噪声敏感。一种是二阶微分的拉普拉斯边缘检测算子,另一种改进方式是先对图像进行平滑处理,然后再应用二阶导数的边缘检测算子,其代表是LOG算子。前边介绍的边缘检测算子法是基于微分方法的,其依据是图像的边缘对应一阶导数的极大值点和二阶导数的过零点。三、Canny边缘检测算子,它不是通过微分算子检测边缘,而是在满足一定约束条件下推导出的边缘检测最优化算子。2、不同边缘算子检测边缘分析本文基于Matlab编程实现不同边缘检测算子对一幅包含两个目标的图像进行边缘提取,原始图像如图
3、2.1所示。Roberts边缘检测算子是一种利用局部差分方法寻找边缘的算子,其采用的是对角方向相邻两像素值之差;Sobel边缘算子所采用的算法是先进行加权平均,然后进行微分运算;Prewitt边缘检测算子就是一种利用局部差分平均方法寻找边缘的算子,其先求平均,再求差分,即利用所谓的平均差分来求梯度;拉普拉斯边缘检测算子正是对二维函数进行二阶导数运算的标量算子;Canny边缘检测算子通过中心边缘点为算子与图像的卷积在边缘梯度方向上的区域中的最大值在梯度方向上判断此点强度是否为其领域的最大值来确定该点是否为边缘点。图2.1原始图像2.1R
4、oberts算子提取边缘图像图2.2Roberts算子边缘检测图像2.2Sobel算子提取边缘图像图2.3Sobel算子边缘检测图像2.3Prewitt算子提取边缘图像图2.4Prewitt算子边缘检测图像2.4Laplace算子提取边缘图像图2.5Laplace算子边缘检测图像2.5Log算子提取边缘图像图2.6Log算子边缘检测图像2.6Canny算子提取边缘图像图2.7Canny算子边缘检测图像3、Hough变换的边缘提取Hough变换利用图像空间和参数空间的点-线对偶性,将图像空间中具有一定关系的像素点在参数空间中进行聚集,通
5、过在参数空间进行简单的累加和统计,找出参数空间中累加器的峰值点,进而确定出图像空间中特定几何特征的相关参数。图像空间中的任意一个点映射到参数空间中是一条直线,图像空间中位于同一直线上的点映射到参数空间中是一组相交于同一点的直线,反过来,参数空间中相交于同一点的所有直线,在图像空间中与之对应的是在同一直线上的一组点。Hough变换提取边缘的主要步骤为:一、读入一副图像,将读入图像转为二值化图像,遍历整幅图像,判断每一个像素点是否为白点;二、对每一个白点进行处理,按照相应的量化数值在变换域累加器数组中的相应位置上加1;三、遍历累加器数组,
6、每找到一个局部最大值,判断该局部最大值是否大于所设置的阈值,若是,则将该最大值及其位置存放在上述定义的数组的一个元素中,并将该局部最大值附近的点清零,以便寻找下一个局部最大值,直到遍历整个数组找到的最大值小于设置的阈值为止。图3.1Hough变换边缘检测图像4、不同边缘检测算子的比较分析从本文的分析结果来看,Roberts算子是2x2算子,对具有陡峭的低噪声图像响应最好。Sobel算子、Prewitt算子是3x3算子,对灰度渐变和噪声较多的图像处理得较好。使用两个掩模板组成边缘检测器时,通常取较大的幅度作为输出值。这使得它们对边缘的走
7、向有些敏感。取它们的平方和的开方可以获得性能更一致的全方位响应。这与真实的梯度值更接近。值得注意的是3x3的Sobel算子和Prewitt边缘算子可扩展成八个方向,并且可以像使用Kirsch算子一样获得边缘方向图。Laplace算子与Log算子对屋脊型边缘的处理效果比较好,Log算子与Laplace算子的区别在于Log算子引入高斯函数,先对图像做平滑滤波处理。Hough变换对直线型的边缘提取效果较好,而对其他边缘提取效果不理想。附录1I=imread('Test.bmp');J=rgb2gray(I);figure(1),subplo
8、t(1,2,1),imshow(I),title('原始彩色图像');subplot(1,2,2),imshow(J),title('原始灰度图像');J1=edge(J,'Roberts');figure(1),sub
此文档下载收益归作者所有