色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

浮點處理器相對于定點處理器有何不同

電子設計 ? 來源:互聯網 ? 作者:佚名 ? 2018-03-07 08:57 ? 次閱讀

C28x+FPU架構的C2000微處理器在原有的C28x定點CPU的基礎上加入了一些寄存器和指令,來支持IEEE 單精度浮點數的運算。對于在定點微處理器上編寫的程序,浮點C2000也完全兼容,不需要對程序做出改動。浮點處理器相對于定點處理器有如下好處:

編程更簡單

性能更優,比如除法,開方,FFT和IIR濾波等算法運算效率更高。

程序魯棒性更強。

一、IEEE754格式的浮點數

C28x+FPU的單精度浮點數遵循IEEE754格式。它包括:

尾數

表1:IEEE單精度浮點數


(1)非規格化數值非常小,計算公式為(-1)sx2(E-126)x0.M

(2)正常范圍數值計算公式為(-1)sx2(E-127)x1.M

正常范圍數值落在± ~1.7 x 10 -38 to ± ~3.4 x 10 +38范圍內。從表1可以看出,IEEE754標準包括:

標準數據格式和特殊值,比如非數值(NaN)和無窮大

標準舍入模式和浮點運算

多平臺支持,包括德州儀器C67x系列芯片。

C2000對該標準作了一些簡化:

狀態標志位和比較運算不區分正0和負0

非規格化數值被認為是0

對非數值(NaN)處理方式和無窮大一樣。

IEEE754標準有5種舍入模式,C28x+FPU只支持其中兩種:

--截斷:小數位不管大小全部舍去

--就近舍入向偶舍入:這種模式下如果小數位小于5就舍去,大于5就進位,如果小數位為5,則舍入到最近的偶數。

表2展示了不同的舍入模式對數據的影響。C28x+FPU編譯器默認將微處理器配置為就近舍入向偶舍入模式[1]。

表2:不同舍入模式示例


??

二、浮點C2000芯片運算技巧和注意點

浮點數的精度由尾數位決定,絕大多數的數在用浮點數表示時都會有誤差,這些誤差很小,多數情況下可以忽略,但是在經過多次計算后這個誤差可能會大到無法接受。

下面用實例來進行說明,下面一段代碼定義float類型變量,分別在TI最新的Delfino芯片F28379D的CPU1和CLA1上,將11.7加20001次。

float CLATMPDATA=0;

int index=20001;

while(index--)

{

CLATMPDATA=CLATMPDATA+11.7;

}

得到如下結果:

其中CLATMPDATA1是在CLA中將11.7加20001次得到的結果,CLATMPDATA2是在CPU中將11.7加20001次得到的結果。可以看出兩者所得到的結果不同,并且都和正確結果234011.7有較大差距。

為何CPU和CLA計算結果不同?

CPU和CLA運算結果的不同是由于其對浮點數的舍入模式的不同造成的,前文已經說過,C28x+FPU 編譯器默認將CPU配置為就近舍入向偶舍入模式。而CLA不同,CLA默認為截斷舍入模式[2]。在CLA的代碼中,我們可以通過增加下述代碼:

__asm(" MSETFLG RNDF32=1");//1為就近舍入向偶舍入,0為截斷舍入

將CLA的舍入模式更改為就近舍入向偶舍入模式,然后再運行代碼,可以得到和CPU同樣的結果。

2. 為何CPU和CLA計算結果都有較大誤差?如何解決?

11.7在用IEEE754格式的浮點數表示時為0x413b3333,其對應的實際值為11.69999980926513671875,可以看出誤差很小,但是經過多次累加多次舍入后得到的結果誤差較大,對此,我們可以將CLATMPDATA定義為long double型變量(64位),再次運行相同的代碼,可以得到如下結果,可以看到誤差很小可以忽略。

需要指出的是,現有的C28x CPU只支持單精度(32位)的硬件浮點運算,對于64位雙精度浮點數的運算都是通過軟件實現的,所以其運算速率會慢很多。另外CLA不支持64位數。

在這個實例中,我們可以分別觀察float類型變量和long double類型變量的匯編代碼如下:

C code: CLATMPDATA2=CLATMPDATA2+11.7;

如果CLATMPDATA2是float型變量,則相應的匯編代碼為:

00c08d: E80209D8 MOVIZ R0, #0x413b 1cycle

00c08f: E2AF0112 MOV32 R1H, @0x12, UNCF 1cycle

