[转载]MATLAB 图像处理命令

原文地址:MATLAB 图像处理命令作者:easleyhux

1.MATLAB中图像处理的一些简单函数

A、 imread

imread函数用于读入各种图像文件,其一般的用法为

[X,MAP]=imread(‘filename’,‘fmt’)

其中,X,MAP分别为读出的图像数据和颜色表数据,fmt为图像的格式,filename为读取的图像文件(可以加上文件的路径)。

例:[X,MAP]=imread(’flowers.tif’,’tif’);

比较读取二值图像,灰度图像,索引图像,彩色图像的X和MAP的特点,可以利用size函数用来显示数组的维数,了解数据的特点。

B=size(a) 返回数组a 的维数。

B、 imwrite

imwrite函数用于输出图像,其语法格式为:

imwrite(X,map,filename,fmt)

imwrite(X,map,filename,fmt)按照fmt指定的格式将图像数据矩阵X和调色板map写入文件filename。

C、 imfinfo

imfinfo函数用于读取图像文件的有关信息,其语法格式为

imfinfo(filename,fmt)

imfinfo函数返回一个结构info,它反映了该图像的各方面信息,其主要数据包括:文件名(路径)、文件格式、文件格式版本号、文件的修改时间、文件的大小、文件的长度、文件的宽度、每个像素的位数、图像的类型等。

2.MATLAB中图像文件的显示

imshow

imshow函数是最常用的显示各种图像的函数,其语法如下:

imshow(X,map)

其中X是图像数据矩阵,map是其对应的颜色矩阵,若进行图像处理后不知道图像数据的值域可以用[]代替map。

(1) 二进制(二值)图像显示方法,在MATLAB中一幅二值图像是uint8或双精度的,该矩阵仅包含0和1。如果希望工具箱中的函数能将图像理解为二进制的,那么所有数据都要是逻辑数据,必须对其进行设置(将所有数据标志均设置on).可以对数据利用“~”取反操作实现图像逆转即黑白反色。

(2) 灰度图像的显示方法,正常情况下无需指定灰度图像的调色板格式。可以是使用imshow函数指定要显示灰度级数目,格式 imshow(I,n),n为指定的灰度级数目。用户也可以指定数据的范围,格式imshow(I,[low high])其中low 和high参数分别为数据数组的最小值和最大值。如果为空矩阵([]),那么imshow函数将自动进行数据标度。

(3) 索引图像,imshow(x,map)对于x的每个个像素,imshow显示存储map中相应行的颜色。

(4) RGB图像的显示,它直接对颜色进行描述而不使用调色板,格式imshow(RGB)。 RGB(:,:,1) RGB(:,:,2)   RGB(:,:,3)

(5) 特殊显示,如多幅图像的显示,需要显示多幅图像时。可以使用figure语句,它的功能就是重新打开一个图像显示窗口。例:

I=imread(‘rice.tif’);

Imshow(I);

J=imread(‘flowers.tif’);

figure,imshow(J);

也可以将多幅图像显示在同一个单独的图像窗口中,有两种方法:一种是联合imshow和subplot函数;另一种是联合使用subimage函数和subplot函数,subplot(m,n,p)这种格式将图形窗口划分为m*n个矩形显示区域并激活第p个显示区域。

A

