matlab中imshow(a,[])用法及其内部计算公式

在Matlab中,imshow()函数用于显示图像,但处理后的图像矩阵若为double型,直接显示可能会出现全白现象。本文解释了原因并提供了解决方案,包括使用imshow(I/256)和imshow(I,[])来正确显示图像。

在matlab中,我们常使用imshow()函数来显示图像,而此时的图像矩阵可能经过了某种运算。在matlab中,为了保证精度,经过了运算的图像矩阵A其数据类型会从unit8型变成double型。如果直接运行imshow(A),我们会发现显示的是一个白色的图像。这是因为imshow()显示图像时对double型是认为在0-1范围内,即大于1时都是显示为白色,而imshow显示uint8型时是0~255范围。而经过运算的范围在0-255之间的double型数据就被不正常得显示为白色图像了。

到两个解决方法:

 imshow(I/256); ———–将图像矩阵转化到0-1之间 
 imshow(I,[]);       ———–自动调整数据的范围以便于显示 

imshow(A,[ ])
inshow(A,[ ])相当于imshow(A,[min(A),max(A)])
其内部计算公式为:

b=(a-min(a(:)))./(max(a(:))-min(a(:)))*255;%%a为double型
imshow(uint8(b));

这样就可以将指定范围的灰度值变换到0-255区间显示。imshow(A,[LOW,HIGH]) 也是使用这种算法进行拉伸显示的。

评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值