Matlab图像处理例子 matlab自带图片

一、图像基本操作

1.读取图像并显示

>> clear;closeall%清空Matlab工作平台所有变量(准备工作)
>>I=imread('pout.tif'); %该图像是Matlab图形工具箱中自带的图像(toolboximagesimdemos)
>> imshow(I)

2.检查内存(数组)中的图像

>>whos

NameSizeBytesClass

I291x24069840 uint8 array

Grand total is 69840 elementsusing 69840 bytes

表示该图像采用8位存储方式并占用了69840B的存储空间。


3.实现图像直方图均衡化:

>>figure(1);imhist(I)% 在新图中显示图像I的直方图


>>I2=histeq(I); %均衡化以后的图像存在I2数组中(图像灰度值扩展到整个灰度范围,对比度提高)
>>figure(2);imshow(I2) % 显示均衡化后的图像
>>figure(2);imhist(I2)% 显示均衡后的灰度值分布情况

8位图像取值范围:[0,255],16位图像取值范围:[0,655351],双精度图像取值范围:[0,1]

4.保存图像:

>>imwrite(I2,'pout2.png');% 将图像由原先的tif格式另存为png格式

5.检查新生成文件的信息:

>>imfinfo('pout2.png')% 观察保存图像的文件信息

ans =

Filename:'pout2.png'%文件名
FileModDate: '11-Apr-200921:55:35' %文件修改日期
FileSize:36938% 文件大小
Format:'png'%文件格式
FormatVersion:[]%格式
Width:240% 文件宽度
Height:291% 文件高度
BitDepth:8% 文件位深度
ColorType: 'grayscale' % 颜色类型

……

二、图像处理Matlab的应用:

实例:消除rice.png图像中亮度不一致的背景,并使用阈值将修改后的图像转换为二值图像,使用成员标记返回图像中对象的个数以及统计特性。按照如下步骤进行:

1.读取和显示图像

>> clear;closeall
>> I=imread('rice.png');
>> imshow(I)

2.估计图像背景:

图像中心位置背景亮度强于其他部分亮度,用imopen函数和一个半径为15的圆盘结构元素对输入的图像I进行形态学开操作,去掉那些不完全包括在圆盘中的对象,从而实现对背景亮度的估计。

>> clear;closeall
>> 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');

显示了背景图(左)和背景表面图(右)

3.从原始图像中减去背景图像(原始图像I减去背景图像得到背景较为一致的图像):

>>I2=imsubtract(I,background);
>> figure,imshow(I2)

4.调节图像的对比度(图像较暗,可用imadjust函数命令来调节图像的对比度)

>>I3=imadjust(I2,stretchlim(I2),[0 1]);
>> figure,imshow(I3);

5.使用阈值操作将图像转换为二进制(二值)图像(bw),调用whos命令查看图像的存储信息.

>>level=graythresh(I3);% 图像灰度处理
>>bw=im2bw(I3,level);% 图像二值化处理
>>figure,imshow(bw)% 显示处理后的图片

>> whos
NameSizeBytes Class

I256x25665536 uint8 array
I2256x25665536 uint8 array
I3256x25665536 uint8 array
background256x25665536 uint8 array
bw256x25665536 logical array
level1x18 double array

Grand total is 327681 elementsusing 327688 bytes

6.检查图像中对象个数(bwlabel函数表示了二值图像中的所有相关成分并返回在图像中找到的对象个数)

>>[labeled,numObjects]=bwlabel(bw,4);

>>numObjects

numObjects =

101

表示图像中的米粒对象个数是101.

7.检查标记矩阵:(imcrop命令进行交互式操作,图像内拉出较小矩形并显示已标记的对象和部分背景内的像素)

>>grain=imcrop(labeled)

grain =

00424242424242420
004242424242424242
004242424242424242
Matlab图像处理例子 matlab自带图片
004242424242424242
004242424242424242
004242424242424242
0424242424242424242
0424242424242424242


8.观察标记矩阵(用label2rgb将其显示为一副伪彩色的索引图像):

>>RGB_label=label2rgb(labeled,@spring,'c','shuffle');
>> imshow(RGB_label);

9.测量图像对象或区域的属性(Regionprops,返回一个结构数据)

>>graindata=regionprops(labeled,'basic')

graindata =

101x1 struct array withfields:
Area
Centroid
BoundingBox
>>graindata(40).Area% 显示矩阵中第40个元素的属性

ans =

197

>>graindata(40).BoundingBox,graindata(40).Centroid% 寻找最近的边缘和中心点

ans =

82.500059.500024.000020.0000


ans =

95.421370.4924

>>allgrains=[graindata.Area];% 创建一个新的向量allgrains,其包含每个米粒的范围
>> whos allgrains
NameSizeBytes Class

allgrains1x101808 double array

Grand total is 101 elementsusing 808 bytes

>>allgrains(51)% 相当于整个矩阵的索引为51的属性是多少,可见与原来得到的结果相同

ans =

140

>>max(allgrains)% 获取最大的米粒大小

ans =

404
>>biggrain=find(allgrains==404)% 使用find命令返回这个最大尺寸米粒的标记号

biggrain =

59

>>mean(allgrains) %获取米粒的平均大小

ans =

175.0396

9.绘制包含30个柱的直方图来说明米粒大小的分布情况

>>hist(allgrains,30)

(米粒大小分布柱状图)

  

爱华网本文地址 » http://www.413yy.cn/a/25101017/356195.html

更多阅读

如何关闭系统自带的windows 防火墙。 系统自带防火墙有用吗

如何关闭系统自带的windows 防火墙。——简介现在网上有很多软件或者游戏SF之类的需要关闭系统自带的防火墙才能运行。这次教大家如何关闭电脑自带防火墙。(这里小编使用的是W7系统,关于XP系统的朋友其实两种方法都是大同小异,操作步骤

如何运用电脑自带画图工具画平面图 windows自带画图工具

如何运用电脑自带画图工具画平面图——简介 很多办公人员,因为工作的缘故,需要各种平面制图,但是又不会运用专业的autoCAD制图工具等专业画图工具,虽然工作上遇到需要制图,对制图上面的要求不是很高,图片上的长宽度也不要求很精确,但是对具

PHPCMSV9如何去掉自带水印的解决方法 phpcms v9下载

很多站长朋友们都知道,Phpcmsv9有自带的水印功能。今天无忧主机小编在给一个朋友修改网站时,询问小编能否把Phpcmsv9自带的水印功能去掉呢,因为有时候在编辑器中上传图片时,不希望上传的图片被自动加上phpcmsv9自带的水印。无忧主机小

教你彻底删除XP系统自带屏保程序 w7系统怎么设置屏保

教你彻底删除XP系统自带屏保程序今天心血来潮想把XP系统自带屏保程序彻底删除,于是上网去找方法,什么下载批处理(怕有毒或木马)、什么直接在windowssystem里找到要删的屏保,按Shift+Del删(按名字搜索不到)、在WindowsXP中,要删除系统自带的

图像处理中的卷积与模板 图像处理 卷积

图像处理中的卷积与模板2011-04-25 11:16转载自 deepthink_2010最终编辑 shuting_guo1.使用模板处理图像相关概念:模板:矩阵方块,其数学含义是一种卷积运算。卷积运算:可看作是加权求和的过程,使用到的图像区域中的每个像素分别与卷积核(

声明:《Matlab图像处理例子 matlab自带图片》为网友像迯跑賊分享!如侵犯到您的合法权益请联系我们删除