Matlab 图像处理基本操作
文/天神
一、图像基本操作
1.读取图像并显示:
>> clear;close all
>> I=imread('pout.tif');
>> imshow(I)
2.检查内存(数组)中的图像:
>> whos
Name
Grand total is 69840 elements using 69840 bytes
表示该图像采用8位存储方式并占用了69840B的存储空间。
3.实现图像直方图均衡化:
>> figure,imhist(I)
>> I2=histeq(I);
>> figure,imshow(I2)
>> figure,imhist(I2)
8位图像取值范围:[0,255],16位图像取值范围:[0,655351],双精度图像取值范围:[0,1]
4.保存图像:
>> imwrite(I2,'pout2.png');
5.检查新生成文件的信息:
>> imfinfo('pout2.png')
ans =
二、图像处理Matlab的应用:
实例:消除rice.png图像中亮度不一致的背景,并使用阈值将修改后的图像转换为二值图像,使用成员标记返回图像中对象的个数以及统计特性。按照如下步骤进行:
1.读取和显示图像
>> clear;close all
>> I=imread('rice.png');
>> imshow(I)
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');
显示了背景图(左)和背景表面图(右)
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
Grand total is 327681 elements using 327688 bytes
6.检查图像中对象个数(bwlabel函数表示了二值图像中的所有相关成分并返回在图像中找到的对象个数)
>> [labeled,numObjects]=bwlabel(bw,4);
>>
numObjects =
表示图像中的米粒对象个数是101.
7.检查标记矩阵:(imcrop命令进行交互式操作,图像内拉出较小矩形并显示已标记的对象和部分背景内的像素)
>> grain=imcrop(labeled)
grain =
8.观察标记矩阵(用label2rgb将其显示为一副伪彩色的索引图像):
>> RGB_label=label2rgb(labeled,@spring,'c','shuffle');
>> imshow(RGB_label);
9.测量图像对象或区域的属性(Regionprops,返回一个结构数据)
>> graindata=regionprops(labeled,'basic')
graindata =
101x1 struct array with fields:
>> graindata(40).Area
ans =
>> graindata(40).BoundingBox,graindata(40).Centroid
ans =
ans =
>> allgrains=[graindata.Area];
>> whos allgrains
Grand total is 101 elements using 808 bytes
>> allgrains(51)
ans =
>> max(allgrains)
ans =
>> biggrain=find(allgrains==404)
biggrain =
>> mean(allgrains)
ans =
9.绘制包含30个柱的直方图来说明米粒大小的分布情况
>> hist(allgrains,30)