新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > 單片機浮點數的實用快速降法

        單片機浮點數的實用快速降法

        作者: 時間:2012-03-08 來源:網絡 收藏

        在較為復雜的單片機系統中,為擴大取值范圍,實現復雜的計算和控制,一般都要涉及的運算。而一般單片機是沒有運算指令的,必須自行編制相應軟件。在進行除法計算時,通常使用的方法是比較除法[1],即利用循環移位和減法操作來得到24~32 位商,效率很低。有些文獻給出了一些改進方法[2],但思想不清晰,很難推廣使用。這里給出一種除法運算的實用快速算法。該方法以數值計算中的預估 -修正方法為指導,充分利用了16位單片機的乘除法功能,很輕易地實現了浮點數的除法。

        1 浮點數格式

        IEEE的浮點數標準規定了單精度(4字節)、雙精度(8字節)和擴展精度(10字節)三種浮點數的格式。最常用的是單精度浮點數,格式如圖1所示。但是這種格式的階碼不在同一個字節單元內,不易尋址,從而會影響運算速度。

        通常在單片機上采用的是一種變形格式的浮點數,如圖2所示。其中的23位加上隱含的最高位1,構成一個定點原碼小數,即為小于1大于等于0.5的小數。有關浮點數格式的詳細內容請參考有關文獻[1][2]。

        2 快速除法的算法原理

        在16 位單片機中只有16位的乘除法,而浮點數的精度(即的有效位數)達24位,因此無法直接相除,但依然可以利用16位的乘除法指令來實現24位除法。不過,如果只進行一次16位的除法必定會帶來很大誤差,因此問題的關鍵在于如何消除這個誤差,從而達到要求的精度。這其實就是通常數值計算中所采用的預估- 修正方法。

        假設兩個浮點數經過預處理后,被除數和除數尾數擴展為32位(末8位為0)分別放入X和Y中。鄰YL為Y的低16位,并記YH=Y-YL。顯然YH≈Y,X/Y與Y/YH相差不多:

        (X/Y)/(X/YH)=(YH/Y)

        =YH/(YH+YL)

        =1/(1+YL/YH)

        ≈1-YL/YH

        =(YH-YL)/YL


        上一頁 1 2 3 下一頁

        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 高雄县| 汤原县| 鹤山市| 咸丰县| 开封县| 澄迈县| 晋中市| 新余市| 英德市| 化州市| 洛南县| 隆子县| 斗六市| 边坝县| 凤庆县| 武鸣县| 江门市| 穆棱市| 阿鲁科尔沁旗| 礼泉县| 上栗县| 太谷县| 邛崃市| 洞头县| 抚顺市| 乐山市| 清流县| 普兰县| 嘉定区| 永善县| 开化县| 镇原县| 灌南县| 南丰县| 尖扎县| 靖远县| 武宁县| 荥阳市| 内乡县| 双流县| 临澧县|