数字图像处理拓展资源 (3).pdf
《数字图像处理拓展资源 (3).pdf》由会员分享,可在线阅读,更多相关《数字图像处理拓展资源 (3).pdf(21页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、 拓展资源 1.2 MATLAB 与数字图像处理 1.2.1 MATLAB 简介 MATLAB 语言是由美国 MathWorks 公司推出的计算机软件,经过多年的逐步发展与不 断完善,现已成为国际公认的优秀的科学计算与数学应用软件之一,其内容涉及矩阵代数、 微积分、应用数学、有限元法、科学计算、信号与系统、神经网络、小波分析及其应用、数 字图像处理、计算机图形学、电子线路、电机学、自动控制与通信技术、物理、力学和机械 振动等方面。MATLAB 的特点是语法结构简单,数值计算高效,图形功能完备,特别受到以 完成数据处理与图形图像生成为主要目的的技术研发人员的青睐。各国的学生(包括硕士生 和博士生
2、)也将 MATLAB 作为必须掌握的基本程序设计语言。 MATLAB 中的基本数据结构是由一组有序的实数或复数元素构成的数组, 同样地, 图像 对象的表达采用的是一组有序的灰度或彩色数据元素构成的实值数组。 MATLAB 中通常用二 维数组来存储图像,数组的每个元素对应于图像的一个像素值。例如,由 200 行和 300 列的 不同颜色点组成的一幅图像在 MATLAB 中采用200300的矩阵存储。 MATLAB 支持多种类 型的图像,而不同类型的图像其存储结构通常是不同的,如 RGB 图像则需要一个三维数组, 3 个数据维分别对应于某像素点的红色、绿色和蓝色强度值。由于对图像采用了通用的数据
3、矩阵的表达方式,MATLAB 中原有的所有基本矩阵操作都可以应用于图像矩阵。 1.2.2 数字图像的表示和类别 一幅图像可以被定义为一个二维函数 f(x,y),其中 x 和 y 是空间(平面)坐标,f 在任何 坐标处(x,y)处的振幅称为图像在该点的亮度。灰度是用来表示黑白图像亮度的一个术语,而 彩色图像是由单个二维图像组合形成的。例如,在 RGB 彩色系统中,一幅彩色图像是由三 幅独立的分量图像(红、绿、蓝)组成的。因此,许多为黑白图像处理开发的技术适用于彩 色图像处理,方法是分别处理三幅独立的分量图像即可。 图像关于 x 和 y 坐标以及振幅连续。要将这样的一幅图像转化为数字形式,就要求数
4、字 化坐标和振幅。将坐标值数字化成为取样;将振幅数字化成为量化。采样和量化的过程如图 1.1 所示。因此,当 f 的 x、y 分量和振幅都是有限且离散的量时,称该图像为数字图像。 作为 MATLAB 基本数据类型的数值数组本身十分适于表达图像,矩阵的元素和图像的 像素之间有着十分自然的对应关系。 图 1.1 图像的采样和量化 根据图像数据矩阵解释方法的不同,MATLAB 把其处理为 4 类:亮度图像(Intensity images) 、二值图像(Binary images) 、索引图像(Indexed images) 、RGB 图像(RGB images) 。 (1)亮度图像 一幅亮度图像是
5、一个数据矩阵,其归一化的取值表示亮度。若亮度图像的像素都是 uint8 类或 uint16 类,则它们的整数值范围分别是0 255和0 65536。若图像的像素是 double 类, 则像素取值就是浮点数。规定双精度型归一化亮度图像的取值范围是0 1。 (2)二值图像 一幅二值图像是一个取值只有 0 和 1 的逻辑数组。而一幅取值只包含 0 和 1 的 uint8 类 数组,在 MATLAB 中并不认为是二值图像。使用 logical 函数可以把数值数组转化为二值数 组或逻辑数组。创建一个逻辑图像,其语法为: B=logical(A) 其中,B 是由 0 和 1 构成的数值数组。 要测试一个数
6、组是否为逻辑数组,可以使用函数: islogical(c) 若 C 是逻辑数组,则该函数返回 1;否则,返回 0。 (3)索引图像 索引颜色通常也称为映射颜色,在这种模式下,颜色都是预先定义的,并且可供选用的 一组颜色也很有限,索引颜色的图像最多只能显示 256 种颜色。 一幅索引颜色图像在图像文件里定义,当打开该文件时,构成该图像具体颜色的索引值 就被读入程序里,然后根据索引值找到最终的颜色。 (4)RGB 图像 一幅 RGB 图像就是彩色像素的一个 MN3 数组,其中每一个彩色相似点都是在特定 空间位置的彩色图像相对应的红、绿、蓝三个分量。按照惯例,形成一幅 RGB 彩色图像的 三个图像常
7、称为红、绿或蓝分量图像。 令 fR,fG 和 fB 分别代表三种 RGB 分量图像。一幅 RGB 图像就利用 cat(级联)操作 将这些分量图像组合成彩色图像: rgb_image=cat(3,fR,fG,fB) 在操作中,图像按顺序放置。 1.2.3 数据类和图像类型间的转化 表 1.1 中列出了 MATLAB 和 IPT 为表示像素所支持的各种数据类。 表中的前 8 项称为数 值数据类,第 9 项称为字符类,第 10 项称为逻辑数据类。 工具箱中提供了执行必要缩放的函数,如表 1.2 所示,以在图像类和类型间进行转化。 表 1.1 MATLAB 和 IPT 支持数据类型 序号 名称 描述
8、1 double 双精度浮点数,范围为-10308-10308 2 uint8 无符号 8bit 整数,范围为0 255 3 uint16 无符号 16bit 整数,范围为0 65536 4 uint32 无符号 32bit 整数,范围为0 4294967295 5 int8 有符号 8bit 整数,范围为-128 127 6 int16 有符号 16bit 整数,范围为-32768 32767 续表 序号 名称 描述 7 int32 有符号 32 比特整数,范围为-2147483648 2147483647 8 single 单精度浮点数,范围为-10308-10308 9 char 字符
9、10 logical 值为 0 或 1 表 1.2 格式转换函数 序号 名称 将输入转化为 有效的输入图像数据类 1 im2uint8 uint8 logical,uint8,uint16 和 doulbe 2 im2uint16 uint16 logical,uint8,uint16 和 doulbe 3 mat2gray double,范围为0 1 double 4 im2double double logical,uint8,uint16 和 doulbe 5 im2bw logical uint8,uint16 和 double 1.2.4 MATLAB7.0 图像处理工具箱 数字图像
10、研究的领域非常广泛,从学科上可以分为图像的数字化、图像变换、图像增强、 图像恢复、图像分割、图像分析和理解,以及图像的压缩等。 MATLAB 图像处理工具箱提供了非常丰富的图像处理函数,主要完成以下功能。 (1)图像的几何操作。 (2)图像的邻域和图像块操作。 (3)线性滤波和滤波器设计。 (4)图像变换。 (5)图像分析和增强。 (6)二值图像形态学操作。 (7)图像复原。 (8)图像编码。 (9)特定区域操作。 1.2.5 与图像处理相关的 MATLAB 函数的使用 1图像文件的读/写 (1)imread 函数用来实现图像文件的读取。 输入以下程序: A=imread(drum.bmp);
11、 %用 imread 函数来读入图像 imshow(A); %用 imshow 函数来显示图像 得到的结果如图 1.2 所示。 (2)imwrite 函数用来实现图像文件的写入。 输入以下程序: imwrite(A,drum.bmp); %可把图像文件 写入 MATLAB 的目录下 (3)imfinfo 函数用来查询图像文件信息。 输入以下程序: info=imfinfo(drum.bmp); %用 imfinfo 函数查询图像文件信息 得到: info = Filename: drum.bmp FileModDate: 05-Jan-2010 09:58:24 FileSize: 20669
12、4 Format: bmp FormatVersion: Version 3 (Microsoft Windows 3.x) Width: 273 Height: 252 BitDepth: 24 ColorType: truecolor FormatSignature: BM NumColormapEntries: 0 Colormap: RedMask: GreenMask: BlueMask: 图 1.2 drum.bmp 图像的显示 ImageDataOffset: 54 BitmapHeaderSize: 40 NumPlanes: 1 CompressionType: none B
13、itmapSize: 0 HorzResolution: 3780 VertResolution: 3780 NumColorsUsed: 0 NumImportantColors: 0 (4)imshow 函数用来显示图像。介绍 imread 函数时已使用此函数。 (5)colorbar 函数将颜色条添加到坐标轴对象中。 输入以下程序: RGB=imread(drum.png); %图像读入 I=rgb2gray(RGB); %把 RGB 图像转换成灰度图像 h=1 2 1;0 0 0;-1 -2 -1; I2=filter2(h,I); imshow(I2,),colorbar(vert)
14、 %将颜色条添加到坐标轴对象中 得到的结果如图 1.3 所示。 (6)warp 函数将图像作为纹理进行映射,使图像显示在一个特定的三维空间中。 输入以下程序: A=imread(drum.bmp); I=rgb2gray(A); x,y,z=sphere; warp(x,y,z,I); %用 warp 函数将图像作为纹理进行映射 得到的结果如图 1.4 所示。 图 1.3 由 RGB 图像转换成的灰度图像 图 1.4 映射图 (7)subimage 函数实现在一个图形窗口中显示多幅图像。 输入以下程序: RGB=imread(drum.bmp); I=rgb2gray(RGB); subplo
15、t(1,2,1),subimage(RGB) %subimage 函数实现在一个图形窗口中显示多 幅图像 subplot(1,2,2),subimage(I) 得到的结果如图 1.5 所示。 图 1.5 在一个窗口中显示多幅图像 2图像处理的基本操作 1)图像代数运算 (1)imadd 函数实现两幅图像的相加或者给一幅图像加上一个常数。 给图像每个像素都增加亮度的程序如下: I=imread(drum.bmp); J=imadd(I,100); %给图像增加亮度 subplot(1,2,1),imshow(I) subplot(1,2,2),imshow(J) 得到的结果如图 1.6 所示。
16、(a)原始图像 (b)增加亮度的图像 图 1.6 增加图像的亮度 (2)imsubtract 函数实现将一幅图像从另一幅图像中减去,或者从一幅图像中减去一个 常数。 实现从一幅图像中减去一个常数,输入以下程序: I=imread(drum.bmp); J=imsubtract(I,100); %给图像减少亮度 subplot(1,2,1),imshow(I) subplot(1,2,2),imshow(J) 得到的结果如图 1.7 所示。 (a)原始图像 (b)减少亮度的图像 图 1.7 减少图像的亮度 (3)immultiply 实现两幅图像的相乘或者一幅图像的亮度缩放。 输入以下程序: I
17、=imread(drum.bmp); J=immultiply(I,0.5); %对图像进行亮度缩放 subplot(1,2,1),imshow(I) subplot(1,2,2),imshow(J) 得到的结果如图 1.8 所示。 (a)原始图像 (b)亮度缩放的图像 图 1.8 缩放亮度图像(变暗) (4)imdivide 函数实现两幅图像的除法或一幅图像的亮度缩放。 输入以下程序: I=imread(drum.bmp); J=imdivide(I,0.5); %图像的亮度缩放 subplot(1,2,1),imshow(I) subplot(1,2,2),imshow(J) 得到的结果如
18、图 1.9 所示。 (a)原始图像 (b)亮度缩放的图像 图 1.9 缩放亮度图像(变亮) 2)图像的空间域操作 (1)imresize 函数实现图像的缩放。 输入以下程序: J=imread(drum.bmp); X1=imresize(J,2); %对图像进行缩放 figure,imshow(J) 得到的结果如图 1.10 所示。 (2)imrotate 函数实现图像的旋转。 输入以下程序: I=imread(drum.bmp); J=imrotate(I,45,bilinear); %对图像进行旋转 subplot(1,2,1),imshow(I); subplot(1,2,2),ims
19、how(J); (a)原始图像 (b)最近邻插值法 图 1.10 插值法变换图像(变小) 得到的结果如图 1.11 所示。 (a)原始图像 (b)采用双线性插值法的图像旋转(45 ) 图 1.11 插值法变换图像(旋转) (3)imcrop 函数实现图像的剪切。 输入以下程序: I=imread(drum.bmp); I2=imcrop(I,75 68 130 112); %对图像进行剪切 subplot(1,2,1),imshow(I); subplot(1,2,2),imshow(I2); 得到的结果如图 1.12 所示。 (a)原始图像 (b)剪切得到的图像 图 1.12 剪切变换图像
20、3)特定区域处理 (1)roipoly 函数用于选择图像中的多边形区域。 输入以下程序: I=imread(drum.bmp); c=200 250 278 248 199 172; r=21 21 75 121 121 75; BW=roipoly(I,c,r); %roipoly 函数选择图像中的多边形区域 subplot(1,2,1),imshow(I); subplot(1,2,2),imshow(BW); 得到的结果如图 1.13 所示。 (a)原始图像 (b)图像中的多边形区域 图 1.13 选择图像中的多边形区域 (2)roicolor 函数是对 RGB 图像和灰度图像实现按灰度
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数字图像处理拓展资源 3 数字图像 处理 拓展 资源
限制150内