Matlab数字图像处理12
合集下载
相关主题
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
12.1.4 开运算和闭运算
结构元素对的开运算,记作,定义为:
即首先采用结构元素对做腐蚀运算,然后再做膨胀运算,使用相同的结构 元素。 闭运算是开运算的对偶运算,记作,定义为:
即首先用结构元素对做膨胀运算,然后再做腐蚀运算,使用相同的结构元 素。
12.2 组合形态学运算
图像的膨胀和腐蚀是最基本的形态学运算。下面介绍组合形态学运算,主 要内容包括高帽滤波和低帽滤波、边界提取、区域填充等等。
12.1.1 基本概念
集合论是数学形态学的基础,首先对集合论的一些基本概念做一个简单介 绍。腐蚀运算和膨胀运算是数学形态学的两个基本变换。参加运算的对象 有两个:图像A(感兴趣目标)和结构集合B,B称为结构元素。结构元素 通常是个圆盘,但它其实可以是任何形状。 设和是的子集,则把图像沿矢量平移一段距离记作或,其定义为: 结构元素的映射为或,定义为: 的补集记作或,定义为: 两个集合和的差集记作,定义为: 对于两幅图像和,如果,则称击中,记作;否则,如果,则称击不中A。
12.3.5 二值图像的面积
面积是二值图像中像素值为1的像素的个数。在MATLAB软件中,采用函 数bwarea( )计算二值图像的面积。函数bwarea( )的调用格式为: total=bwarea(BW):该函数计算输入的二值图像BW的面积,返回值total为 得到的面积值。在计算二值图像的面积时,不是简单的计算像素值为1的 像素的个数,而是为每个像素设置一个权值,采用加权求和的方式得到面 积。
12.3 通过下面的程序建立灰度图像,通过编程来获取该图像的局部极大值。 close all; clear all; clc; I=20*ones(10, 10); I(3:3, 3:4)=35; I(5:7, 7:9)=43; I(2,8)=60
12.1 基本的形态学运算
数学形态学可以看作是一种特殊的数字图象处理方法和理论,主要以图象 的形态特征为研究对象。它通过设计一整套运算、概念和算法,用以描述 图象的基本特征。这些数学工具不同于常用的频域或空域算法,而是建立 在微分几何以及随机集论的基础之上的。数学形态学作为一种用于数字图 象处理和识别的新理论和新方法,它的理论虽然很复杂,但它的基本思想 却是简单而完美的。 数学形态学方法比其他空域或频域图像处理和分析方法具有一些明显的优 势。例如,基于数学形态学的边缘信息提取处理优于基于微分运算的边缘 提取算法,它不像微分算法对噪声那样敏感,提取的边缘比较光滑;利用 数学形态学方法提取的图像骨架也比较连续,断点少等;数学形态学易于 用并行处理方法有效的实现,而且硬件实现容易。
12.2.3 最大值和最小值
对于一幅图像可以有多个局部极大值或极小值,但只有一个最大值或最小 值。在MATLAB软件中,采用函数imregionalmax( )获取图像的所有局部极 大值,采用函数imregionalmin( )获取局部极小值。函数imregionalmax ( )的 调用格式为: BW=imregionalmax(I):该函数获取灰度图像I的局部极大值,返回值BW 为和原图像大小相同的二值图像,BW中元素1对应的是极大值,其它元素 值为0。 BW=imregionalmax(I, conn):该函数中参数conn为连通类型。对于二维图 像conn可以取值为4和8,默认值为8。对于三维图像,conn可取值为6、18 和26,默认值为26。
12.2.1 高帽滤波和低帽滤波
图像的形态学高帽滤波(top-hat filtering)定义为:
其中为输入的图像,为采用的结构元素,即从图像中减去形态学开操作后 的图像。通过高帽滤波可以增强图像的对比度。 图像的形态学低帽滤波(bottom-hat filtering)定义为:
其中为输入的图像,为采用的结构元素,即从图像中减去形态学闭操作后 的图像。通过低帽滤波可以获取图像的边缘。
12.2.4 图像的边界测定
对于灰度图像可以通过形态学的膨胀和腐蚀来获取图像的边缘。通过形态 学获取灰度图像的边缘的优点是对边缘的方向性依赖比较小。下面通过例 子程序进行说明。
12.2.5 二值图像的形态学操作
在MATLAB软件中,通过函数bwmorph( )可以进行二值图像的大量形态学 操作,例如图像的骨骼化、图像的细化,以及开操作和闭操作等等。该函 数的功能非常强大,读者可以查询MATLAB的帮助系统获取该函数的调用 格式。下面通过几个例子程序介绍该函数的功能。
习题
12.1 通过下面的程序建立一个二值图像,对该二值图像先进行膨胀,然后进 行腐蚀,观察结果并进行分析。 close all; clear all; clc; I=zeros(10, 10); I(3:5, 4:5)=1;
12.2 任意选择一幅灰度图像,然后对该图像进行高帽滤波,显示结果并进行 分析。
AB x : Bx A
12.1.3 膨胀与腐蚀
膨胀是将与物体接触的所有背景点合并到该物体中,使边界向外部扩张的 过程。通过膨胀,可以填充图像中的小孔,及在图像边缘处的小凹陷部分。 结构元素对图像的膨胀,记作,定义为:
腐蚀和膨胀是对偶操作。腐蚀是一种消除边界点,使边界向内部收缩的过 程。利用腐蚀操作,可以消除小且无意义的物体。集合被结构元素腐蚀, 记作,定义为:
12.3 二值图像的其他形态学操作
Biblioteka Baidu
图像的膨胀和腐蚀是最基本的形态学操作。下面介绍一些常用的形态学操 作,主要包括极限腐蚀、查表操作、图像的标记、对象的选择、图像的面 积和欧拉数等。
12.3.1 二值图像的极限腐蚀
在MATLAB软件中,采用函数bwulterode( )进行图像的极限腐蚀,每个对 象最后变为一个像素点为止。函数bwulterode( )的调用格式为: BW2=bwperim(BW1):该函数获取二值图像的边缘,返回值BW2是和原图 像大小相同的二值图像。 BW2=bwulterode(BW, method, conn):该函数中设置参数method,可取值 为euclidean、cityblock、chessboard和quasi-euclidean。对于二维图像,参 数conn可取值为4和8,默认值为8。对于三维图像,conn可取值为6、18和 26,默认值为26。
12.3.3 二值图像的标记
对于属于同一个像素连通区域的所有像素分配相同的编号,对不同的连通 区域分配不同的编号,称为连通区域的标记。在MATLAB中,采用函数 bwlabel( )和函数bwlabeln( )进行连通区域的标记操作。函数bwlabel( )只支 持二维的二值图像,函数bwlabeln( )支持任意维数的二值图像。函数 bwlabel( )的调用格式为: L=bwlabel(BW, n):该函数建对二值图像BW的连通区域进行标记,参数n 为连通类型,可取值为4和8,默认值为8,即8-连通。函数的返回值L为标 记矩阵,和原来的二值图像有相同的大小。 [L, num]=bwlabel(BW, n):该函数对二值图像BW进行标记,返回值num为 连通区域的数目。
12.2.2 图像填充操作
在MATLAB软件中,采用函数imfill( )对二值图像或灰度图像进行填充操 作。函数imfill( )的调用格式为: BW2=imfill(BW):该函数对二值图像BW进行填充操作,对于二维图像允 许用户通过鼠标选择填充的点。通过键盘上面的Backspace键或Delete键可 以取消当前选择的点,通过键盘上的Return键可以结束交互式的选择。 [BW2, locations]=imfill(BW):该函数中返回值locations包含了交互式选择 时的点的坐标。 BW2=imfill(BW, locations):该函数中通过参数locations指定了进行填充时 的点的坐标。 BW2=imfill(BW, ‘holes’):该函数通过参数holes可以填充二值图像中的 空洞。 I2=imfill(I):该函数对灰度图像进行填充操作,返回值I2也是灰度图像。
12.3.6 二值图像的欧拉数
在二值图像中,像素值为1的连通区域(对象)的个数减去孔数,所得的 差值为这幅图像的欧拉数。欧拉数测量的是图像的拓扑结构。在MATLAB 中,使用函数bweuler( )计算二值图像的欧拉数,该函数的调用格式为: eul=bweuler(BW, n):该函数计算输入的二值图像BW的欧拉数,参数n可 以为4和8,默认值为8,即8连通。
12.3.2 二值图像的查表操作
为了提高二值图像的处理速度,MATLAB软件提供了查表操作的相关函数。 查表操作适合处理2×2和3×3的邻域情况。在MATLAB软件中,函数 makelut( )用于建立表单,函数applylut( )用于查表操作。函数makelut( )的 调用格式为: lut=makelut(fun, n):该函数建立表单,其中参数fun为设定判断条件的函 数,n为邻域大小,可取值为2或3。 采用函数makelut( )建立表单后,可以采用函数applylut( )进行查表操作。 在MATLAB中,函数applylut( )的调用格式为: A=applylut(BW, LUT):该函数采用查表的方式对二值图像的邻域进行操 作,参数BW为二值图像,参数LUT为采用函数makelut( )建立的表单。返 回值A为查表操作后得到的二值图像。
第12章 形态学图像处理
形态学是一种应用于图像处理和模式识别领域的新的方法,是一门建立在 严格的数学理论基础上而又密切联系实际的科学。由于形态学具有完备的 数学基础,这为形态学用于图像分析和处理等奠定了坚实的基础。本章详 细的介绍利用MATLAB软件进行形态学图像处理,主要内容包括基本运算、 组合形态学运算以及二值图像的其他形态学运算等内容。
12.3.4 二值图像的对象选择
在MATLAB软件中,采用函数bwselect( )在二值图像中选择单个的对象, 要求图像必须是二维的。函数bwselect( )的调用格式为: BW2=bwselect(BW, c, r, n):该函数对输入的二值图像BW进行对象选择, 输入参数(c, r)为对象的像素点的位置,c和r的维数相同,参数n为对象的 连通类型,可取值为4和8。返回值BW2为选择了指定对象的二值图像,和 原图像有相同的大小。 BW2=bwselect(BW, n):该函数采用交互的方式,用户采用鼠标选择像素 点的位置。
12.1.2 结构元素
结构元素是膨胀和腐蚀的最基本组成部分,用于测试输入图像。二维结构 元素是由数值0和1组成的矩阵。结构元素的原点指定了图像中需要处理的 像素范围,结构元素中数值为1的点决定结构元素的领域像素在进行膨胀 或腐蚀操作时是否参与计算。 在MATLAB软件中,结构元素定义为一个STREL对象。如果nhood为结构 元素定义的领域,则任意大小和维数的结构元素的原点坐标为: origin=floor((size(nhood)+1)/2)。在MATLAB软件中,采用函数strel( )创建 任意大小和形状的STREL对象。函数strel( )支持常用的形状,例如线型 (line)、矩形(rectangle)、方形(square)、球形(ball)、钻石型 (diamond)和自定义的任意型(arbitrary)等。
12.4 本章小结
本章详细的介绍了利用形态学进行图像的处理和分析。首先详细的介绍了 形态学的基本概念和基本运算,包括膨胀、腐蚀、开运算和闭运算等。然 后详细介绍了利用形体学进行图像的处理,主要内容包括图像的填充、最 大值和最小值的获取、图像的边界测定以及二值图像的形态学分析。最后 介绍了形态学进行图像处理常用的操作,包括极限腐蚀、查表操作、图像 的标记、对象的选取、图像的面积和欧拉数等。