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

在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]) 也是使用这种算法进行拉伸显示的。

猜你喜欢

转载自blog.csdn.net/lihe4151021/article/details/100690699