matlab中用imshow()显示double类型图像中出现的问题
2015-06-25 10:37
561 查看
在matlab中,我们常使用imshow()函数来显示图像,而此时的图像矩阵可能经过了某种运算。在matlab中,为了保证精度,经过了运算的图像矩阵I其数据类型会从unit8型变成double型。如果直接运行imshow(I),我们会发现显示的是一个白色的图像。这是因为imshow()显示图像时对double型是认为在0~1范围内,即大于1时都是显示为白色,而imshow显示uint8型时是0~255范围。而经过运算的范围在0-255之间的double型数据就被不正常得显示为白色图像了。
这里那,要是把运算后是double型的图像矩阵转化为uint8(I)类型,虽然可以保证显示范围,但是显示精度确实大大降低,好多细节的区域不会显示出来,这里既要把doule类型的矩阵显示出来又要保证显示精度,因此可以使用:
imshow(I/max(max(I))); ----------将图像矩阵转化到0-1之间
imshow(I,[]); -----------自动调整数据的范围以便于显示
第一种方法是将图像除以矩阵中的最大值,这样就可以转化到0到1之间,就可以正常显示了,这里如果要是除以255的话会出现一个问题,那就是如果图像矩阵的像素值都比较小的话那么显示的图像就会全部变为黑色。
第二种方法的原理和第一种差不多,具体可以看看imshow()函数的显示原理:
imshow(I,n)
imshow(I,[low high])
用指定的灰度范围 [low high]显示灰度图像 I。显示结果,图像中灰度值等于或低于low的都将用黑色显示,而灰度值大于等于high的都显示为白色,介于low和high之间的用其灰度级的默认值的中间色调显示。如果你用了一个空矩阵 ([]) 来代替 [low high], imshow 函数将使用 [min(I(:))max(I(:))]作为第二个参数。
这里那,要是把运算后是double型的图像矩阵转化为uint8(I)类型,虽然可以保证显示范围,但是显示精度确实大大降低,好多细节的区域不会显示出来,这里既要把doule类型的矩阵显示出来又要保证显示精度,因此可以使用:
imshow(I/max(max(I))); ----------将图像矩阵转化到0-1之间
imshow(I,[]); -----------自动调整数据的范围以便于显示
第一种方法是将图像除以矩阵中的最大值,这样就可以转化到0到1之间,就可以正常显示了,这里如果要是除以255的话会出现一个问题,那就是如果图像矩阵的像素值都比较小的话那么显示的图像就会全部变为黑色。
第二种方法的原理和第一种差不多,具体可以看看imshow()函数的显示原理:
imshow(I,n)
imshow(I,[low high])
用指定的灰度范围 [low high]显示灰度图像 I。显示结果,图像中灰度值等于或低于low的都将用黑色显示,而灰度值大于等于high的都显示为白色,介于low和high之间的用其灰度级的默认值的中间色调显示。如果你用了一个空矩阵 ([]) 来代替 [low high], imshow 函数将使用 [min(I(:))max(I(:))]作为第二个参数。
相关文章推荐
- matlab中norm函数的用法
- matlab echo 的用法
- 实验二:FFT算法的MATLAB实现
- 实验一 离散时间序列卷积和MATLAB实现
- Huffman编码用MTLAB的实现及编码注释----------Matlab
- MIMO信道容量及注水算法---------Matlab
- MATLAB实用源代码
- 协方差,方差,期望的意义
- matlab中sum()求和函数
- PCA ( 主成分分析) 详解 ( 写给初学者) 结合matlab
- Matlab常用函数流水账
- 几种简单常用的镜头边缘检测算法(matlab实现)
- matlab中 tic,toc函数的用法
- 利用MATLAB绘制信号时域波形和信号的频谱
- [图像]Canny检测的Matlab实现(含代码)
- matlab中clc,close,close all,clear,clear all作用区别
- Matlab——zeros函数和ones函数
- win7运行matlab7.0闪一下就消失
- Matlab图像处理小结
- Matlab区分难点