IQMath lib的使用 参考手册《IQmath_Quickstart.pdf》 版本V1.6.0 存放路径:C:\ti\controlSUITE\libs\math\IQmath\v160\doc 1.TMS320F28035是TI公司推出的32位定点DSP芯片,其硬件本身不支持浮点数运算,在用C语言编程时用到的浮点运算是在软件层面上完成的,并非TMS320F28035具备浮点运算能力。用C语言编程在软件上实现浮点数运算将增加代码量和程序运行时间。IQmath是一种采用定点运算,但具有浮点数据处理特性的计算方法,并且IQmath还具有丰富的函数库。
优点就是处理速度快,代码量低。缺点就是十进制浮点数转化为二进制时可能会存在误差。 4.IQ格式由整数部分(I),小数部分(Q)和一位符号位构成。所以I+Q=31位。当Q值确定后,所有参加运算的IQ数据精度是一致的,同时数据的动态范围也被确定了。具体的Q值对应的精度和数据范围可以查表。 5.IQmath应用的简单归纳: 1)Q值定标:根据要求的误差和数据范围,选择一个Q值。 2)浮点数转换为IQ数据格式。 3)将IQ数据转换为浮点数。 6.IQmath.lib用于定点芯片。IQmath_f32.lib用于浮点芯片。 7.CMD文件配置的一些建议: 输出段“IQmathTables”,含有的一些函数是已经被烧录到BOOTROM区域,所以必须被设置成“NOLOAD”类型,在 BOOTROM区域查表,而不需要载入其他区域。 输出段“IQmathTablesRam”含有的函数,需要时可以载入,某些芯片也将这些函数烧录到BOOTROM区域,看直接查表。 8.工程中配置IQmath.lib库文件 1).与加入c文件的方法类似,只要知道路径并且添加即可 2).需要在c文件中包含 #include "IQmathLib.h" 3).配置.CMD文件。 9.IQmath使用须知 1. 在IQmathLib.h里,根据需要修改Q格式,范围是 Q1 to Q30 (P30) // 30 <= GLOBAL_Q <= 1 // #ifndef GLOBAL_Q #define GLOBAL_Q 24 #endif IQmathLib.h里默认是Q24格式 Q格式的取值范围与精度在手册的10页有说明 10.使用IQmath的过程 1)所有参与运算的数据,必须转化为Q格式,比如 #define PI 3.1415926535898 _iq input = _IQ(PI); //将PI转化为Q格式 2)转化为Q格式后,所有数据参与计算,必须使用IQ库函数计算 3)实现Q格式转换为浮点数 float _IQtoF( _iq A) 11.
|