Matlab图像如何处理?Matlab图像处理的基本操作

来源:脚本之家时间:2022-02-18 10:20:02

虽然说Matlab是一款数学处理软件,但是这款软件特别强大,强大之处在于他还能够处理图像,这个功能是很多新手学习Matlab的时候感到惊讶的地方,所不了解,所要学习的,下面小编就给大家介绍Matlab处理图像的方法。一起去看看吧!

数学软件Matlab R2016a 64位 完全特别版(附破解文件+密钥+安装教程)

类型:编程其它大小:7.6GB语言:简体中文时间:2016-11-23查看详情

一、图像基本操作

1、读取图像并显示:

》》 clear;close all %清空Matlab工作平台所有变量(准备工作)

》》 I=imread(‘pout.tif’); % 该图像是Matlab图形工具箱中自带的图像(\toolbox\images\imdemos)

》》 imshow(I)

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的直方图

》》 I2=histeq(I); % 均衡化以后的图像存在I2数组中(图像灰度值扩展到整个灰度范围,对比度提高)

》》 figure,imshow(I2) % 显示均衡化后的图像

》》 figure,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-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)

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

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

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);

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 图像处理

相关阅读

推荐阅读

江苏省养老方式及服务需求研究报告发布

江苏省养老方式及服务需求研究报告发布

当你老了,如何养老?10月11日,江苏省消保委发布《江苏省养老方式及服务需求研究报告》(简称《报告》),本次研究采用线上问卷和线下问卷调 更多

2021-10-12 07:55:20
电影票房狂吸金超40亿元  上市公司表现如何呢?

电影票房狂吸金超40亿元 上市公司表现如何呢?

在刚刚过去的国庆长假里,电影票房成绩优秀。据灯塔专业版数据,2021年国庆档总票房43 86亿元,这是国庆档票房历史第二次破40亿,仅次于201 更多

2021-10-09 07:54:06
国庆假期你去露营了吗?我国目前有3.2万家露营相关企业

国庆假期你去露营了吗?我国目前有3.2万家露营相

相约露营,现如今变得新潮又时尚。把客厅、厨房和卧室,都搬到野外去,食于山野,宿于山野,每一帧画面都透露出一种岁月静好的美好。扬子晚 更多

2021-10-08 08:27:04
我国现存眼镜企业超132万家  南京居全国第四

我国现存眼镜企业超132万家 南京居全国第四

日前,在第三届国民视觉健康高峰论坛上分享了一组数据,2020年,我国儿童青少年总体近视率为52 7%,其中6岁儿童为14 3%,小学生为35 6%,初 更多

2021-10-08 07:54:47
兴昌塑胶拟减持不超1%股份  大股东减持曾重挫股价

兴昌塑胶拟减持不超1%股份 大股东减持曾重挫股价

股东减持出现新理由,要借给上市公司无偿使用。9月29日晚间,高乐股份(002348)披露称,公司实控人之一兴昌塑胶五金厂有限公司(以下简称兴昌 更多

2021-09-30 08:43:16
”酱油三剑客“股价都在涨  股价再度突破百元大关

”酱油三剑客“股价都在涨 股价再度突破百元大关

9月26日晚间,海天味业公告:由于今年以来各主要原材物料、运输、能源等成本持续大幅上涨,给经营带来了一定的挑战,近期正在评估是否对产 更多

2021-09-28 07:50:33
“丝绸文创第一股”来了!万事利发行价格为5.24元/股

“丝绸文创第一股”来了!万事利发行价格为5.24元

9月22日,以丝绸文化创意领先的杭州丝绸品牌万事利登陆A股创业板。万事利(301066)发行价格为5 24元 股,截至9月24日,最新股价为24 18元, 更多

2021-09-26 07:51:26
组团减持后股价大跌  百亚股份跌逾8%

组团减持后股价大跌 百亚股份跌逾8%

卫生巾第一股百亚股份(003006)股东组团减持不超过公司10%股份的消息果然影响了公司9月22日的股价。截至9月22日收盘,百亚股份股价大跌8 02% 更多

2021-09-23 08:07:23
+ 点击查看更多精彩
不一样的天猫“6·18”新指标  每笔订单减碳17.6%
    今年的6·18有些不一样:没有公布总成交额,而是改用碳排放量做衡...
上市公司海外收入哪家强? 化工、采掘、电子行业的海外收入最高
      中建迪拜山庄基础设施升级改造施工现场。  中国建筑供图 ...
“新电商人才发展计划”发布 四位一体布局 培养急需人才
    今年是决胜全面小康、决战脱贫攻坚的最后一年,数字经济持续快速...
各地侨企铆足干劲 释放着攒了数月的能量
    近期,侨企益海嘉里(哈尔滨)粮油食品工业有限公司面粉车间日夜...
2小时带货6100万元湖北商品!快手直播带货助力湖北重启
    夏丹喊你下单了,一起为湖北拼单、立马‘夏丹’,无法&...
商业银行正式进入金融期货市场
    谢卫群 摄商业银行今天(4月10日)正式进入中国金融期货市场。首批...