• <li id="00i08"><input id="00i08"></input></li>
  • <sup id="00i08"><tbody id="00i08"></tbody></sup>
    <abbr id="00i08"></abbr>
  • 新聞中心

    EEPW首頁 > 測試測量 > 設計應用 > Cortex-M3內核浮點型運算的研究與實現

    Cortex-M3內核浮點型運算的研究與實現

    作者: 時間:2011-03-11 來源:網絡 收藏

    摘要:通過分析3的結構與型格式,充分利用3中的分支預測、單周期乘法、硬件除法等眾多功能強大的特性,使用Thumb-2指令集實現了單精度型的加、減、乘、除與比較,并給出了加減法的流程圖和除法的源程序。
    關鍵詞:3型;速度

    本文引用地址:http://www.czjhyjcfj.com/article/195058.htm

    引言
    在一些較為復雜的運算中,經常需要處理取值范圍大、精度高的浮點型數據。但一般的低端嵌入式內核中沒有浮點型硬件運算器,因此處理語音信號等數據比較困難。本文提出了一種基于Cortex-M3內核的浮點型運算的處理方法。

    1 Thumb-2指令集與COrtex-M3內核結構
    Thumb-2指令集具有以下優點:許多指令(包括乘法相關指令、突破性的32位硬件除法指令等)都是單周期的,并且位段處理指令取指都按32位處理。
    Cortex-M3是一個32位處理器內核,采用哈佛結構,擁有獨立的指令總線和數據總線,可以讓取指與數據訪問并行不悖。它具有如下特點:功耗低,有睡眠、停機和待機3種模式;實時性好;響應中斷快,而且響應中斷所需的周期數是確定的;采用Thumb-2指令集,使得代碼
    密度和執行效率更高。

    2 浮點數的格式
    IEEE的浮點型數據標準規定,浮點數具有單精度(4字節)、雙精度(8字節)和擴展精度(10字節)三種浮點型格式。在實際的應用中,使用最多的是單精度浮點數,格式如下:

    a.JPG
    浮點數表示為:X=MsEsEm-1…E1E0 M-1M-2…M-n。IEEE標準規定:階碼用移碼;尾數的符號位用1表示負數,0表示正數;尾數的數據位用原碼表示,并且隱藏了第24位(即M-1),M-1為1,所以尾數是大于等于0.5小于1的小數。
    階碼用移碼表示、尾數用原碼表示浮點數的好處:
    ①浮點數據零的所有位均為零。
    ②2個浮點數比較大小時,可不必區分階碼位和數據位,視為有符號32位整型數據比較。

    3 浮點型運算的具體實現
    3.1 加減運算
    Cortex-M3是32位的內核,可以把單精度浮點數存儲為32位的有符號整數,這樣便于比較運算。加減運算的流程如圖1所示。

    b.JPG


    上一頁 1 2 3 下一頁

    評論


    相關推薦

    技術專區

    關閉
    主站蜘蛛池模板: 湖口县| 信宜市| 花莲县| 新昌县| 钟祥市| 三河市| 梨树县| 大石桥市| 丽江市| 邛崃市| 余江县| 太和县| 尤溪县| 台北县| 禄丰县| 徐水县| 郓城县| 正镶白旗| 永安市| 宁南县| 泾源县| 宁城县| 井研县| 彭泽县| 双牌县| 沙雅县| 河西区| 沧州市| 玉树县| 屯昌县| 天峻县| 滨州市| 玉龙| 望都县| 陆良县| 治多县| 洛宁县| 哈密市| 五台县| 威宁| 志丹县|