matlab中double、im2double、mat2gray區別

****************假設某圖像數據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。

在實際的對圖像處理過程中,由於我們讀入圖像是unit8型,而在MATLAB的矩陣運算中要求所有的運算變量爲double型(雙精度型)。因此通常使用im2double函數將圖像數據轉換成雙精度型數據。


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章