matlab_处理图像时为什么把数据转换为double型,及显示

转载 2018年04月15日 11:32:56
一、图像处理为什么转换为double类型?
1 有些函数支持double型,而不支持uint8的数据类型,所以要转换
2 精度问题了,因为uint8进行数据处理的时候,容易造成数据溢出或精度不够

为了节省存储空间,matlab为图像提供了特殊的数据类型uint8(8位无符号整数),以此方式存储的图像称作8位图像。

imread把灰度图像存入一个8位矩阵,当为RGB图像时,就存入8位RGB矩阵中。

因此,matlab读入图像的数据是uint8,而matlab中数值一般采用double型(64位)存储和运算。所以要先将图像转为double格式的才能运算,
I2=im2double(I1)  %把图像I1转换成double精度类型 (假设图形矩阵范围0~255)
或者
I64=double(I8);   %uint转换成double
如果不转换,计算会产生溢出。

经过计算后,I2已经是double型。如果现在想imshow显示图像结果,就需要再转换成uint8格式。如果矩阵复合数据图像标准(0~1之间),
I3=im2uint8(I2)  %把矩阵I2转换成uint8类型
如果超出0~1范围,就要用uint8()
I8=uint8(round(I64*255));  %double转换成uint8    
或者mat2gray()

I3=mat2gray(I2)  &把矩阵转化为灰度图像格式double

二、imshow显示

在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(:))]作为第二个参数。

原理:imshow(A,[])是将A的最大值(max(A))和最小值(min(A))分别作为纯白(255)和纯黑(0),中间的K值相应地映射为0到255之间的标准灰度值,这样就可以正常显示了。。。,相当于将double型的矩阵A拉伸成为了0-255的uint8型的矩阵,因此就可以正常显示


matlab在处理图像时为什么把数据转换为double型?

1 有些函数支持double型,而不支持uint8的数据类型,所以要转换 2 精度问题了,因为uint8进行数据处理的时候,容易造成数据溢出或精度不够。 为了节省存储空间,matlab为图像...
  • qq_26093511
  • qq_26093511
  • 2016-12-21 15:22:13
  • 4504

图像处理中uint8和double的问题

为了节省存储空间,matlab为图像提供了特殊的数据类型uint8(8位无符号整数),以此方式存储的图像称作8位图像。 imread把灰度图像存入一个8位矩阵,当为RGB图像时,就存入8位RGB矩阵中...
  • yjl9122
  • yjl9122
  • 2016-03-20 19:07:02
  • 5763

matlab编程中涉及到图象矩阵数据类型uint8\double matlab中用imshow()显示图像与图像矩阵的数据类型

记得当时用 imshow 显示灰度图有一些问题 进行double转化后解决 这个问题是在刚开始接触使用Matlab处理图像时经常会遇见的困惑。         网上有这么一种说...
  • ssmjcode
  • ssmjcode
  • 2012-04-25 13:54:06
  • 2327

OpenCV中double和float类型图像数据的访问

首先解释下结构体IplImage和类Mat
  • chinacoy
  • chinacoy
  • 2014-07-25 14:29:34
  • 4617

Matlab图像数据类型unit8,double关系

本文参考http://blog.csdn.net/fx677588/article/details/53301740。     matlab中读取图片后保存的数据是uint8类型(8位无符号整数,即...
  • cymy001
  • cymy001
  • 2017-09-20 10:56:41
  • 3182

matlab中用imshow()显示double类型图像中出现的问题

在matlab中,我们常使用imshow()函数来显示图像,而此时的图像矩阵可能经过了某种运算。在matlab中,为了保证精度,经过了运算的图像矩阵I其数据类型会从unit8型变成double型。如果...
  • majinlei121
  • majinlei121
  • 2015-06-25 10:37:01
  • 4977

MatLab matlab编程中涉及到图象矩阵的数据类型uint8\double

这个问题是在刚开始接触使用Matlab处理图像时经常会遇见的困惑。         网上有这么一种说法:          默认情况下,matlab将图像中的数据存储为double型,即64位浮点...
  • redline2005
  • redline2005
  • 2011-10-16 17:24:34
  • 744

Matlab图像处理中uint8和double的问题

 为了节省存储空间,matlab为图像提供了特殊的数据类型uint8(8位无符号整数),以此方式存储的图像称作8位图像。 imread把灰度图像存入一个8位矩阵,当为RGB图像时,就存入8位RG...
  • SMF0504
  • SMF0504
  • 2017-06-07 14:51:21
  • 1062

图像类型、MATLAB数据类型,以及类型之间的转换(二)

上篇中我们根据需要将图像分为4种类型,其中每种图像的表示或多或少都牵扯到不同的数据类型,大致如下: 图像类型 使用到的数据类型 灰度图像 像素值为uint8,uint16,归一化doub...
  • Scut_Aspen
  • Scut_Aspen
  • 2015-04-15 15:27:04
  • 2319

对double类型中存在-0.0的数据检验

昨晚在牛客APP上做JAVA题库,见到一题目很有新意,便对该问题和答案做了检验。 原题是这样的: 下列代码执行的结果应该是什么? public class ZeroTest { public ...
  • li99yangg
  • li99yangg
  • 2017-08-18 12:09:31
  • 202
收藏助手
不良信息举报
您举报文章:matlab_处理图像时为什么把数据转换为double型,及显示
举报原因:
原因补充:

(最多只允许输入30个字)