新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > PIC單片機浮點數格式與十進制數之間的轉換及程序設計

        PIC單片機浮點數格式與十進制數之間的轉換及程序設計

        作者: 時間:2012-01-17 來源:網絡 收藏

        在我們設計的儀表中采用系列,碰到了浮的運算問題,查閱其有關資料發現,其浮及其與,與我們常用的MCS-51所提供的三字節、四字節浮完全不同,本文將說明其浮點數的及其與步驟。

        1 浮點數的

        Microchip公司所采用的浮點數格式是IEEE-754標準的變異型。32位浮點數格式為:



        其中:×表示一位二進制數0或1;eb為指數的偏差;S為浮點數的符號位,S=0為正數,S=1為負數;小數點“·”在符號位S的右邊;BY0BY1BY2為尾數的小數部分。

        應特別注意:

        ⑴浮點數隱含其整數部分為1。

        0的浮點數表示為00H,00H,00H,00H。

        2 浮點數與十進制數的相互

        2.1 十進制數轉換成浮點數

        設:十進數為A,則2Z=A,Z=lnA/ln2,指數P=int(z);尾數部分X:X=A/2P,其整數部分隱含為1(零除外),將其小數部分按原碼格式化為二進制數,即為尾數的小數部分BY0BY1BY2。而指數偏差eb=P+7FH(其中的7FH為指數的偏移量)。符號位S,視十進制數的正負而確定。

        例如十進制數50.265化為32位規格化浮點數:A=50.265,則Z=ln50.265/ln2,P=int(Z),故P=5;X=A/2P=50.265/25=1.57078125,將0.57078125化為23位二進制小數,即是BY0BY1BY2,在最高位添上十進制數的符號位S(因十進制數為正數,故S=0);而eb=P+7FH,所以,十進制數50.265的32位規格化浮點數即為84H,49H,0FH,5CH。

        2.2 浮點數轉換為十進制數

        設浮點數為ebS.BY0BY1BY2。由于浮點數隱含尾數的整數為1,故尾數X的實際值為:

        BY0BY1BY2;指數P=eb-7FH;故:十進制數

        A=(-1)S×2P×X

        例:32位規格化浮點數84H,49H,0FH,5CH轉換為十進制數。

        符號位S=0;指數P=84H-7FH,故P=5;尾數的小數部分為49H,0FH,5CH左移一位,而尾數的整數部分隱含為1,故尾數X的實際值為:1.57078123;十進制數A=(-1)0×25×1.57078123,即A=50.265。

        3 浮點數與十進制數相互轉換的

        3.1 浮點數轉換為十進制數的

        (1)檢測浮點數是否為零;若為零,則十進制數整數部分和小數部分均為零。

        (2)保存浮點數的符號位,將浮點數隱含的1置于浮點數的符號位,指數偏差eb加1,小數點移到原浮點數的符號位之前。

        (3)判斷指數偏差大于7FH否?若小于等于7FH,則該進制數整數部分為零,浮點數尾數部分右移n次(注:n=7FH-指數偏差eb),即求得二進制小數部分。若大于7FH,則將小數點右移n’次(注:n’=指數偏差eb-7FH),即求得二進制整數部分和小數部分。

        (4)將二進制整數部分轉換為十進制整數;將二進制小數部分轉換為十進制小數。至此,完成了浮點數到十進制數的轉換。

        3.2 十進制數轉換為浮點數的程序設計

        (1)檢測十進制數是否為零,若為零,則浮點數置成00H,00H,00H,00H。

        (2)保存十進制數的符號位,將十進制數的整數部分轉換為二進制整數,將十進制數的小數部分轉換為二進制小數(設二進制整數為三個字節,二進制小數為兩個字節)。

        (3)將浮點數的指數偏差eb置為7FH+23,檢測二進制整數的最高位是否為1,不是,則將二進制整數和二進制小數聯合左移,左移一次,指數偏差減1,直至二進制整數的最高位為1;隱含尾數整數的1,將二進制整數的最高位改為數的符號位。至此,指數偏差eb單元及原二進制整數的三個單元中的內容,即構成四字節浮點數。

        最后應該指出,本文所述32位浮點數,精度相當于7位十進制數;32位浮點數運算程序在Microchip公司提供的有關資料中均有,但是,在調試其浮點子程序時,發現0減0的結果為00H,80H,00H,00H,而不是00H,00H,00H,00H,編程時應注意。

        4 結語

        本文中的十進制數與浮點數之間相互轉換的程序設計,在智能化儀表的鍵盤置數及數據顯示中,具有實用價值。這里提出了一種設計思路,沒有復雜的算法,程序設計亦較簡單,工作量較少,可利用Microchip公司提供的現成子程序實現十進制整數與二進制整數的相互轉換,十進制小數與二進制小數的相互轉換。

        本文引用地址:http://www.104case.com/article/172232.htm


        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 周宁县| 海阳市| 丽水市| 谷城县| 泌阳县| 吉林省| 新邵县| 明溪县| 雷州市| 怀来县| 中方县| 营山县| 绥江县| 游戏| 广平县| 汤原县| 甘肃省| 东兴市| 泸州市| 钟祥市| 昌乐县| 鹿邑县| 西乌珠穆沁旗| 会东县| 兴义市| 启东市| 昌图县| 庆城县| 宣汉县| 七台河市| 景泰县| 沅江市| 镇沅| 遂平县| 呼图壁县| 临颍县| 平乐县| 观塘区| 濉溪县| 嘉善县| 高要市|