<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > 單片機(jī)浮點(diǎn)數(shù)的實(shí)用快速降法

          單片機(jī)浮點(diǎn)數(shù)的實(shí)用快速降法

          作者: 時(shí)間:2012-03-08 來(lái)源:網(wǎng)絡(luò) 收藏

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

          1 浮點(diǎn)數(shù)格式

          IEEE的浮點(diǎn)數(shù)標(biāo)準(zhǔn)規(guī)定了單精度(4字節(jié))、雙精度(8字節(jié))和擴(kuò)展精度(10字節(jié))三種浮點(diǎn)數(shù)的格式。最常用的是單精度浮點(diǎn)數(shù),格式如圖1所示。但是這種格式的階碼不在同一個(gè)字節(jié)單元內(nèi),不易尋址,從而會(huì)影響運(yùn)算速度。

          通常在單片機(jī)上采用的是一種變形格式的浮點(diǎn)數(shù),如圖2所示。其中的23位加上隱含的最高位1,構(gòu)成一個(gè)定點(diǎn)原碼小數(shù),即為小于1大于等于0.5的小數(shù)。有關(guān)浮點(diǎn)數(shù)格式的詳細(xì)內(nèi)容請(qǐng)參考有關(guān)文獻(xiàn)[1][2]。

          2 快速除法的算法原理

          在16 位單片機(jī)中只有16位的乘除法,而浮點(diǎn)數(shù)的精度(即的有效位數(shù))達(dá)24位,因此無(wú)法直接相除,但依然可以利用16位的乘除法指令來(lái)實(shí)現(xiàn)24位除法。不過(guò),如果只進(jìn)行一次16位的除法必定會(huì)帶來(lái)很大誤差,因此問(wèn)題的關(guān)鍵在于如何消除這個(gè)誤差,從而達(dá)到要求的精度。這其實(shí)就是通常數(shù)值計(jì)算中所采用的預(yù)估- 修正方法。

          假設(shè)兩個(gè)浮點(diǎn)數(shù)經(jīng)過(guò)預(yù)處理后,被除數(shù)和除數(shù)尾數(shù)擴(kuò)展為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


          上一頁(yè) 1 2 3 下一頁(yè)

          評(píng)論


          相關(guān)推薦

          技術(shù)專(zhuān)區(qū)

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();