zoukankan      html  css  js  c++  java
  • [转载]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
  • 相关阅读:
    C# 获取 域(AD) 用户信息
    如何在 MOSS 2007 启用 Session
    安装 卸载 回收 sharepoint 解决方案 moss wss wsp
    [转]挑战Windows极限:物理内存
    霍特卡的 CSLA.Net 3.6 Windows及Silverlight的正式版 昨天发布 同时CSLA.Net 业务对象 2008 英文版图书可以网上订购
    转帖如何在不联网的情况下安装 Silverlight Tools
    jQuery 选择器的使用
    关闭 Windows Server 2008 用户权限控制(UAC)
    jQuery 的第一个例子
    jQuery for Asp.Net 一步一步从入门到精通(附 jQuery API 彩色大图)
  • 原文地址:https://www.cnblogs.com/ZHENGJUNupperclassman/p/7754162.html
Copyright © 2011-2022 走看看