网站首页  软件下载  游戏下载  翻译软件  电子书下载  电影下载  电视剧下载  教程攻略

请输入您要查询的教程攻略:

 

标题 超全面!Matlab图像处理基本操作
分类 软件教程
内容     
    虽然说Matlab是一款数学处理软件,但是这款软件特别强大,强大之处在于他还能够处理图像,这个功能是很多新手学习Matlab的时候感到惊讶的地方,下面就给大家介绍Matlab处理图像的方法。
    一、图像基本操作
    1、读取图像并显示:
    》》 clear;close all %清空Matlab工作平台所有变量(准备工作)
    》》 I=imread(‘pout.tif’); % 该图像是Matlab图形工具箱中自带的图像(\\toolbox\\images\\imdemos)
    》》 imshow(I)
    超全面!Matlab图像处理基本操作
    2、检查内存(数组)中的图像:
    》》 whos
    Name Size Bytes Class
    I 291x240 69840 uint8 array
    Grand total is 69840 elements using 69840 bytes
    表示该图像采用8位存储方式并占用了69840B的存储空间。
    3、实现图像直方图均衡化:
    》》 figure,imhist(I) % 在新图中显示图像I的直方图
    超全面!Matlab图像处理基本操作
    》》 I2=histeq(I); % 均衡化以后的图像存在I2数组中(图像灰度值扩展到整个灰度范围,对比度提高)
    》》 figure,imshow(I2) % 显示均衡化后的图像
    》》 figure,imhist(I2) % 显示均衡后的灰度值分布情况
    8位图像取值范围:[0,255],16位图像取值范围:[0,655351],双精度图像取值范围:[0,1]
    超全面!Matlab图像处理基本操作
    超全面!Matlab图像处理基本操作
    4、保存图像:
    》》 imwrite(I2,‘pout2.png’); % 将图像由原先的tif格式另存为png格式
    超全面!Matlab图像处理基本操作
    5、检查新生成文件的信息:
    》》 imfinfo(‘pout2.png’) % 观察保存图像的文件信息
    ans =
    Filename: ‘pout2.p26. 世间万物,满天星辰是你,湖边暖风是你,柳絮飘然是你,道不尽的思念是你。ng’ % 文件名
    FileModDate: ‘11-Apr-2009 21:55:35’ % 文件修改日期
    FileSize: 36938 % 文件大小
    Format: ‘png’ % 文件格式
    FormatVersion: [] % 格式
    Width: 240 % 文件宽度
    Height: 291 % 文件高度
    BitDepth: 8 % 文件位深度
    ColorType: ‘grayscale’ % 颜色类型
    ……
    二、图像处理Matlab的应用:
    实例:消除rice.png图像中亮度不一致的背景,并使用阈值将修改后的图像转换为二值图像,使用成员标记返回图像中对象的个数以及统计特性。按照如下步骤进行:
    1、读取和显示图像
    》》 clear;close all
    》》 I=imread(‘rice.png’);
    》》 imshow(I)
    超全面!Matlab图像处理基本操作
    2、估计图像背景:
    图像中心位置背景亮度强于其他部分亮度,用imopen函数和一个半径为15的圆盘结构元素对输入的图像I进行形态学开操作,去掉那些不完全包括在圆盘中的对象,从而实现对背景亮度的估计。
    》》 clear;close all
    》》 I=imread(‘rice.png’);
    》》 imshow(I)
    》》 background=imopen(I,strel(‘disk’,15));
    》》 imshow(background)
    》》 figure,surf(double(background(1:8:end,1:8:end))),zlim([0,255]);
    》》 set(gca,‘ydir’,‘reverse’);
    超全面!Matlab图像处理基本操作
    超全面!Matlab图像处理基本操作
    显示了背景图(左)和背景表面图(右)
    3、从原始图像中减去背景图像(原始图像I减去背景图像得到背景较为一致的图像):
    》》 I2=imsubtract(I,background);
    》》 figure,imshow(I2)
    超全面!Matlab图像处理基本操作
    4、调节图像的对比度 (图像较暗,可用imadjust函数命令来调节图像的对比度)
    》》 I3=imadjust(I2,stretchlim(I2),[0 1]);
    》》 figure,imshow(I3);
    超全面!Matlab图像处理基本操作
    5、使用阈值操作将图像转换为二进制(二值)图像(bw),调用whos命令查看图像的存储信息。
    》》 level=graythresh(I3); % 图像灰度处理
    》》 bw=im2bw(I3,level); % 图像二值化处理
    》》 figure,imshow(bw) % 显示处理后的图片
    》》 whos
    Name Size Bytes Class
    I 256x256 65536 uint8 array
    I2 256x256 65536 uint8 array
    I3 256x256 65536 uint8 array
    background 256x256 65536 uint8 array
    bw 256x256 65536 logical array
    level 1x1 8 double array
    Grand total is 327681 elements using 327688 bytes
    超全面!Matlab图像处理基本操作
    6、检查图像中对象个数(bwlabel函数表示了二值图像中的所有相关成分并返回在图像中找到的对象个数)
    》》 [labeled,numObjects]=bwlabel(bw,4);
    》》 numObjects
    numObjects =
    101
    表示图像中的米粒对象个数是101.
    7、检查标记矩阵:(imcrop命令进行交互式操作,图像内拉出较小矩形并显示已标记的对象和部分背景内的像素)
    》》 grain=imcrop(labeled)
    grain =
    0 0 42 42 42 42 42 42 42 0
    0 0 42 42 42 42 42 42 42 42
    0 0 42 42 42 42 42 42 42 42
    0 0 42 42 42 42 42 42 42 42
    0 0 42 42 42 42 42 42 42 42
    0 0 42 42 42 42 42 42 42 42
    0 42 42 42 42 42 42 42 42 42
    0 42 42 42 42 42 42 42 42 42
    8、观察标记矩阵(用label2rgb将其显示为一副伪彩色的索引图像):
    》》 RGB_label=label2rgb(labeled,@spring,‘c’,‘shuffle’);
    》》 imshow(RGB_label);
    超全面!Matlab图像处理基本操作
    9、测量图像对象或区域的属性(Regionprops,返回一个结构数据)
    》》 graindata=regionprops(labeled,‘basic’)
    graindata =
    101x1 struct array with fields:
    Area
    Centroid
    BoundingBox
    》》 graindata(40).Area % 显示矩阵中第40个元素的属性
    ans =
    197
    》》 graindata(40).BoundingBox,graindata(40).Centroid % 寻找最近的边缘和中心点
    ans =
    82.5000 59.5000 24.0000 20.0000
    ans =
    95.4213 70.4924
    》》 allgrains=[graindata.Area]; % 创建一个新的向量allgrains,其包含每个米粒的范围
    》》 whos allgrains
    Name Size Bytes Class
    allgrains 1x101 808 double array
    Grand total is 101 elements using 808 bytes
    》》 allgrains(51) % 相当于整个矩阵的索引为51的属性是多少,可见与原来得到的结果相同
    ans =
    140
    》》 max(allgrains) % 获取最大的米粒大小
    ans =
    404
    》》 biggrain=find(allgrains==404) % 使用find命令返回这个最大尺寸米粒的标记号
    biggrain =
    59
    》》 mean(allgrains) % 获取米粒的平均大小
    ans =
    175.0396
    10、绘制包含30个柱的直方图来说明米粒大小的分布情况
    》》 hist(allgrains,30)
    超全面!Matlab图像处理基本操作
    米粒大小分布柱状图
    以上几点便是Matlab图像处理的基本操作,多次使用后你会发现这些方法在使用Matlab的过程中很实用,并且使用起来非常简单。以上便是关于Matlab图像处理方法的基本操作,希望对你的学习有所帮助。
        超全面!Matlab图像处理基本操作唠唠叨花红风雪交加柳绿叨14. 朋友是什么?朋友是快乐日子里的一把吉它,尽情地为你弹奏生活的愉悦;朋友是忧伤日子里的一股春风,轻轻地为你拂去心中的愁云;朋友是成功道路上的一位良师,热情的将你引向阳光的地带;朋友是失败苦闷中的一盏明灯,默默地为你驱赶心灵的阴霾。我们永远都不会忘记在一起度过的日子。211.旧时王谢堂前燕,飞入寻常百姓家。《乌衣巷》    冰肌玉骨,自清凉无汗。水殿风来暗香满。绣帘开,一点明月窥人,人未寝,倚枕钗横鬓乱。上国随缘住,来途若梦行。Matlab图像处理,Matlab教程,Matlab下载If so, even though 3 percent more accidents occurred after the change, the author’s argument that changing the speed limit increases danger for drivers would be seriously weakened.
随便看

 

霍普软件下载网教程攻略栏目提供软件使用教程、手机游戏攻略等方法技巧。

 

Copyright © 2002-2024 101bt.net All Rights Reserved
更新时间:2025/3/17 6:43:40