mat2gray_mat2gray函数的作用 - CSDN
精华内容
参与话题
  • I = mat2gray(A, [amin amax]) 将图像矩阵A中介于amin和amax的数据归一化处理,其余小于amin的元素都变为0,大于amax的元素都变为1。 I = mat2gray(A) 将图像矩阵A归一化为图像矩阵I,归一...

    函数简介

    函数功能:实现图像矩阵的归一化操作。所谓"归一化"就是使矩阵的每个元素的值都在0和1之间。该函数在数字图像处理中经常用到。

    调用格式:

    I = mat2gray(A, [amin amax])

    将图像矩阵A中介于amin和amax的数据归一化处理,其余小于amin的元素都变为0,大于amax的元素都变为1。

    I = mat2gray(A)

    将图像矩阵A归一化为图像矩阵I,归一化后矩阵中每个元素的值都在0到1范围内(包括0和1)。其中0表示黑色,1表示白色。

    程序示例

    在命令窗口中输入:
    >> test = [1 2 3; 4 5 6]
    test =
    1 2 3
    4 5 6
    >> test2 = mat2gray(test)
    test2 =
    0 0.2000 0.4000
    0.6000 0.8000 1.0000
    >> test2 = mat2gray(test, [2, 5])
    test2 =
    0 0 0.3333
    0.6667 1.0000 1.0000

     

    转载于:https://www.cnblogs.com/rong86/p/3558320.html

    展开全文
  • 关于matlab里mat2gray函数格式

    千次阅读 2018-01-31 22:01:53
    Matlab 中 mat2gray 函数的介绍   Matlab 中 mat2gray 函数的介绍 函数功能: 实现图像矩阵的归一化操作。 所谓"归一化"就是使矩阵的每个元素的值都在0和1之间。该函数在数字图像处理中经常...

    Matlab 中 mat2gray 函数的介绍

     
    Matlab 中 mat2gray 函数的介绍
    函数功能: 实现图像矩阵的归一化操作。 所谓"归一化"就是使矩阵的每个元素的值都在0和1之间。该函数在数字图像处理中经常用到。
    在matlab命令窗口中输入: doc mat2gray或者help mat2gray即可获得该函数的帮助信息, 键入type mat2gray可以查看函数的实现代码。
    调用格式:
    I = mat2gray(A, [amin amax])
    将图像矩阵A中介于amin和amax的数据归一化处理, 其余小于amin的元素都变为0, 大于amax的元素都变为1。
    I = mat2gray(A)
    将图像矩阵A归一化为图像矩阵I, 归一化后矩阵中每个元素的值都在0到1范围内(包括0和1)。其中0表示黑色,1表示白色。
    展开全文
  • 图像类和类型间的转换 im2uint8 将输入中所有小于0的设置为0,而将输入中所有大于1的...mat2gray 把一个double类的任意数组转换成值范围在[0,1]的归一化double类数组 im2double 将输入转换为double类.若输入是uint8
    图像类和类型间的转换
    im2uint8  将输入中所有小于0的设置为0,而将输入中所有大于1的设置为255 其他的所有乘以255
    im2uint16  将输入中所有小于0的设置为0,而将输入中所有大于1的设置为65535
    mat2gray   把一个double类的任意数组转换成值范围在[0,1]的归一化double类数组
    im2double 将输入转换为double类.若输入是uint8类 uint16 类 logical类则函数将其转换为范围[0,1]之间的类.
    若输入是double类,则函数im2double将返回一个与输入相等的数组.
    g=im2bw(f,T)将一副亮度图像f转换成一副二值图像g ,输出二值图像g中值为0的像素,对应于输入亮度图像f中值小于T的的像素点,输出二值图像g中的1对应于输入亮度图像中大于T的像素点..不管输入是何种数据类图像,T的取值必须在[0,1]内.
    亮度变换函数
    函数imadjust是对灰度图像进行亮度转换的基本IPT工具
    g=imadjust(f,[low-in   high-in],[low_out  high_out],gmma)

    此函数将图像f中的亮度值映像到g中的新值,即将low_in至high_in之间的值的映射到low_out和high_out之间的值.low_in以下high_in以上的值被剪切了.   参数gamma给出曲线的形状.该曲线用来映射f的亮度值,以便生成图像g.若gamma小于1,则映射被加权至更高的输出值.




    ****************假设某图像数据A(uint8格式)**********************

    >>A = uint8([235 200 89 20])
    A =
      235  200  89  20
    >> double(A)                 %返回与原矩阵数值相同但类型为double的矩阵;
    ans =
       235   200 89   20
    >> im2double(A)              
    %返回矩阵类型:double;数值范围[0 1] ,0对应uint8中的0;1对应uint8中的255;
    ans =
        0.9216    0.7843   0.3490    0.0784
    >> mat2gray(A)                %对原矩阵归一化
    ans =
        1.0000    0.8372   0.3209      0
    ****************假设矩阵A为一般二维数组,非图像数据(double格式)**********************
    A =
       235   200    89    20 
    >> double(A)
    ans =
       235   200   89    20
    >> im2double(A)
    ans =
       235   200   89    20
    >> mat2gray(A)
    ans =
        1.0000    0.8372    0.3209      0 
    **********************小结***************************
    im2double:如果输入类型是uint8、unit16 、logical,则按照0-->>0,255-->>1,将其值按比例处理成0~1之间的double数值;如果输入类型是double,输出没有处理;
    double:返回数值与输入相同的double类型矩阵;
    mat2gray:对输入进行归一化处理,最小值-->>0;最大值-->>1,输出类型为double。
    在实际的对图像处理过程中,由于我们读入图像是unit8型,而在MATLAB的矩阵运算中要求所有的运算变量为double型(双精度型)。因此通常使用im2double函数将图像数据转换成双精度型数据。


    mat2gray

    功能:将矩阵转化为灰度图像。
    用法:I = mat2gray(A,[amin amax])        把一个double类的任意数组转换成取值范围为[0 1]的亮度图像。其中图像I的取值范围也在0(黑色)到1(白色)之间。参数amin和amax表示将A中小于amin的值转换为0,将A中大于amax的值转换为1。I = mat2gray(A)      将矩阵A中实际最小值和最大值分别赋给amin和amax。


    >> A = randint(5, 5, [0 255])
    A =
       208    24    40    36   167
       231    71   248   107     9
        32   140   245   234   217
       233   245   124   202   239
       161   247   204   245   173
    >> mat2gray(A)
    ans =
        0.8326    0.0628    0.1297    0.1130    0.6611
        0.9289    0.2594    1.0000    0.4100         0
        0.0962    0.5481    0.9874    0.9414    0.8703
        0.9372    0.9874    0.4812    0.8075    0.9623
        0.6360    0.9958    0.8159    0.9874    0.6862
    >> im2double(A)
    ans =
       208    24    40    36   167
       231    71   248   107     9
        32   140   245   234   217
       233   245   124   202   239
       161   247   204   245   173

    mat2gray函数原理分析:

    matlab里面很多函数都非常好用,但是当我们需要转化成C的时候就必须理解它的原理,mat2gray这个函数的原理经过单步调式发现其中有个函数imlincombc并没有提供源代码,这里我通过测试几组有意义的数据,基本弄明白了它的原理,具体算法步骤如下:
        1、mat2gray是将输入数据F归一化为0-1之间的double型数据
        2、令数据F中的max(F)为1,min(F)为0;
        3、计算最大值和最小值的差值的倒数即:det=1/(max(F)-min(F));
        4、对于数据F中介于最大值和最小值之间的数据是这样处理的:假设temp1为介于最大值和最小值中的某一值,经过mat2gray
        变换后变为:temp_last=(temp1-min(F))*det;
        经过测试多组数据,发现上述步骤无误:

    展开全文
  • mat2gray、interp1

    2018-07-01 10:14:25
    p26:“函数mat2gray会将值限定在[0,1]范围内”,我的理解是该函数会自动检测输入的值的类型,0对应该类型的最小值,1对应该类型的最大值,将该数值进行变换。例如输入uint8类型的数字(范围为0-255),该函数就会...

    p26:

    “函数mat2gray会将值限定在[0,1]范围内”,我的理解是该函数会自动检测输入的值的类型,0对应该类型的最小值,1对应该类型的最大值,将该数值进行变换。

    例如输入uint8类型的数字(范围为0-255),该函数就会自动将0对应0,1对应255来进行变换。

    im2uint8也同理。


    p27:

    interp1(z,T,f)

    该函数的z与T为长度相同的列向量,他们其中的值一一对应。

    例如z数组为:[1 2 3 4 5 6] 

    T数组为:[0 20 60 68 77 100]

    则1对应0,2对应20,3对应60,4对应68,5对应77,6对应100,通过该对应来对图像f进行变换。如原图像中灰度值在0至20的,线性变换为1至2;而20至60的,线性变换为2至3。


    linspace(a,b,numel(T))

    a为起始值,b为结束值,numel函数可获取数组的元素个数。该函数会根据T数组的元素个数来对a至b的值进行等距分割。

    例如t为6元素的数组,a=0,b=1,该函数会输出[0 0.2 0.4 0.6 0.8 1]。

    展开全文
  • mat2gray

    2020-01-07 16:21:43
    mat2gray:将矩阵转换为灰度图像 Syntax I = mat2gray(A,[amin amax]) I = mat2gray(A) Description I = mat2gray(A,[amin amax])将矩阵A转换为强度图像I,该强度图像I包含0(黑色)到1(白色)范围内的值...
  • mat2gray函数原理分析

    千次阅读 2014-05-06 21:00:00
    matlab里面很多函数都非常好用,但是当我们需要转化成C的时候就必须理解它的原理,mat2gray这个函数的原理经过单步调式发现其中有个函数imlincombc并没有提供源代码,这里我通过测试几组有意义的数据,基本弄明白了...
  • matlab中mat2gray函数用法

    万次阅读 2018-05-24 11:08:33
    mat2gray是一个计算机函数,功能是实现图像矩阵的归一化操作。 所谓”归一化”就是使矩阵的每个元素的值都在0和1之间。该函数在数字图像处理中经常用到。 函数简介 函数功能: 实现图像矩阵的归一化操作。[1] 所谓...
  • 图像类和类型间的转换 im2uint8 将输入中所有小于0的设置为0,而将输入中所有大于1的...mat2gray 把一个double类的任意数组转换成值范围在[0,1]的归一化double类数组 im2double 将输入转换为double类.若输入是uint8
  • mat2gray 函数mat2gray可以把任意任意类型图像矩阵转换为取值范围为[0,1]的归一化double类数组。 调用格式 B = mat2gray(A) 将图像矩阵A归一化为图像矩阵B,A的值无限制,调用函数后,B的值限制在[0,1]。 B = mat2...
  • 刚好今天也有需要用三维重建中的深度数据,数据值大于255,自己用matlab可以显示出来,如果直接保存成图片数据都是1,什么都看不到,拿给别人也没有用,于是就想到用mat2gray先将数据进行归一化到(0,1),然后保存...
  • im2double 、mat2gray与double double 就是简单地把一个变量类型转换成double类型,数值大小不变 mat2gray是把一个double类的数组转换成取值范围为[0,1]的归一化double类数组。 函数im2double将输入转换成double类型...
  • 其实主要是因为平时习惯用imshow(img,[]) 看一些 取值范围不在0-255内的图片。比如如果用imshow() 而使用imshow(img,[])就可以了,因为...img_trans=mat2grey(img); 即可将img转成能够保存成图片的样子。 ...
  • matlab中double、im2double、mat2gray区别

    千次阅读 2015-11-03 21:32:58
    原文地址:matlab中double、im2double、mat2gray区别--原创作者:mimi ****************假设某图像数据A(uint8格式)********************** A =  235 200 89 20 >> double(A) %返回与原矩阵...
  • 声明:本文转载自... ****************假设某图像数据A(uint8格式)********************** A =  235 200 89 20 >>double(A) %返回与原矩阵数值相同但类型
  • 1. matlab图像保存说明  matlab中读取图片后保存的数据是uint8类型(8位无符号整数,即1个字节),以此方式存储的图像称作8位图像,好处相比较默认matlab数据类型双精度浮点double(64位,8个字节),自然可以节省...
  • matlab 中matgray函数

    千次阅读 2018-06-11 20:41:47
    在matlab命令窗口中输入: doc mat2gray或者help mat2gray即可获得该函数的帮助信息, 键入type mat2gray可以查看函数的实现代码。 调用格式: I = mat2gray(A, [amin amax]) A为源图像一般...
  • double im2double mat2gray之一二说

    千次阅读 2017-07-22 15:21:57
    tip:首先我们需要知道的是如果要在控制台定义一个矩阵,那么它是double类型的。 a =[235 200 89 20] whos a double double()函数只是单纯地把数据转为double类型的,也就是说如果是uint8的类型的只是把它转换成...
  • // 图像基本操作.cpp : 定义控制台应用程序的入口点。 // #include "stdafx.h" ...#include "cxcore.h" // Mat定义在这里 using namespace cv; int _tmain(int argc, _TCHAR* argv[]) { Mat Img; Img
1 2 3 4 5 ... 20
收藏数 22,125
精华内容 8,850
关键字:

mat2gray