《第十讲 图像处理精选PPT.ppt》由会员分享,可在线阅读,更多相关《第十讲 图像处理精选PPT.ppt(91页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、第十讲 图像处理第1页,此课件共91页哦 7.1 7.1 概述概述7.1.1 MATLAB7.1.1 MATLAB中的图像和图像处理工具箱中的图像和图像处理工具箱 MATLAB中大多数图像是用二维数组(矩阵)中大多数图像是用二维数组(矩阵)double(64位)浮点型,或位)浮点型,或uint8(8位无符号整数位无符号整数)、uint16(16位无符号整数位无符号整数)来存储的,矩阵中的每一来存储的,矩阵中的每一个元素对应图像中的一个像素个元素对应图像中的一个像素(pixel).例如:例如:l一幅由一幅由200行行300列不同灰度值的点组成的图像可以用列不同灰度值的点组成的图像可以用200X3
2、00的矩阵来存储。的矩阵来存储。l对于彩色图像,如对于彩色图像,如RGB图像,需要用三维数组来存储。图像,需要用三维数组来存储。第2页,此课件共91页哦7.1.2 MATLAB7.1.2 MATLAB中的图像类型中的图像类型二值图像二值图像(Binary):图像的取值为图像的取值为0或或1。索引图像索引图像(Indexed,pseudocolor):图像为图像为mXn矩阵,矩阵元素矩阵,矩阵元素的值指向颜色映像表的值指向颜色映像表(colormap)。灰度图像灰度图像(intensity,gray scale,gray level):图像为图像为mXn矩阵,矩阵元素的值指的是灰度值。对矩阵,矩
3、阵元素的值指的是灰度值。对single or double矩阵取值范围:矩阵取值范围:0,1,对,对 uint8矩阵取值范围:矩阵取值范围:0,255,对,对uint16矩阵取值范围:矩阵取值范围:0,65535,对,对int16矩阵取值范围:矩阵取值范围:-32768,32767。真彩色图像真彩色图像(RGB):图像为图像为mXnX3的矩阵。的矩阵。第3页,此课件共91页哦 二值图像二值图像(Binary)第4页,此课件共91页哦 索引图像索引图像(Indexed)第5页,此课件共91页哦 灰度图像灰度图像(Grayscale)第6页,此课件共91页哦 真彩色图像真彩色图像(Truecolo
4、r)第7页,此课件共91页哦gray2ind:Convert a grayscale image to an indexed image.grayslice:Convert a grayscale image to an indexed image using multilevel thresholding.im2bw:Convert a grayscale image,indexed image,or truecolor image,to a binary imageind2gray:Convert an indexed image to a grayscale image。7.1.3 MA
5、TLAB7.1.3 MATLAB中的图像类型之间的转换中的图像类型之间的转换第8页,此课件共91页哦ind2rgb:Convert an indexed image to a truecolor image.mat2gray:Convert a data matrix to a grayscale image,by scalingthe data.rgb2gray:Convert a truecolor image to a grayscale image.rgb2ind:Convert a truecolor image to an indexed image.第9页,此课件共91页哦im2
6、uint8 rgb2=im2uint8(rgb1)im2uint16im2int16im2singleim2double7.1.4 7.1.4 图像数据类型之间的转换图像数据类型之间的转换第10页,此课件共91页哦用用N N维数组来存储图像序列维数组来存储图像序列 mXnXp的数组表示的数组表示p个二维图像个二维图像7.1.5 7.1.5 图像序列图像序列mXnX3Xp 表示表示?第11页,此课件共91页哦MATLAB支持下列图像文件格式:支持下列图像文件格式:BMP(Microsoft Windows Bitmap 位图位图)HDF(Hierarchical Data Format 层次数据
7、层次数据)JPEG(Joint Photographic Expert Group 静止图像压缩静止图像压缩标准标准)PCX(Paintbrush 画刷格式画刷格式)PNG(Portable Network Graphics 可移植网络图像可移植网络图像)TIFF(Tagged Image File Format 标记图像文件标记图像文件)XWD(X Window Dump)GIF(Graphics Interchange Format 图形交换图形交换)7.1.5 7.1.5 图像文件格式图像文件格式第12页,此课件共91页哦 7.2 7.2 图像的读写和查询图像的读写和查询7.2.1 7.
8、2.1 图像文件的读取图像文件的读取A=imread(文件名,文件格式文件名,文件格式)X,map=imread(文件名,文件格式文件名,文件格式)l文件名必须在文件名必须在MATLAB的搜索路径范围内,否的搜索路径范围内,否则需要指出完整的路径。则需要指出完整的路径。RGB=imread(football.jpg);X,map=imread(trees.tif);第13页,此课件共91页哦 7.2 7.2 图像的读写和查询图像的读写和查询7.2.2 7.2.2 图像文件的写入图像文件的写入 imwrite(A,filename,fmt):写图像写图像A到文件名到文件名filename中,格式
9、为中,格式为fmtimwrite(X,map,filename,fmt):写索引图像写索引图像X和它和它相连的颜色映像表相连的颜色映像表map到文件名到文件名filename中,格式为中,格式为fmt 例如:例如:imwrite(A,myfile.jpg,Quality,100);写图像矩阵到文件名为写图像矩阵到文件名为myfile.jpg的文件中,参的文件中,参数数Quality,100是控制存入时压缩比的。是控制存入时压缩比的。第14页,此课件共91页哦 7.2 7.2 图像的读写和查询图像的读写和查询7.2.3 7.2.3 图像文件信息的查询图像文件信息的查询 info=imfinfo(
10、filename):从图像文件中查询其信息,从图像文件中查询其信息,包括文件名、路径、格式、版本号、文件修改时间、包括文件名、路径、格式、版本号、文件修改时间、文件大小、图像宽度和长度、每个像素的位数、图文件大小、图像宽度和长度、每个像素的位数、图像类型等。像类型等。例如:例如:info=imfinfo(football.jpg)第15页,此课件共91页哦 7.3 7.3 图像的显示图像的显示7.3.1 7.3.1 标准图像显示标准图像显示imshow(I,n)imshow(I,low high)imshow(X,map)参考参考MATLAB帮助帮助moon=imread(moon.tif);
11、imshow(moon);或者:或者:imshow(moon.tif);moon=getimage第16页,此课件共91页哦 7.3 7.3 图像的显示图像的显示7.3.2 7.3.2 图像的特殊显示技术图像的特殊显示技术添加颜色条添加颜色条显示多帧图像阵列显示多帧图像阵列多图的显示多图的显示纹理映射纹理映射 第17页,此课件共91页哦 7.3 7.3 图像的显示图像的显示7.3.2 7.3.2 图像的特殊显示技术图像的特殊显示技术添加颜色条添加颜色条 RGB=imread(saturn.png);I=rgb2gray(RGB);h=1 2 1;0 0 0;-1-2-1;I2=filter2(
12、h,I);imshow(I2,),colorbar第18页,此课件共91页哦 7.3 7.3 图像的显示图像的显示7.3.2 7.3.2 图像的特殊显示技术图像的特殊显示技术显示多帧图像阵列显示多帧图像阵列l多帧的单帧显示多帧的单帧显示l多帧的一次性显示多帧的一次性显示l将多帧阵列转化为电影将多帧阵列转化为电影 第19页,此课件共91页哦l多帧的单帧显示多帧的单帧显示 load mri imshow(D(:,:,:,7)l多帧的一次性显示多帧的一次性显示 load mri montage(D,map)l将多帧阵列转化为电影将多帧阵列转化为电影 load mri mov=immovie(D,ma
13、p);movie(mov)第20页,此课件共91页哦 7.3 7.3 图像的显示图像的显示7.3.2 7.3.2 图像的特殊显示技术图像的特殊显示技术多图的显示多图的显示 例例1.多幅图像在不同窗口显示多幅图像在不同窗口显示X1,map1=imread(forest.tif);X2,map2=imread(trees.tif);imshow(X1,map1),figure,imshow(X2,map2)第21页,此课件共91页哦 7.3 7.3 图像的显示图像的显示7.3.2 7.3.2 图像的特殊显示技术图像的特殊显示技术多图的显示多图的显示 例例2.多幅图像在同一窗口显示多幅图像在同一窗口
14、显示X1,map1=imread(forest.tif);X2,map2=imread(trees.tif);subplot(1,2,1),imshow(X1,map1)subplot(1,2,2),imshow(X2,map2)使用同一个颜色映像表,产生不能接受的显示结果,使用使用同一个颜色映像表,产生不能接受的显示结果,使用subimagesubimage可以改变这一情况可以改变这一情况第22页,此课件共91页哦 7.3 7.3 图像的显示图像的显示7.3.2 7.3.2 图像的特殊显示技术图像的特殊显示技术多图的显示多图的显示 例例3.多幅图像在同一窗口显示多幅图像在同一窗口显示X1,m
15、ap1=imread(forest.tif);X2,map2=imread(trees.tif);subplot(1,2,1),subimage(X1,map1)subplot(1,2,2),subimage(X2,map2)subimage在显示之前,将图像转换为真彩色,因此避免了在显示之前,将图像转换为真彩色,因此避免了colormap的共享问题。的共享问题。第23页,此课件共91页哦 7.3 7.3 图像的显示图像的显示7.3.2 7.3.2 图像的特殊显示技术图像的特殊显示技术纹理映射纹理映射:将图像显示在一个特定的参数曲面上将图像显示在一个特定的参数曲面上 warp:MATLAB中利
16、用插值算法将图像映射到曲面网中利用插值算法将图像映射到曲面网格上格上 例例.将将peppers.png图像纹理映射到圆柱面和球面图像纹理映射到圆柱面和球面 x,y,z=cylinder;I=imread(peppers.png);subplot(1,2,1),warp(x,y,z,I);x,y,z=sphere(50);subplot(1,2,2),warp(x,y,z,I);第24页,此课件共91页哦 7.4 7.4 图像的算术运算图像的算术运算图像的加法图像的加法 imadd图像的减法图像的减法 imsubtract图像的乘法图像的乘法 immultiply图像的除法图像的除法 imdiv
17、ide图像的补图像的补 imcomplement图像的绝对值的差图像的绝对值的差 imabsdiff图像的线性组合图像的线性组合 imlincomb 第25页,此课件共91页哦 7.4 7.4 图像的算术运算图像的算术运算I=imread(rice.png);I2=imread(cameraman.tif);K=imdivide(imadd(I,I2),2);%not recommendedK=imlincomb(.5,I,.5,I2);%recommended第26页,此课件共91页哦 7.5 7.5 图像的几何操作图像的几何操作图像的缩放图像的缩放 imresize图像的旋转图像的旋转 i
18、mrotate图像的剪裁图像的剪裁 imcrop图像的一般几何变换图像的一般几何变换 imtransform 第27页,此课件共91页哦 7.5.1 7.5.1 图像的插值运算图像的插值运算最近邻插值方法(最近邻插值方法(Nearest neighbor)双线性插值方法(双线性插值方法(Bilinear)双三次插值方法(双三次插值方法(Bicubic)第28页,此课件共91页哦 7.5.2 7.5.2 图像的缩放和旋转图像的缩放和旋转B=imresize(A,m,method)B=imresize(A,mrows ncols,method)I=imread(circuit.tif);J=imr
19、esize(I,1.25);imshow(I)figure,imshow(J)I=imread(circuit.tif);J=imresize(I,100 150,bilinear);imshow(I)figure,imshow(J)第29页,此课件共91页哦 7.5.2 7.5.2 图像的缩放和旋转图像的缩放和旋转B=imrotate(A,angle,method,crop)I=imread(circuit.tif);J=imrotate(I,35,bilinear);imshow(I)figure,imshow(J)如果:如果:J=imrotate(I,35,bilinear,crop);
20、结果的区别?结果的区别?第30页,此课件共91页哦 7.5.3 7.5.3 图像的剪裁图像的剪裁B=imcrop(A)B=imcrop(X,map)用户可以用鼠标选取区域,也可以在函数中定义图像的矩形用户可以用鼠标选取区域,也可以在函数中定义图像的矩形区域参数区域参数I=imread(circuit.tif);J=imcrop(I);figure,imshow(J)上面剪切图像上面剪切图像J也可以用:也可以用:J=imcrop(I,60 40 100 90);其中位置矢量表示为:其中位置矢量表示为:xmin ymin width height.第31页,此课件共91页哦 7.5.4 7.5.4
21、 图像的一般几何变换图像的一般几何变换B=imtransform(A,TFORM,INTERP)它根据变换结构(它根据变换结构(TFORM)变换二维图像)变换二维图像A,变换,变换结构结构TFORM是由是由maketform函数或函数或cp2tform函数返函数返回的,回的,INTERP可以取可以取nearest,bilinear(默认值默认值)或或bicubic第32页,此课件共91页哦 7.5.4 7.5.4 图像的一般几何变换图像的一般几何变换B=imtransform(A,TFORM,INTERP)I=imread(cameraman.tif);tform=maketform(affi
22、ne,1 0 0;0.5 1 0;0 0 1);J=imtransform(I,tform);imshow(J),figure,imshow(J)第33页,此课件共91页哦 7.6 7.6 图像的线性滤波图像的线性滤波滤波滤波是一种图像修正或增强技术。可以突出图像的某些特征,是一种图像修正或增强技术。可以突出图像的某些特征,也可以删除另一些特征。也可以删除另一些特征。图像滤波图像滤波的本质是一种邻域操作,输出图像的任一个像素值都是通的本质是一种邻域操作,输出图像的任一个像素值都是通过输入图像对应的像素邻域内的像素值利用一定的算法得到的。过输入图像对应的像素邻域内的像素值利用一定的算法得到的。图
23、像的线性滤波图像的线性滤波就是输出图像任一个像素值都是通过输入图像对就是输出图像任一个像素值都是通过输入图像对应的像素邻域内的像素值应的像素邻域内的像素值线性组合线性组合得到的。得到的。图像的线性滤波是通过卷积来完成的。图像的线性滤波是通过卷积来完成的。第34页,此课件共91页哦 7.6 7.6 图像的线性滤波图像的线性滤波二维卷积函数二维卷积函数 conv2滤波函数滤波函数 filter2图像滤波图像滤波 imfilter预定义滤波器预定义滤波器 fspecial 第35页,此课件共91页哦7.6.1 二维卷积函数二维卷积函数 conv2 A=17 24 1 8 15 23 5 7 14 1
24、6 4 6 13 20 22 10 12 19 21 3 11 18 25 2 9 h=8 1 6 3 5 7 4 9 2 C=conv2(A,h)第36页,此课件共91页哦卷积步骤:卷积步骤:1.关于卷积核的中心,旋转卷积核关于卷积核的中心,旋转卷积核180度。度。2.滑动卷积核,将卷积核的中心位于图像矩阵的每滑动卷积核,将卷积核的中心位于图像矩阵的每一个元素。一个元素。3.将旋转后的卷积核作为权重,乘以对应的矩阵元素将旋转后的卷积核作为权重,乘以对应的矩阵元素4.求加权和求加权和第37页,此课件共91页哦计算卷积输出计算卷积输出(2,4)第38页,此课件共91页哦C=conv2(A,B)C
25、=conv2(A,B,shape)A:输入图像,输入图像,B:卷积核,:卷积核,C:输出图像,若:输出图像,若A大小为大小为mana,B大小为大小为mbnb,则则C大小为(大小为(ma+mb-1)(na+nb-1)shape指定卷指定卷积积运算的范运算的范围围:shape=full(the default),返回全部二返回全部二维维卷卷积结积结果果shape=same,返回与返回与A同同样样大小的卷大小的卷积积中心部分中心部分shape=valid,不考不考虑边虑边界界补补零,返回零,返回C大小大小为为(ma-mb+1)(na-nb+1)第39页,此课件共91页哦7.6.2 相关运算实现滤波:
26、相关运算实现滤波:filter2相关运算相关运算(correlation)n滑动相关核,将相关核的中心位于图像矩阵的每滑动相关核,将相关核的中心位于图像矩阵的每一个元素。一个元素。n将相关核作为权重,乘以对应的矩阵元素将相关核作为权重,乘以对应的矩阵元素n求加权和求加权和用相关运算实现滤波的函数是用相关运算实现滤波的函数是filter2B=filter2(h,A)第40页,此课件共91页哦计算相关输出计算相关输出(2,4)第41页,此课件共91页哦7.6.3 图像的线性滤波图像的线性滤波nimfilternB=imfilter(A,H,option1,option2,)A:多维图像阵列,多维图
27、像阵列,H:多维滤波器,多维滤波器,option1,option2决定边缘上的处理方法,输出图像大小,决定边缘上的处理方法,输出图像大小,采用与采用与filter2相同的方法还是卷积的方法。相同的方法还是卷积的方法。第42页,此课件共91页哦例:利用例:利用imfilter函数实现均值滤波函数实现均值滤波 I=imread(coins.png);h=ones(5,5)/25;I2=imfilter(I,h);imshow(I),title(Original Image);figure,imshow(I2),title(Filtered Image)第43页,此课件共91页哦imfilter输入
28、输出的数据类型是一样的输入输出的数据类型是一样的A=magic(5)h=-1 0 1;imfilter(A,h)可以看到输出有负值,所以有时候在可以看到输出有负值,所以有时候在imfilter 前用类型转换,避前用类型转换,避免这种情况。免这种情况。A=uint8(magic(5)imfilter(A,h)第44页,此课件共91页哦option:相关和卷积相关和卷积nimfilter既可以用相关,也可以用卷积实现滤波操作,既可以用相关,也可以用卷积实现滤波操作,缺省是相关。缺省是相关。A=magic(5);h=-1 0 1imfilter(A,h)%filter using correlati
29、onimfilter(A,h,conv)%filter using convolution第45页,此课件共91页哦option:边界补零边界补零(zero-padding)和边界复和边界复制制(border replication)n边界补零边界补零(zero-padding):缺省缺省第46页,此课件共91页哦option:边界补零边界补零(zero-padding)和边界和边界复制复制(border replication)n边界补零边界补零(zero-padding):缺省缺省I=imread(eight.tif);h=ones(5,5)/25;I2=imfilter(I,h);ims
30、how(I),title(Original Image);figure,imshow(I2),title(Filtered Image with Black Border)缺点:滤波得到的图像边缘有一个缺点:滤波得到的图像边缘有一个dark band第47页,此课件共91页哦option:边界补零边界补零(zero-padding)和边界复制和边界复制(border replication)n边界复制边界复制(border replication)第48页,此课件共91页哦option:边界补零边界补零(zero-padding)和边界复和边界复制制(border replication)n边
31、界复制边界复制(border replication)I3=imfilter(I,h,replicate);figure,imshow(I3);title(Filtered Image with Border Replication)imfilter还有其他的边界补充选项,参考还有其他的边界补充选项,参考imfilter的帮助的帮助第49页,此课件共91页哦多维滤波多维滤波nimfilter既可以处理多维图像,也可以处理多维滤波器。用既可以处理多维图像,也可以处理多维滤波器。用一个二维滤波器对一个三维图像滤波,相当于对三维图像一个二维滤波器对一个三维图像滤波,相当于对三维图像的每个平面进行二维
32、滤波。的每个平面进行二维滤波。例例:用同样的滤波器对一个真彩色图像的每个颜色平面进:用同样的滤波器对一个真彩色图像的每个颜色平面进行滤波。行滤波。第50页,此课件共91页哦%Read in an RGB image and display itrgb=imread(peppers.png);imshow(rgb);%Filter the image and display it.h=ones(5,5)/25;rgb2=imfilter(rgb,h);figure,imshow(rgb2)第51页,此课件共91页哦imfilter与与filter2、conv2的关系:的关系:nfilter2、c
33、onv2、convn:将输入转换为将输入转换为double类型,类型,输出也是输出也是double的,输入总是补零(的,输入总是补零(zero padded),不不支持其他的边界补充选项。支持其他的边界补充选项。nimfilter:不将输入转换为不将输入转换为double,输出只与输入,输出只与输入同类型,有灵活的边界补充选项同类型,有灵活的边界补充选项第52页,此课件共91页哦7.6.4 预定义滤波器预定义滤波器h=fspecial(type,parameters)例:应用例:应用“unsharp masking”滤波器对图像进行滤波滤波器对图像进行滤波I=imread(moon.tif);
34、h=fspecial(unsharp);I2=imfilter(I,h);imshow(I),title(Original Image)figure,imshow(I2),title(Filtered Image)关于关于fspecial的参数选择参见的参数选择参见help第53页,此课件共91页哦7.7 7.7 图像的变换图像的变换n图像的一般数学表示是用两个空域变量的函数表示,图像的一般数学表示是用两个空域变量的函数表示,(x,y)表示一个特定点的位置,表示一个特定点的位置,f(x,y)表示表示(x,y)处处的图像灰度值。的图像灰度值。n图像的变换就是把图像表达成另一种表示方法。例如傅图像
35、的变换就是把图像表达成另一种表示方法。例如傅立叶变换是把图像表示为变化的频率、相位和振幅的复立叶变换是把图像表示为变化的频率、相位和振幅的复指数的和,这就是频率域。指数的和,这就是频率域。n图像的变换在图像的分析、增强、特征提取、图图像的变换在图像的分析、增强、特征提取、图像压缩等许多领域被广泛应用。像压缩等许多领域被广泛应用。第54页,此课件共91页哦7.7 7.7 图像的变换图像的变换n傅立叶变换傅立叶变换(Fourier Transform)n离散余弦变换离散余弦变换(Discrete Cosine Transform)第55页,此课件共91页哦7.7.1 傅立叶变换傅立叶变换(Four
36、ier Transform)f(m,n)是一个二维离散空域变量是一个二维离散空域变量(m,n)的函数,那么的函数,那么f(m,n)的二维的二维离散傅立叶离散傅立叶(DFT)定义为:定义为:二维离散傅立叶的逆变换二维离散傅立叶的逆变换(IDFT)为:为:第56页,此课件共91页哦7.7.1 傅立叶变换傅立叶变换(Fourier Transform)二维离散傅立叶二维离散傅立叶(DFT)变换的系数:变换的系数:第57页,此课件共91页哦离散傅立叶离散傅立叶(DFT)的计算:的计算:nfft、fft2、fftn:分别实现一维、二维和:分别实现一维、二维和n维离散快速傅立叶变换维离散快速傅立叶变换(D
37、FT)nifft、ifft2、ifftn:分别实现一维、二维:分别实现一维、二维和和n维离散快速傅立叶逆变换维离散快速傅立叶逆变换(IDFT)第58页,此课件共91页哦例:图像傅立叶变换和幅值例:图像傅立叶变换和幅值1.产生图像矩阵,包括一个矩形区域产生图像矩阵,包括一个矩形区域f=zeros(30,30);f(5:24,13:17)=1;imshow(f,InitialMagnification,fit)2.计算和显示计算和显示f的傅立叶变换的傅立叶变换F=fft2(f);F2=log(abs(F);figure,imshow(F2,-1 5,InitialMagnification,fit
38、);colormap(jet);colorbar第59页,此课件共91页哦第60页,此课件共91页哦上图:傅立叶变换的取样很粗,且零频率系数不像传上图:傅立叶变换的取样很粗,且零频率系数不像传统的那样显示在图像中心,而是显示在左上角。统的那样显示在图像中心,而是显示在左上角。为获得傅立叶变换较精细的取样,采用补零的方法。为获得傅立叶变换较精细的取样,采用补零的方法。3.补零和计算补零和计算f的傅立叶变换的傅立叶变换F=fft2(f,256,256);F2=log(abs(F);figure,imshow(F2,-1 5,InitialMagnification,fit);colormap(je
39、t);colorbar第61页,此课件共91页哦4.将零频系数移动到图像中心将零频系数移动到图像中心F=fft2(f,256,256);F2=fftshift(F);figure,imshow(log(abs(F2),-1 5,InitialMagnification,fit);colormap(jet);colorbar第62页,此课件共91页哦傅立叶变换的应用:傅立叶变换的应用:n线性滤波器的频率响应线性滤波器的频率响应线性滤波器的脉冲响应的傅立叶变换给出该滤波器线性滤波器的脉冲响应的傅立叶变换给出该滤波器的频率响应。的频率响应。freqz2计算和显示滤波器的频率计算和显示滤波器的频率响应
40、。响应。例:显示高斯滤波器的频率响应例:显示高斯滤波器的频率响应h=fspecial(gaussian);freqz2(h)第63页,此课件共91页哦傅立叶变换的应用:傅立叶变换的应用:n快速卷积快速卷积两个空域函数卷积的傅立叶变换等于这两个函数傅立两个空域函数卷积的傅立叶变换等于这两个函数傅立叶变换的乘积。叶变换的乘积。例:例:A=magic(3);B=ones(3);A(8,8)=0;B(8,8)=0;C=ifft2(fft2(A).*fft2(B);C=C(1:5,1:5);C=real(C)第64页,此课件共91页哦傅立叶变换的应用:傅立叶变换的应用:n图像特征识别图像特征识别例:在一
41、幅包含文字的图像中查找字母例:在一幅包含文字的图像中查找字母a1、Read in the sample imagebw=imread(text.png);2、Create a template for matching by extracting the letter a from the imagea=bw(32:45,88:98);imshow(bw);figure,imshow(a);第65页,此课件共91页哦第66页,此课件共91页哦傅立叶变换的应用:傅立叶变换的应用:n3、Compute the correlation of the template image with the o
42、riginal image by rotating the template image by 180o and then using the FFT-based convolution techniqueC=real(ifft2(fft2(bw).*fft2(rot90(a,2),256,256);figure,imshow(C,)%Scale image to appropriate display range.第67页,此课件共91页哦第68页,此课件共91页哦傅立叶变换的应用:傅立叶变换的应用:n4、find the maximum pixel value and then defin
43、e a threshold value that is less than this maximum.The locations of these peaks are indicated by the white spots in the thresholded correlation image.max(C(:)ans=68.0000thresh=60;%Use a threshold thats a little less than max.figure,imshow(C thresh)%Display showing pixels over threshold.第69页,此课件共91页哦
44、第70页,此课件共91页哦7.7.2 离散余弦变换离散余弦变换(Discrete Cosine Transform)n通常对于一幅图像的通常对于一幅图像的DCT,其重要的可视信息集中,其重要的可视信息集中在在DCT的少数系数上。正是基于这一特性,的少数系数上。正是基于这一特性,DCT经经常被用于图像压缩应用。例如,常被用于图像压缩应用。例如,DCT是国际标准有是国际标准有损图像压缩算法损图像压缩算法JPEG的核心。的核心。第71页,此课件共91页哦7.7.2 离散余弦变换离散余弦变换(Discrete Cosine Transform)n一个一个MN矩阵矩阵A的的DCT定义为:定义为:第72页
45、,此课件共91页哦7.7.2 离散余弦变换离散余弦变换(Discrete Cosine Transform)nDCT的逆变换:的逆变换:第73页,此课件共91页哦7.7.2 离散余弦变换离散余弦变换(Discrete Cosine Transform)nMATLAB中计算中计算DCT:1.dct2函数函数2.使用使用dct变换矩阵,由变换矩阵,由dctmtx返回返回第74页,此课件共91页哦7.7.2 离散余弦变换离散余弦变换(Discrete Cosine Transform)nMATLAB中计算中计算DCT:1.dct2,idct2函数函数2.使用使用dct变换矩阵,由变换矩阵,由dctm
46、tx返回返回第75页,此课件共91页哦 7.8 图像分析和增强图像分析和增强7.8.1 图像的像素值及其统计图像的像素值及其统计1、提供特定像素的数据值(灰度值或颜色值)、提供特定像素的数据值(灰度值或颜色值)npixval:交互显示像素数据值:交互显示像素数据值 imshow canoe.tif pixvalnimpixel:返回被选中点或选中区域像素的数据值,用:返回被选中点或选中区域像素的数据值,用户可在参数中提供像素坐标,也可通过鼠标选取。户可在参数中提供像素坐标,也可通过鼠标选取。imshow canoe.tif vals=impixel第76页,此课件共91页哦 7.8 图像分析和
47、增强图像分析和增强7.8.1 图像的像素值及其统计图像的像素值及其统计2、图像像素值剖面图形、图像像素值剖面图形nimprofile:沿着图像中一条直线或折线段计算和绘制:沿着图像中一条直线或折线段计算和绘制图像像素值的图形。图像像素值的图形。C=improfileC=improfile(I,xi,yi)imshow peppers.png improfile第77页,此课件共91页哦 7.8 图像分析和增强图像分析和增强7.8.1 图像的像素值及其统计图像的像素值及其统计3、图像轮廓图、图像轮廓图nimcontour:显示一幅灰度图像的轮廓图。:显示一幅灰度图像的轮廓图。I=imread(r
48、ice.png);imshow(I)figure,imcontour(I,3)第78页,此课件共91页哦 7.8 图像分析和增强图像分析和增强7.8.1 图像的像素值及其统计图像的像素值及其统计4、图像直方图、图像直方图nimhist:显示灰度图像或索引图像的灰度分布,创建:显示灰度图像或索引图像的灰度分布,创建图形窗口绘制出每一灰度级对应像素个数的图形窗口绘制出每一灰度级对应像素个数的 柱状图。柱状图。I=imread(rice.png);imshow(I)figure,imhist(I)第79页,此课件共91页哦 7.8 图像分析和增强图像分析和增强7.8.1 图像的像素值及其统计图像的像
49、素值及其统计5、样本统计量和有关区域属性的一些量、样本统计量和有关区域属性的一些量n标准的图像统计函数标准的图像统计函数:mean2 std2 corr2分别计算图分别计算图像矩阵元素的均值、标准差和两个相同矩阵的相关系数。像矩阵元素的均值、标准差和两个相同矩阵的相关系数。n选定图像区域的有关属性:选定图像区域的有关属性:regionprops参看参看help第80页,此课件共91页哦 7.8 图像分析和增强图像分析和增强7.8.2 图像分析(提取图像的结构信息)图像分析(提取图像的结构信息)n边缘检测边缘检测edge:检测图像边缘。检测图像边缘。BW=edge(I,method,thresh
50、)参看参看help第81页,此课件共91页哦I=imread(coins.png);imshow(I)BW1=edge(I,sobel);BW2=edge(I,canny);imshow(BW1)figure,imshow(BW2)第82页,此课件共91页哦 7.8 图像分析和增强图像分析和增强7.8.3 图像的灰度值调整(改善图像质量)图像的灰度值调整(改善图像质量)n灰度调整灰度调整imadjust:检测图像边缘。检测图像边缘。J=imadjust(I,low_in high_in,low_out high_out,gamma)参看参看help第83页,此课件共91页哦X,map=imre