00c091: E8099998 MOVXI R0H, #0x3333 1cycle

00c093: E7100040 ADDF32 R0H, R0H, R1H 2cycle

00c095: 7700 NOP 1cycle

00c096: E2030012 MOV32 @0x12, R0H 1cycle

如果CLATMPDATA2是long double型變量,則相應的匯編代碼為:

00c08b: 7680005A MOVL XAR6, #0x00005a 1cycle

00c08d: 8F00005A MOVL XAR4, #0x00005a 1cycle

00c08f: 8F40C26A MOVL XAR5, #0x00c26a 1cycle

00c091: FF69 SPM #0 1cycle

00c092: 7640C0C9 LCR FD$$ADD 4cycle(跳轉耗時)

+25cycle(FD$$ADD函數內部需要25cycle)

可以看出CPU對float類型數執行一次加法耗時7個cycle,對long double類型數執行一次加法耗時33個cycle。

三、結論

1. C2000的CPU和CLA默認的舍入模式不同,在計算浮點數時可能會得到不同的結果,但是我們可以通過代碼改變其舍入模式得到相同的結果。

2. 單精度浮點數經過多次計算后可能會有較大誤差,可以通過將變量定義為64位long double型解決精度問題。

3. C28x CPU只支持單精度(32位)的硬件浮點運算,對于64位雙精度浮點數的運算都是通過軟件實現的,所以其運算速率會慢很多。在下一代的C2000產品中我們會實現對64位雙精度浮點數運算的硬件支持。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • cpu
    cpu
    +關注

    關注

    68

    文章

    10951

    瀏覽量

    213945
  • 微處理器
    +關注

    關注

    11

    文章

    2314

    瀏覽量

    83071
  • C2000 c
    +關注

    關注

    0

    文章

    3

    瀏覽量

    10306
