新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > AVR單片機定點運算及數制轉換子程序

        AVR單片機定點運算及數制轉換子程序

        作者: 時間:2012-04-05 來源:網絡 收藏

        (5)開平方SQR

        操作:(R17,R16,R15,R14)→R14,R13,R12

        可視為雙字型整數X(≤4294967295)開平方,因有舍入處理,方根最大可達$10000(如X=$FFFF0000開平方即屬此),故用3字節存儲平方根。也可視為小數開平方,將X自最高位起每2位進行分割,采用摸擬手算的方法(X每左移2位試出1位根)開平方。

        3 數制

        該組整數二翻十、定點整數十翻二、定點小數二翻十和定點小數十翻二等4個子程序組成,分別稱為CONV1、CONV2、CONV3和CONV4。由于AT90系列只有字節乘字節指令,計算功能不強,故采用移位調整法實現多字節數據的數制。其中,整數二翻十子程序CONV1和小數十翻二子程序CONV4采取左移調整的方法,而整數十翻二子程序CONV2和小數二翻十子程序CONV3采用右移調整的方法。不論左移還是右移,調整總是對十進制數進行,其目的是使十進制數的移位規則符合于二進制數移位規則:左移1位值增倍,右移1位值折半。當某位BCD中的最高位(8)左移移入高位BCD中時,按二進制數看待應為16,而按十進制數相鄰位看待只能為10,故要做加6調整。另外,左移過程中若出現非法BCD碼時也要對其調整。BCD碼左移只不過是BCD碼相加的特例,故調用 BCD碼相加調整子程序ADAA1就可完全解決左移調整問題。當右移BCD碼時,若某位BCD中的1移入低位BCD最高位,按二進制數看待,1折半應為 0.5,而低位BCD中最高位值為0.8,故要做減3(即0.3)調整。因8421BCD碼其各位之權(某位上的1所代表的實際數值)分別為8、4、2和 1,若只在本碼位內部移動,則符合左移1位值增倍、右移1位值折半的規則,故不須調整。

        本組定點及數制子程序為適應大多數應用場合而設,具體使用時可加以修改。如整數二翻十時,二進制數不超過$FFFF,為提高運行速度,可將二進制數改為二字節,十進制數改為3字節,并將移位循環次數(R21)改為16。如數據精度不夠,可把乘法子程序改為3字節乘3字節等等。

        ADAA1為左移BCD碼并對其進行調整的子程序。

        RDAA為對右移后的BCD碼進行測試、實施減3調整的子程序,以R20為工作單元。

        注:開平方子程序SQR說明中,請將對開平方數R17、R16、R15、R14加上完整根號。

        參考文獻

        1 宋建國,等. 原理及其應用. 北京:北京航空航天大學出版社, 2000
        2 張克彥. MCS-51/196浮點程序和實用程序(2.2.7 2.4.1 3.1.2 3.1.3等小節). 北京:北京航空航天大學出版社, 2001


        上一頁 1 2 下一頁

        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 临夏县| 阜宁县| 日喀则市| 凌源市| 阿鲁科尔沁旗| 江华| 礼泉县| 乌鲁木齐市| 陇西县| 土默特右旗| 禹城市| 谢通门县| 习水县| 马山县| 达拉特旗| 克什克腾旗| 福海县| 水富县| 原阳县| 浦江县| 朝阳县| 华宁县| 余江县| 西乡县| 阳新县| 平泉县| 湖北省| 家居| 浏阳市| 黄冈市| 静宁县| 安徽省| 贡觉县| 伊吾县| 宣城市| 岑溪市| 通江县| 綦江县| 贺州市| 个旧市| 红原县|