線上訂房服務-台灣趴趴狗聯合訂房中心
發文 回覆 瀏覽次數:3300
推到 Plurk!
推到 Facebook!

想請問 想要撰寫 與IEEE 754浮點數不同格式 像C語言的float自訂型態 來轉換的問題

答題得分者是:dllee
inanang
一般會員


發表:3
回覆:2
積分:1
註冊:2007-12-23

發送簡訊給我
#1 引用回覆 回覆 發表時間:2008-03-07 21:39:49 IP:61.229.xxx.xxx 訂閱
1.碰到鐵板了  撰寫類似 但不同C語言 的 float 型態轉換(規格如下表) 請注意喔與IEEE 754 不同
例如: (十進位 ) 12.3456789 10------------>轉換成(二進位)10101010101010102(<---這是自己掰的喔 )
Bit #
Bit #
LSB
-00-
Exponent
-01-
-02-
-03-
-04-
-05-
-06-
-07-
-08-
-00-
Mantissa
Least Significant
Part (LSP)
-01-
-02-
-03-
-04-
-05-
-06-
-07-
3
Mantissa
Middle Significant
Part
-01-
-02-
-03-
-04-
-05-
-06-
-07-
4
Mantissa
Most Significant
Part (MSP)
-01-
-02-
-03-
-04-
-05-
-06-
-31-
-07-
15
31
Byte #1
13
11
9
7
5
3
1
M-LSB
Exponent
Byte #3
29
27
25
23
21
19
17
Mantissa MSP
Data Type Representation - "CAPS spfp"
------
inanang
編輯記錄
inanang 重新編輯於 2008-03-07 21:41:43, 註解 無‧
inanang 重新編輯於 2008-03-07 21:43:58, 註解 無‧
inanang 重新編輯於 2008-03-07 21:48:59, 註解 無‧
dllee
站務副站長


發表:321
回覆:2519
積分:1711
註冊:2002-04-15

發送簡訊給我
#2 引用回覆 回覆 發表時間:2008-03-08 11:12:54 IP:59.105.xxx.xxx 訂閱
會用到自定的 floating point,大部分是為了使用非 x86 相容的處理器,或不支援 IEEE754 的浮點運算器。
如果是只要數值的轉換,可以利用位元運算
例如:
(MSB) FFFFFFFFFFFFFFFFFFFFFFF
IEEE 754 的格式: (MSB)

其差別只有 EXP 在前或在後的差別,將這些位元 Shift 後再重組即可,
會用到 >> 或 << 或 | 或 & 或 ^ 等位元運算子。
想要用 structure /union 就要了解位元宣告方式:

typedef struct
{
unsigned E:8;
unsigned F:23;
unsigned S:1;
} BitCAPS;
typedef struct
{
unsigned F:23;
unsigned E:8;
unsigned S:1;
} BitIEEE;

typedef union
{
BitIEEE Bit;
float Float;
unsigned int U32;
} FloatIEEE;

typedef union
{
BitCAPS Bit;
unsigned int U32;
} FloatCAPS;

FloatIEEE a;
FloatCAPS b;
a.Float=100.001;
b.Bit.S=a.Bit.S;
b.Bit.E=a.Bit.E;
b.Bit.F=a.Bit.F;
...



VMASKVMIO-Server / HMI / SECS/GEMblog.yam.com/dlleedllee's StatPlus
------
http://www.ViewMove.com
inanang
一般會員


發表:3
回覆:2
積分:1
註冊:2007-12-23

發送簡訊給我
#3 引用回覆 回覆 發表時間:2008-03-08 19:14:26 IP:218.161.xxx.xxx 訂閱
dlee前輩 謝啦(不是洩了喔 有點A) 讓迷途的小羊有了提示方向!!!
------
inanang
系統時間:2024-03-29 20:13:39
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!