Matlab中double,im2double,mat2gray區別
轉載:http://blog.sina.com.cn/s/blog_6c41e2f30101559d.htm
****************假設某影象資料A(uint8格式)**********************
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。
1. 在Matlab對影象處理過程中,影象是unit型別,所以imshow等這些關於影象的函式,預設輸入都是uint格式的,其他格式的資料顯示會有預設改動,需要注意。另一方面,在MATLAB的矩陣運算中要求所有的運算變數為double型(雙精度型)。因此通常使用im2double函式將影象資料轉換成雙精度型資料再進行計算。
2. 有時需要把影象以mat的方式進行儲存(multispectral images), 那麼mat只能儲存double型別的資料,所以最好先用im2double將uint型別的圖片轉為[0 1]範圍內的資料儲存於mat中,將來使用的時候再用im2uint8 or im2uint16轉換回影象。
3. uint16和uint8之間的轉換,使用im2double 作為中間橋樑,或者:img8 = uint8(img16 / 256)。