DSP编程技巧之16 -- DSP里的数据类型,你都认得它们么

发布时间:2014-10-16 15:34    发布者:看门狗
关键词: DSP , 数据类型 , C语言 , C++
作者:paradoxfx 来源:电子产品世界

  DSP的C/C++编程时有多少种数据类型?float,double和long double,long和long long这些绕口的名字究竟有什么区别?数据类型使用不正确又会有什么后果?如果你感觉说不清楚,那我们来看看这些到底都是何方神圣吧:

  表1 C28x C/C++支持的数据类型
1.jpg

       Ø 64位整数的处理

  从上面的表中,可以看出C28x的编译器是支持64位的整数类型的,这使得在处理某些高精度智能编码器的反馈数据时特别方便,因为在更老的不支持64位整数类型的器件上编程时,需要我们自己定义64位类型,在运算时要自己定义运算规则才行。一个long long类型的整数需要使用ll或者LL前缀,才能被I/O正确处理,例如,我们使用下面的代码才能正确把它们显示在屏幕上:

  printf("%lld", 0x0011223344556677);

  printf("%llx", 0x0011223344556677);

  需要注意的是,虽然编译器支持了64位整数,但是实际的CPU的累加器还有相关的CPU寄存器还是32位的,在程序运行时,64位整数类型是被CPU“软支持”的。我们可以添加相关的实时运行库来提高效率,其中包含了llabs(), strtoll() 和strtoull()等函数。

  Ø 浮点的处理

  从表1中我们可以看出,C28x的编译器支持32位的单精度浮点、64位的单精度和双精度浮点运算。在定义双精度64位变量时,也要记得使用l或者L前缀,否则会被视为双精度的32位变量,造成精度的损失。例如:

  long double a = 12.34L; /* 初始化为双精度64位浮点 */

  long double b = 56.78; /* 把单精度浮点强制类型转换为双精度浮点 */

  在I/O处理时,也要标有相关的前缀,例如:

  printf("%Lg", 1.23L);

  printf("%Le", 3.45L);

  需要注意的是,虽然编译器支持了双精度浮点,但是FPU只支持硬件的32位单精度浮点,在程序运行时,双精度浮点类型是被CPU“软支持”的。特别是long double的操作,需要多个CPU寄存器的配合才能完成(代码尺寸和执行时间都会变长);在多个long double操作数的情况下,前两个操作数的地址会传递到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的时候,CPU寄存器的值为:

CPU寄存器寄存器的值
XAR4变量a的地址
XAR5变量b的地址
*.SP[2]变量c的地址
XAR6变量d的地址

       CPU寄存器寄存器的值:

  在C28x的浮点操作中,以加法为例,其汇编代码是有区别的:

  LCR FS$$ADD ; 单精度加法

  LCR FD$$ADD ; 双精度加法

  一般情况下,没有特殊的需要,完全可以不实用双精度的浮点,例如在电机控制系统中,因为A/D采样的精度限制,整个系统的精度是无法实现那么高的精度的。

  Ø 数据类型很多,使用时一定要小心

  单精度与双精度,有符号与无符号,一个大于65535的数赋给16位宽的类型……这些转换都是隐患重重,使用一定要小心啊!例如:

   如果你用Excel分析对比数据

  记得Excel中浮点类型只能使用双精度的浮点数。所以如果你把DSP中单精度的浮点数据取出放入Excel中,发现数据发生了变化,就不会觉得奇怪了。例如,单精度浮点的0.2放到Excel,就变成0.200000002980232了。


本文地址:https://www.eechina.com/thread-133474-1-1.html     【打印本页】

本站部分文章为转载或网友发布,目的在于传递和分享信息,并不代表本网赞同其观点和对其真实性负责;文章版权归原作者及原出处所有,如涉及作品内容、版权和其它问题,我们将根据著作权人的要求,第一时间更正或删除。
您需要登录后才可以发表评论 登录 | 立即注册

厂商推荐

相关视频

关于我们  -  服务条款  -  使用指南  -  站点地图  -  友情链接  -  联系我们
电子工程网 © 版权所有   京ICP备16069177号 | 京公网安备11010502021702
快速回复 返回顶部 返回列表