《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 業界動態 > 單片機浮點數的實用快速除法

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

2009-02-24
作者:張玉明1, 王 超2

  摘? 要: 介紹一種在8096/98系列單片機上實現的單精度浮點數快速除法。該算法采用了預估-修正的數值計算方法,并充分利用了16位CPU中的乘除法指令,計算速度快、精度高,有很強的實用性。

  關鍵詞: 浮點數? 除法 尾數? 預估-修正? 誤差? 精度

?

  在較為復雜的單片機系統中,為擴大取值范圍,實現復雜的計算和控制,一般都要涉及浮點數的運算。而一般單片機是沒有浮點數運算指令的,必須自行編制相應軟件。在進行除法計算時,通常使用的方法是比較除法[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與X/YH相差不多:

  

  可見只需要在X/YH的基礎上再乘以一個修正因子(YH-YL)/YH,就可以得到X/Y的一次校準值。不難證明這個值已經達到了24位的精度要求。事實上,相對誤差滿足:

  

  這說明這個一次校準值完全可以作為最終的結果。

3 算法的具體實現

  

  這里的YH雖仍是32位,但其低16位已為0,計算時可以將它視為16位數,這不會影響計算精度。通過兩次16位除法,就可得到精確的32位結果。例如,計算Q0時,第一次除法,X除以YH的高16位,得到的商為Q0的高16位,而16位余數末尾添0成32位,再除以YH的高16位,得到Q0的低16位(余數舍去)。由此得到了32位的Q0

  在具體運算中,X應先除以4(X右移2位),以保證Q0不會溢出(YH取高16位):

  

  在計算Q0′、Q1時,均進行了兩次16位除法,使得Q0′、Q1均為精確的32位,保證了計算過程中的精度,減小了累積誤差。對于YL=0即除數只有16位有效數字的特殊情況,直接有Q1=1,還能省去兩次16位除法。

  在計算Q時,則通過3次16位乘法實現了32位乘法,取結果的高32位,即得Q。

  整個算法至多只須用4次除法、3次乘法和5次加法,就求得了浮點數商的尾數,可見計算效率是很高的,保證了運算速度。

  浮點數除法流程圖如圖3所示。

4 程序源代碼

  限于篇幅,只給出源代碼中的關鍵部分,即有效數字的計算部分。

;被除數為x,除數為y

;用yh,yl分別表示y的高16位和低16位

;假設x,y的有效數字部分分別在(dx,cx)和(bx,ax)中

;計算預估值Q0′=(x/4)/yh

shrl? cx, #2???????? ;計算x/4

divu cx, bx????????? ;計算(x/4)÷yh

ld?fx, cx??? ??????? ;把商暫放入寄存器fx,即Q0′的高16位有

????????????????????? ;效數字

clr?? cx

divu cx, bx????????? ;把余數末尾添0后再除以yh

ld? ex, cx????    ;把商暫放入寄存器ex, 即Q0

??????????????????????;的低16位有效數字

??????????????????????;(fx,ex) = Q0

;計算修正因子 Q1=(yh-yl)/yh

cmp ax, 0??????????? ;判斷yl是否為0

jne?? getQ1?????????? ;若yl非0,計算修正因數Q1

ld?? ax, ex????????? ;若yl=0, 修正因數Q1=1

ld? ?bx, fx????????? ;(Q0′×Q1)=Q0′,可以直接計算Q

sjmp? getQ

getQ1:

ld? hx, bx?????????? ;把yh放于寄存器hx中

neg? ax

dec? bx?????????????? ;計算yh-yl

divu ax, hx????????? ;計算Q1=(yh-yl)÷yh

ld??dx, ax?? ????????;把商暫時放入寄存器dx,即Q1的高16位有

????????????????????? ;效數字

clr?? ax

divu ax, hx?? ?????? ;把余數末尾添0后再除以yh,得Q1的

????????????????????? ;低16位有效數字

ld? bx dx  ??????????;(bx,ax) = Q1

;計算Q0′×Q1=(fx,ex)×(bx,ax),只取32位有效數字

ld???? hx, bx

mulu???cx, bx, ex?? ;(dx,cx) = bx×ex

mulu???ax, fx??????? ;(bx,ax) = ax×fx

clr? ex?

add? cx, ax?

addc? dx, bx?

addc? ex, 0?????????? ;(ex,dx,cx)=(dx,cx)+(bx,ax)?

mulu? ax, fx, hx???? ;(bx,ax) = fx×hx?

add? ax, dx????????? ?;(bx,ax) = (bx,ax)+(ex,dx)?

addc??bx, ex????? ????;(bx,ax) = Q0′× Q1?

;計算校準值Q = (Q0′×Q1)×4并調整階碼

getQ:

  … 

  代碼到這里為止,浮點數商的有效數字已經全部求出。只要再執行一些調整浮點數階碼的操作,就可以得到最終結果。

  在作者開發的一個80C196KC單片機系統中,涉及到了二進制-十進制數制轉換、分段線性插值、數字濾波等大量浮點數的運算,都是靠加減乘除等底層函數來實現的。

  此外,本算法思路清晰,因此很容易加以推廣。例如,為了得到更高的精度,可取修正因子:

  ????

?

參考文獻

1 復旦大學計算機系微機開發研究室.十六位單片機8096的原理和設計方法.重慶:科學技術文獻出版社重

? 慶分社,1988

2 涂時亮,姚志石.單片微機MCS-96/98實用子程序.上海:復旦大學出版社, 1991

3 李慶揚.數值分析. 武漢:華中工學院出版社, 1986

本站內容除特別聲明的原創文章之外,轉載內容只為傳遞更多信息,并不代表本網站贊同其觀點。轉載的所有的文章、圖片、音/視頻文件等資料的版權歸版權所有權人所有。本站采用的非本站原創文章及圖片等內容無法一一聯系確認版權者。如涉及作品內容、版權和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經濟損失。聯系電話:010-82306118;郵箱:aet@chinaaet.com。
欧美激情办公室aⅴ_国产欧美综合一区二区三区_欧美午夜精品久久久久免费视_福利视频欧美一区二区三区

          亚洲小说欧美另类婷婷| 在线一区视频| 国产日韩欧美一区二区三区在线观看 | 午夜在线播放视频欧美| 久久午夜激情| 伊人久久av导航| 国产精品一区二区三区四区五区| 亚洲欧美综合| 夜夜嗨一区二区| 麻豆av福利av久久av| 欧美日韩精品免费观看| 国产亚洲第一区| 激情久久久久久久| 久久综合九色综合欧美狠狠| 亚洲国产精品第一区二区| 久久xxxx精品视频| 一区二区欧美日韩| 极品尤物久久久av免费看| 欧美综合二区| 在线亚洲欧美| 亚洲国产一区二区精品专区| 欧美另类专区| 欧美一区二区三区四区在线观看地址 | 久久亚洲影院| 正在播放亚洲| 伊人久久亚洲热| 欧美日韩理论| 欧美精品播放| 欧美日韩岛国| 欧美特黄a级高清免费大片a级| 久久久久综合| 久久综合九色综合久99| 久久国产精品亚洲77777| 国产亚洲一区在线| 国产伦精品一区二区三区| 亚洲美女啪啪| 一区二区三区四区国产| 一区二区三区四区五区精品视频 | 国产伦精品一区二区| 亚洲精选91| 99一区二区| 中文一区二区| 国产伦精品一区二区三区视频黑人| 亚洲欧洲一区二区天堂久久| 夜夜爽www精品| 国产一区二区三区黄| 亚洲一区二区精品在线| 麻豆精品视频| 国产精品va| 亚洲精品一区二| 中文高清一区| 亚洲欧美国产精品桃花| 久久午夜精品| 亚洲午夜精品福利| av成人激情| 性色一区二区| 欧美午夜免费| 中文在线不卡| 欧美激情视频一区二区三区在线播放| 欧美日本韩国在线| 99精品国产一区二区青青牛奶| 国产精品一区毛片| 欧美~级网站不卡| 亚洲国产三级| 亚洲成色www久久网站| 亚洲在线成人| 欧美日韩免费观看一区=区三区| 欧美精品七区| 中国成人在线视频| 久久亚洲一区| 亚洲人久久久| 午夜精品网站| 中文一区二区| 亚洲一区二区三区免费在线观看| 乱码第一页成人| 亚洲性图久久| 亚洲欧美日韩国产综合精品二区| 欧美先锋影音| 久久国产精品毛片| 亚洲成色www久久网站| 久久久久欧美精品| 国产亚洲毛片在线| 亚洲第一精品影视| 午夜欧美精品| 久久久成人网| 国产精品毛片va一区二区三区| 国精品一区二区三区| 小嫩嫩精品导航| 在线日韩电影| 狠狠爱成人网| 欧美性色综合| 欧美日本国产| 欧美一区免费视频| 麻豆精品传媒视频| 国产精品日韩一区二区 | 麻豆成人小视频| 99re6热在线精品视频播放速度| 久久午夜影视| 免费日韩av| 国产麻豆综合| 国产日韩1区| 99re国产精品| 日韩视频一区| 日韩亚洲精品在线| 影音先锋一区| 亚洲激情午夜| 99pao成人国产永久免费视频| 国产综合亚洲精品一区二| 女女同性女同一区二区三区91 | 亚洲成人在线视频网站| 欧美1区免费| 欧美在线视频一区二区三区| 久久亚洲二区| 欧美日韩高清在线一区| 国产精品v欧美精品∨日韩| 欧美日韩国产三区| 国产在线日韩| 91久久综合| 国产精品呻吟| 久久精品女人的天堂av| 美女黄网久久| 欧美韩日精品| 亚洲福利免费| 国产精品亚洲综合| 久久久夜夜夜| 极品少妇一区二区三区| 亚洲免费播放| 久久久国产亚洲精品| 欧美喷水视频| 亚洲精品专区| 另类av一区二区| 欧美日韩国产探花| 亚洲欧洲精品一区二区| 免费亚洲婷婷| 亚洲午夜高清视频| 亚洲一区二区精品在线观看| 午夜精品av| 一本一道久久综合狠狠老精东影业| 亚洲影音先锋| 欧美三日本三级少妇三99| 99精品免费| 久久青青草原一区二区| 亚洲国产精品一区二区第一页| 中文亚洲欧美| 国模精品一区二区三区| 亚洲永久字幕| 亚洲国内精品| 欧美日韩亚洲一区二区三区在线| 国产亚洲一区二区三区在线播放| 欧美成人在线免费观看| 国产一区二区三区高清| 亚洲无毛电影| 久久久久久夜| 国产区日韩欧美| 国产在线观看一区| 香蕉国产精品偷在线观看不卡| 国产一区二区三区四区hd| 国产一区二区三区成人欧美日韩在线观看 | 国内精品亚洲| 免播放器亚洲| 亚洲免费播放| 韩国久久久久| 欧美va亚洲va日韩∨a综合色| a91a精品视频在线观看| 欧美日韩中文| 久久亚洲国产精品一区二区| 亚洲三级国产| 精品不卡视频| 欧美午夜不卡影院在线观看完整版免费| 99精品久久久| 亚洲激情黄色| 精品电影一区| 黑人中文字幕一区二区三区| 久久精品午夜| 亚洲女人av| 亚洲影院免费| 免播放器亚洲| 久久av一区二区三区| 一区二区三区偷拍| 亚洲乱码视频| 夜夜精品视频| 99香蕉国产精品偷在线观看| 亚洲黄色一区二区三区| 亚洲国产电影| 在线视频观看日韩| 亚洲国产影院| 中文有码久久| 午夜综合激情| 欧美淫片网站| 欧美特黄视频| 今天的高清视频免费播放成人| 亚洲午夜91| 亚洲国产电影| 国产欧美韩日| 国产精品亚洲综合色区韩国| 国产精品三上| 欧美在线高清| 亚洲先锋成人| 亚洲免费播放| 亚洲影视在线| 欧美va天堂在线| 好吊日精品视频| 99精品国产高清一区二区| 在线综合视频| 久久免费国产| 亚洲五月婷婷| 国产精品毛片| 欧美久久综合| 亚洲人成久久| 久久精品国产第一区二区三区最新章节 | 亚洲综合国产激情另类一区| 亚洲一区二区三区涩| 欧美一区=区| 黑人一区二区| 亚洲一区二区在| 欧美午夜精品| 国产日韩精品久久| 欧美精品七区| 国产精品日韩精品欧美精品| 午夜亚洲福利| 国产亚洲毛片| 国产精品va| 久久成人国产| 伊人蜜桃色噜噜激情综合| 先锋影音国产一区| 亚洲第一在线| 欧美精品18| 亚洲欧美日本日韩| 伊人久久大香线蕉综合热线| 西西裸体人体做爰大胆久久久| 黑人一区二区三区四区五区| 久久久久久久久久久一区| 亚洲欧洲综合| 亚洲午夜在线| 欧美日韩国产不卡在线看| 亚洲免费中文| 99国产成+人+综合+亚洲欧美| 欧美理论在线| 牛牛国产精品| 麻豆精品网站| 国产精品一区二区在线观看| 亚洲国产一区在线| 国内精品久久国产| 欧美精品一区二区三区在线看午夜 | 午夜亚洲性色福利视频| 伊人激情综合| 亚洲视屏一区| 欧美体内she精视频在线观看| 久久精品亚洲一区二区| 国产精品乱看| 国产一区二区三区免费不卡| 一本色道久久综合亚洲精品不| 国产综合自拍| 国产综合婷婷| 亚洲性图久久| 在线欧美视频| 亚洲三级观看| 一道本一区二区| 亚洲精品在线免费| 亚洲美女91| 亚洲深夜激情| 男人的天堂亚洲| 久久性天堂网| 国产精品啊啊啊| 在线不卡亚洲| 国产欧美日韩一区| 免费久久99精品国产自在现线| 亚洲一区二区三区欧美| 亚洲欧美视频| 久久在线精品| 欧美高清视频一区二区三区在线观看| 欧美国产精品| 国内外成人免费视频| 亚洲精品激情| 亚洲欧美不卡| 欧美激情第六页| 尤物网精品视频| 国产欧美三级| 老牛影视一区二区三区| 午夜精品一区二区三区四区| 国产一区二区三区四区老人| 91久久国产自产拍夜夜嗨| 一区二区三区欧美成人| 先锋影音久久久| 欧美日韩一区二区三区在线视频 | 亚久久调教视频| 欧美精品一区二区三区久久久竹菊| 欧美日韩在线观看一区二区三区| 国精品一区二区三区| 一区二区福利| 欧美永久精品| 一本久道综合久久精品| 久久精品一区二区国产| 亚洲网站在线| 亚洲欧美bt| 国外成人免费视频| 亚洲一区在线免费| 国产在线精品二区| 一本色道久久综合| 亚洲欧美综合一区| 在线亚洲精品| 国产精品a级| 麻豆久久婷婷| 9色国产精品| aa国产精品| 亚洲三级色网| 一区二区三区导航| 国产精品乱码一区二区三区| 国产欧美欧美| 欧美日韩第一区| 国产欧美亚洲一区| 国产在线视频欧美一区二区三区| 国产精品久久久一区二区三区| 久久天堂精品| 美女诱惑黄网站一区| 欧美国产另类| 亚洲图片欧洲图片日韩av| 国产亚洲一区在线| 欧美日韩mv| 亚洲一区二区四区| 韩国一区二区三区在线观看 | 在线观看成人av| 免费在线成人av| 一本综合精品| 在线不卡亚洲| 国产精品v欧美精品v日韩 | 亚洲国产一区二区三区a毛片| 久久久精品国产一区二区三区| 亚洲久久一区二区| 黑人一区二区三区四区五区| 欧美一区二区三区四区在线观看地址| 国产精品久久久一区二区| 一区在线视频观看| 狠狠综合久久av一区二区老牛| 欧美日本国产| 欧美精品aa| 欧美日韩国产三区| 老妇喷水一区二区三区| 久久婷婷国产综合尤物精品| 亚洲永久网站| 麻豆成人av| 老司机午夜精品视频| 女女同性女同一区二区三区91| 久久综合伊人77777麻豆| 蜜桃av综合| 欧美激情一区| 欧美特黄视频| 亚洲国产精品久久久久婷婷老年| 亚洲视频久久| 亚洲精品孕妇| 亚洲综合好骚| 久久午夜精品| 韩日视频一区| 国产欧美不卡| 久久亚洲综合| 在线精品福利| 亚洲自拍另类| 欧美在线高清| 亚洲图色在线| 国产亚洲毛片在线| 久久中文欧美| 亚洲大片av| 亚洲综合电影一区二区三区| 牛牛国产精品| 99riav1国产精品视频| 乱码第一页成人| 在线观看视频免费一区二区三区| 一区二区精品在线| 欧美在线免费一级片| 亚洲国产午夜| 久久免费99精品久久久久久| 在线国产日韩| 久久久久久黄| 99视频国产精品免费观看| 久久久久久亚洲精品不卡4k岛国| 亚洲视频一区| 久久久久高清| aa级大片欧美三级| 欧美日韩精品不卡| 亚洲一区日韩在线| 激情婷婷亚洲| 欧美a级片一区| 国产精品推荐精品| 亚洲无线视频| 久久综合网络一区二区| 亚洲国产精品综合| 欧美jjzz| 噜噜噜噜噜久久久久久91| 亚洲国产综合在线看不卡| 欧美成熟视频| 久久国产99| 国产一区二区高清不卡| 国产综合亚洲精品一区二| 久久久精品五月天| 国产亚洲一级| 亚洲精品欧洲精品| 亚洲网站啪啪| 欧美日韩精品免费观看| 美女黄网久久| 性色av一区二区怡红|