<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>

新聞中心

EEPW首頁(yè) > 嵌入式系統 > 設計應用 > DSP里的數據類(lèi)型,你都認得它們么

DSP里的數據類(lèi)型,你都認得它們么

作者: 時(shí)間:2016-12-21 來(lái)源:網(wǎng)絡(luò ) 收藏
  DSPC/C++編程時(shí)有多少種數據類(lèi)型?float,double和long double,long和long long這些繞口的名字究竟有什么區別?數據類(lèi)型使用不正確又會(huì )有什么后果?如果你感覺(jué)說(shuō)不清楚,那我們來(lái)看看這些到底都是何方神圣吧:

表1 C28xC/C++支持的數據類(lèi)型

本文引用地址:http://dyxdggzs.com/article/201612/332419.htm


? 64位整數的處理

  從上面的表中,可以看出C28x的編譯器是支持64位的整數類(lèi)型的,這使得在處理某些高精度智能編碼器的反饋數據時(shí)特別方便,因為在更老的不支持64位整數類(lèi)型的器件上編程時(shí),需要我們自己定義64位類(lèi)型,在運算時(shí)要自己定義運算規則才行。一個(gè)long long類(lèi)型的整數需要使用ll或者LL前綴,才能被I/O正確處理,例如,我們使用下面的代碼才能正確把它們顯示在屏幕上:

  printf("%lld", 0x0011223344556677);

  printf("%llx", 0x0011223344556677);

  需要注意的是,雖然編譯器支持了64位整數,但是實(shí)際的CPU的累加器還有相關(guān)的CPU寄存器還是32位的,在程序運行時(shí),64位整數類(lèi)型是被CPU“軟支持”的。我們可以添加相關(guān)的實(shí)時(shí)運行庫來(lái)提高效率,其中包含了llabs(), strtoll() 和strtoull()等函數。

  ? 浮點(diǎn)的處理

  從表1中我們可以看出,C28x的編譯器支持32位的單精度浮點(diǎn)、64位的單精度和雙精度浮點(diǎn)運算。在定義雙精度64位變量時(shí),也要記得使用l或者L前綴,否則會(huì )被視為雙精度的32位變量,造成精度的損失。例如:

  long double a = 12.34L; /* 初始化為雙精度64位浮點(diǎn) */

  long double b = 56.78; /* 把單精度浮點(diǎn)強制類(lèi)型轉換為雙精度浮點(diǎn) */

  在I/O處理時(shí),也要標有相關(guān)的前綴,例如:

  printf("%Lg", 1.23L);

  printf("%Le", 3.45L);

  需要注意的是,雖然編譯器支持了雙精度浮點(diǎn),但是FPU只支持硬件的32位單精度浮點(diǎn),在程序運行時(shí),雙精度浮點(diǎn)類(lèi)型是被CPU“軟支持”的。特別是long double的操作,需要多個(gè)CPU寄存器的配合才能完成(代碼尺寸和執行時(shí)間都會(huì )變長(cháng));在多個(gè)long double操作數的情況下,前兩個(gè)操作數的地址會(huì )傳遞到CPU輔助寄存器XAR4和XAR5中,其它的地址則被放置在棧中。例如下面的代碼中:

  long double foo(long double a, long double b, long double c)

  {

  long double d = a + b + c;

  return d;

  }

  long double a = 1.2L;

  long double b = 2.2L;

  long double c = 3.2L;

  long double d;

  void bar()

  {

  d = foo(a, b, c);

  }

  在函數bar()中調用foo的時(shí)候,CPU寄存器的值為:

  
CPU寄存器寄存器的值:

  在C28x的浮點(diǎn)操作中,以加法為例,其匯編代碼是有區別的:

  LCR FS$$ADD ; 單精度加法

  LCR FD$$ADD ; 雙精度加法

  一般情況下,沒(méi)有特殊的需要,完全可以不實(shí)用雙精度的浮點(diǎn),例如在電機控制系統中,因為A/D采樣的精度限制,整個(gè)系統的精度是無(wú)法實(shí)現那么高的精度的。

  ? 數據類(lèi)型很多,使用時(shí)一定要小心

  單精度與雙精度,有符號與無(wú)符號,一個(gè)大于65535的數賦給16位寬的類(lèi)型……這些轉換都是隱患重重,使用一定要小心啊!例如:

   如果你用Excel分析對比數據

  記得Excel中浮點(diǎn)類(lèi)型只能使用雙精度的浮點(diǎn)數。所以如果你把DSP中單精度的浮點(diǎn)數據取出放入Excel中,發(fā)現數據發(fā)生了變化,就不會(huì )覺(jué)得奇怪了。例如,單精度浮點(diǎn)的0.2放到Excel,就變成0.200000002980232了。



關(guān)鍵詞: DSP數據類(lèi)

評論


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

關(guān)閉
国产精品自在自线亚洲|国产精品无圣光一区二区|国产日产欧洲无码视频|久久久一本精品99久久K精品66|欧美人与动牲交片免费播放
<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>