[x1,map1]=imread(\'trees.tif\');

[x2,map2]=imread(\'forest.tif\');

subplot(1,2,1),imshow(x1,map1)

subplot(1,2,2),imshow(x2,map2)

B

[x1,map1]=imread(\'trees.tif\');

[x2,map2]=imread(\'forest.tif\');

subplot(1,2,1),subimage(x1,map1)

subplot(1,2,2),subimage(x2,map2)

3.MATLAB中灰度直方图的显示

MATLAB图像处理工具箱提供了imhist函数来计算和显示图像的直方图,imhist函数的语法格式为:

imhist(I,n)

imhist(X,map)

其中imhist(I,n)计算和显示灰度图像I的直方图,n为指定的灰度级数目,默认值为256。imhist(X,map)计算和显示索引色图像X的直方图,map为调色板。

例:

I = imread(\'rice.tif\');

imshow(I)

figure, imhist(I)

4.对比度增强

如果原图像f(x,y)的灰度范围是[m,M],我们希望调整后的图像g(x,y)的灰度范围是[n,N],那么下述变换, ,就可以实现这一要求。

MATLAB图像处理工具箱中提供的imadjust函数,可以实现上述的线性变换对比度增强。Imadjust函数的语法格式为:

J = imadjust(I,[low_in high_in],[low_out high_out])

J = imadjust(I,[low_in high_in],[low_out high_out])返回图像I经过直方图调整后的图像J,[low_in high_in]为原图像中要变换的灰度范围,[low_out high_out]指定了变换后的灰度范围。其详细的用法可参见《计算机图像处理与识别技术》。

例:

I = imread(\'pout.tif\');

J = imadjust(I,[0.3 0.7],[]);

imshow(I), figure, imshow(J)

5.图像类型转换:

图像类型之间的转换有时非常有用。MATLAB提供的图像类型转换函数

函数

功能

dither

使用抖动方法,根据灰度图像船舰二进制图像和根据RGB图像创建索引图像

 gray2ind

根据一幅灰度图像创建索引图像

 grayslice

使用阈值截取方法,根据一幅灰度图像创建索引图像

 im2bw

使用阈值截取方法,根据一幅灰度图像,索引图像或RGB图像创建二进制图像

 ind2gray

根据一幅索引图像创建一幅灰度图像

 ind2rgb

根据一幅索引图像创建一幅RGB图像

 mat2gray

通过数据缩放,在根据矩阵数据创建一幅灰度图像

 rgb2gray

根据一幅RGB图像创建一幅灰度图像

 rgb2ind

根据一幅RGB图像创建一幅索引图像

上表中函数有类似的调用格式:函数的输入参数是图像数据矩阵(如果是索引图像,那么输入参数还包括调色板),返回值是转换后的函数(包括索引函数的调色板),只有函数im2bw的调用格式不同,其输入参数中还包括一个截取阈值,超过此阈值的像素被截取为1否则为0。示例:

A、load trees

BW = im2bw(X,map,0.4);

imview(X,map),imview(BW)

B、

I = imread(\'snowflakes.png\');

X = grayslice(I,16);

imview(I)

imview(X,jet(16))

6.MATLAB还提供了图像存储类型之间的转换函数

这些函数包含im2doble、im2uint8和 im2uint16,这些函数可以自动的进行原始数据的重新标度和偏移.调用格式简单,输入为图像矩阵,输出为转换后的图像:如:以下命令将一个描述双精度RGB1图像的矩阵(数据范围为[0,1]转换为uint8的图像矩阵([0,255]范围内)RGB2=im2uint8(rgb1);也可以使用MATLAB函数对图像存储类型进行转换。例如,double函数可以将uint8或 uint16的数据转化为双精度数据。存储类型之间的转变将改变matlab及其工具箱理解图像数据的方式,如果用户希望转换后得到的数组能够被正确的理解为图像数据,那么转换时需要重新标度或偏移数据。当使用较少的类型来描述数字图像时,通常可能丢失用户图像的一些信息。

7.图像格式之间的转换

可以间接利用图像读写函数来完成;首先使用imread函数按照原有的图像格式进行图像读取,然后调用imwrite函数对图像进行保存,并指定图像的保存格式。如将BMP格式转换为PNG格式,

  bitmap=imread(‘mybitmap,bmp’,’bmp’)

  imwrite(‘mybitmap,png’,’png’)

matlab图像处理命令

二值图像操作

色图操作

brighten 亮/暗色图

cmpermute 色图中颜色的重排

colormap 设置色图

imapprox 以较少的颜色来近似索引图像

rgbplot 绘制RGB色图

色彩空间变换

hsv2rgb 饱和色彩色图HSV向红绿蓝色图RGB转换

ntsc2rgb 将NTSC制式值转换到RGB颜色空间

rgb2hsv RGB色图M向HSV色图cmap转换

rgb2ntsc 将RGB颜色空间转换到NTSC制式

rgb2ycbcr 将RGB颜色空间转换到YCBCR颜色空间

ycbcr2rgb 将YCBCR颜色空间转换到RGB颜色空间

图像类型判断及其转换

dither 用抖动法(dithering)转换图像

gray2ind 灰度图像向索引图像转换

grayslice 设定阀值将灰度图转换为索引图

isbw 图像为二值图像则返回真

isgray 图像为灰度图像则返回真

isind 图像为索引图像则返回真

isrgb 图像为RGB图像则返回真

im2bw 设定阀值将图像转换为值维图像

im2double 将图像数据阵列转换为double型

im2uint8 将图像数据阵列转换为uint8型

im2uint16 将图像数据阵列转换为uint16型

ind2gray 索引图像向灰度图像转换

ind2rgb 索引图像向RGB图像转换

mat2rgb 将矩阵转换为灰度图

rgb2gray RGB图像向灰度图转换

rgb2ind RGB图像向索引图像转换

图像处理演示函数

dctdemo 二维DCT图像压缩演示

edgedemo 边缘检测演示

firdemo 二维FIR滤波及滤波器演示

imadjdemo 灰度及调整和直方图均衡演示

landsatdemo 陆地卫星颜色合成演示

nrfiltdemo 噪声消除滤波演示

qtdemo 四叉树分解演示

roidemo 特定区域处理演示

图像分析

edge 得到加强图像的边缘

qtdecomp 四叉树分解

qtgetblk 得到四叉树分解的块值

qtsetblk 调整四叉树分解的块值

图像增强

histeq 自动调整直方图

imadjust 灰度级调整

imnoise 引入各种类型的噪声

medfilt2 中值滤波

ordfilt2 执行二维阶统计滤波

wiener2 维纳滤波器的二维滤波

线性滤波

conv2 图像卷积

convmtx2 计算二维卷积矩阵

convn 图像的n 维卷积

filter2 二维线性滤波

fspecial 产生预定义的滤波器

medfilt2 中值滤波

wiener2 维纳滤波器的二维滤波

二维线性滤波器的设计

filter2二维线性滤波

fspecial 产生预定义的滤波器

fsample 生成滤波器

freqz2 计算二维滤波器的频率响应

fsamp2 二维FIR滤波器的频率采样设计

fwind1 由用户自定义的两个一维窗口生成一个二维窗口滤波器

fwind2 由一个已知的二维窗口直接生成一个二维滤波器

hamming 创建一个一维窗口

freqspace 生成合适的频率点阵矩阵

ftrans2 频率变换

图像变换

dct 离散余弦变换

dct2 计算二维离散余弦变换

dctmtx 计算离散余弦变换矩阵

dctmtx2 计算二维离散余弦变换矩阵

dctdemo 二维离散余弦变图像压缩矩阵

fft2 得到二维FFT的结果

fftn N维FFT变换

fftshiftn FFT变换结果的逆象限

iradon Radon逆变换

idct 离散余弦离散余弦变换的逆变换

idct2 计算二维离散余弦离散余弦变换的逆变换

radon Radon变换

邻域及块处理

blkproc 执行分块操作

bestblk 选择用于块处理的块尺寸

col2im 对矩阵的列进行块重排

colfilt 利用列式函数进行邻域操作

im2col 将图像块按列重排

nlfilter 执行常规滑动邻域操作

图像的区域处理

rolpoly 选定多边形形状的特定区域

roifilt2 对图像特定区域进行滤波

roifill 指定区域的快速插值

roicolor 根据颜色进行

图像显示

colorbar 对图像增加颜色条

figure 在不同的图像窗口显示不同的图像

getimage 从轴上得到图像数据

montage 多贞图像一次显示

image 显示图像

imagesc 显示亮度图像

imcontour 显示一幅图画的轮廊图

immovie 多帧图像转换为电影

imshow 显示各类图像

subimage 在一幅图形窗口中显示多个图像

subplot 在同一个图形窗口中显示多图

truesize 调整图像显示的大小

warp 纹理乘图功能

zoom 图像的区域缩放

图像文件数据输入/输出

imfinfo 查询图像文件信息

imread 从图像文件中读数据

imwrite 将数据写入到图像文件中

图像的几何操作

imcrop 裁剪余弦中的一部分

interp2 二维数据插补

imresize 同于改变图像尺寸

imrotate 用于进行图像的旋转

像值与统计

corr2 计算尺寸相同的两个图像矩阵的相关系数

applylut 利用查找表执行邻域操作

bwarea 返回一幅二值图像的面积

bweuler 对图像的拓扑结构的测量

bwfill 进行区域的填充

bwlabel 对图像中不同目标进行标注

bwmorph 一系列的膨胀与腐蚀操作

bwperim 决定二值图像中目标对象的轴长

bwselect 对目标进行操作

dilate 二值图像的膨胀

erode 二值图像的腐蚀

makelut 创建查找表

http://blog.sina.com.cn/s/blog_70441c8e0102v3sr.html