收藏 人收藏

    評論

    相關推薦

    用FPGA 嵌入式處理器實現高性能浮點元算

    APU 接口與處理器的緊密結合可讓浮點運算單元直接執行原生 PowerPC 浮點指令,這相對軟件仿真而言,速度一般可提高 6 倍。除少數情況外,賽靈思 PowerPC FPU 一般符
    發表于 08-03 11:15

    請問定點處理器處理浮點數精度多高?

    最近接觸到了DSP處理器,關于定點處理器處理浮點運算兩個疑問,我是用C語言開發的,16位
    發表于 05-13 01:09

    dsp33EP256mu810是定點處理器還是浮點處理器

    我怎么知道?我想做的網格接口PLL。我是否去FordSP33 EP256MU810系列?ISDSP33 EP256MU810是浮點處理器
    發表于 04-27 06:09

    定點處理器浮點處理器的選擇

    浮點處理器的優點眾所周知。毫無疑問,許多算法的浮點實現執行起來比定點代碼占用更少的周期(當然,假設定點代碼提供相同的精度)。
    發表于 08-25 17:31 ?0次下載

    ARM處理器浮點運算單元

      Float Point Unit,浮點運算單元是專用于浮點運算的協處理器,在計算領域,例如三角函數以及時域頻域變換通常會用到浮點運算。
    發表于 09-16 11:28 ?6次下載

    SHARC處理器滿足一高二低的浮點設計需求

    DSP的比較優勢是浮點算法擁躉者們在浮點定點之爭的話題中常提及的,也為大多數嵌入式設計工程師所熟知。 然而,由于電路復雜性和制造工藝上的原因,浮點處理器
    發表于 11-02 11:26 ?0次下載
    SHARC<b class='flag-5'>處理器</b>滿足一高二低的<b class='flag-5'>浮點</b>設計需求

    讓新型SHARC處理器滿足“一高二低”的浮點設計需求

    DSP的比較優勢是浮點算法擁躉者們在浮點定點之爭的話題中常提及的,也為大多數嵌入式設計工程師所熟知。 然而,由于電路復雜性和制造工藝上的原因,浮點處理器
    發表于 11-02 11:46 ?0次下載
    讓新型SHARC<b class='flag-5'>處理器</b>滿足“一高二低”的<b class='flag-5'>浮點</b>設計需求

    TMS320C6654定點浮點數字信號處理器詳細資料概述

    本文的主要內容介紹的是TI的產品TMS320C6654定點浮點數字信號處理器的詳細資料概述
    發表于 04-27 08:59 ?10次下載
    TMS320C6654<b class='flag-5'>定點</b>和<b class='flag-5'>浮點</b>數字信號<b class='flag-5'>處理器</b>詳細資料概述

    FPGA簡單入門和邏輯塊與相對于處理器的并行操作

    4分鐘的FPGA簡單入門介紹,主要介紹了邏輯塊、相對于處理器的并行操作。搬運于YouTube,字幕自制。
    的頭像 發表于 08-29 06:05 ?2613次閱讀

    基于TI TMS320C6748定點/浮點DSP C674x處理器

      TI TMS320C6748定點/浮點DSP C674x處理器提供語音、算法、圖像、視頻等多種類型實驗提供教學實驗指導手冊和完整的實驗代碼。
    的頭像 發表于 11-10 10:20 ?3297次閱讀
    基于TI TMS320C6748<b class='flag-5'>定點</b>/<b class='flag-5'>浮點</b>DSP C674x<b class='flag-5'>處理器</b>

    定點處理器TMS320C2000的IQmath庫解決方案

    DSP數字信號處理器分為定點浮點兩種基本類型,它們之間最大差異在于浮點DSP比定點DSP具有更強大的計算能力和更大范圍的動態精度。
    發表于 08-10 16:54 ?2288次閱讀

    C2000浮點運算注意事項:CPU和CLA的差異及誤差處理技巧

    C28x+FPU架構的C2000微處理器在原有的C28x定點CPU的基礎上加入了一些寄存和指令,來支持IEEE 單精度浮點數的運算。對于
    的頭像 發表于 04-06 10:30 ?2098次閱讀

    TMS320C6671定點浮點數字信號處理器數據表

    電子發燒友網站提供《TMS320C6671定點浮點數字信號處理器數據表.pdf》資料免費下載
    發表于 08-05 11:17 ?0次下載
    TMS320C6671<b class='flag-5'>定點</b>和<b class='flag-5'>浮點</b>數字信號<b class='flag-5'>處理器</b>數據表

    TMS320C6743定點浮點數字信號處理器數據表

    電子發燒友網站提供《TMS320C6743定點浮點數字信號處理器數據表.pdf》資料免費下載
    發表于 08-07 11:37 ?0次下載
    TMS320C6743<b class='flag-5'>定點</b>和<b class='flag-5'>浮點</b>數字信號<b class='flag-5'>處理器</b>數據表

    TMS320C6654定點浮點數字信號處理器數據表

    電子發燒友網站提供《TMS320C6654定點浮點數字信號處理器數據表.pdf》資料免費下載
    發表于 08-07 10:11 ?1次下載
    TMS320C6654<b class='flag-5'>定點</b>和<b class='flag-5'>浮點</b>數字信號<b class='flag-5'>處理器</b>數據表
    主站蜘蛛池模板: 麻豆精品乱码WWW久久密 | 99精品中文字幕在线观看 | 4k岛国精品午夜高清在线观看 | 姐姐不~不可以动漫在线观看 | 成人在线精品视频 | 24小时日本在线 | 久9视频这里只有精品123 | 国产传媒在线观看 | 好吊妞国产欧美日韩视频 | 国产亚洲精品精品国产亚洲综合 | tube69hdxxxx日本 | 哒哒哒影院在线观看免费高清 | 99久久精品6在线播放 | 美女胸禁止18以下看 | 中文字幕欧美日韩VA免费视频 | 影音先锋av天堂 | 亚洲A片不卡无码久久尤物 亚洲a免费 | 真实国产精品视频国产网 | 国产色情短视频在线网站 | 公和我做好爽添厨房中文字幕 | chinese东北老年tv视频 | 日韩亚洲国产中文字幕欧美 | 青草久久精品亚洲综合专区 | 亚洲国产区中文在线观看 | 国精产品一区二区三区四区糖心 | 久久精品无码一区二区日韩av | 亚洲精品人成电影网 | 国产h视频在线观看免费 | 免费成年人在线视频 | 中文字幕网站在线观看 | 男女做爽爽爽视频免费软件 | 蜜芽在线影片 | 欧美激情一区二区三区四区 | 欧美特黄99久久毛片免费 | 99婷婷久久精品国产一区二区 | 亚洲视频在线观看免费 | 成人久久欧美日韩一区二区三区 | cctv论坛| 久久精品动漫99精品动漫 | 久久久精品久久久久特色影视 | 寂寞护士中文字幕 mp4 |