Matlab中处理double型图像以及对imshow(I,[])函数的理解

原文链接: https://blog.csdn.net/u012162771/article/details/79901160

Matlab中处理double型图像以及对imshow(I,[])函数的理解

转载 本文链接:Matlab中处理double型图像以及对imshow(I,[])函数的理解

近期学习使用matlab处理图像,对于显示double型图像遇到些问题,查阅相关博客、论坛,总结如下:
1、在matlab中,为了保证精度,经过了运算的图像矩阵I其数据类型会从uint8型变成double型。
2、如果直接运行imshow(I),我们会发现显示的是一个白色的图像。这是因为imshow()显示图像时对double型是认为在0~ 1范围内,即大于1时都是显示为白色,而imshow显示uint8型时是0~255范围。

解决办法如下:
1、imshow(I/256); % 将图像矩阵转化到0-1之间
2、imshow(I,[]); % 自动调整数据的范围以便于显示
3、inshow(uint8(I)); % 转成uint8

针对第二种解决方法,官方文档(https://cn.mathworks.com/help/matlab/ref/imshow.html?searchHighlight=imshow&s_tid=doc_srchtitle )中提示:
imshow(I,[low high]) 显示灰度图像 I,将该显示范围指定为一个二元素向量 [low high]。
参数 “[low high]” 可简写为 “[]”, 即将I的最大值 max(I) 和最小值 min(I) 分别作为纯白(255)和纯黑(0),中间的K值相应地映射为0到255之间的标准灰度值,相当于将double型的矩阵I拉伸成为了0-255的uint8型的矩阵。这里需要注意当图像的所有像素值相同时,该函数会将像素值当做最大值映射为255,图像会显示为白色,因此这时需要给定显示范围,如 imshow(I,[0 255])。

猜你喜欢

转载自blog.csdn.net/Elvirangel/article/details/102503786
今日推荐