IQmath的使用方法

在F2812的ROM中,有3K×16位被保留用于存放数学公式表以及未来的开发。主要应用于高速度和高精度的实时计算,比同等程度的ANSIC C语言效率更高,同时可以节省用户更多的设计和调试时间。
1、IQmath库
为了应用IQmath,首先要从TI官方网站下载IQmath库,文档名称为SPRC087。我们主要应用库里面的:IQmath.cmd,IQmathLib.h,IQmath.lib。新建一个工程,将IQmath.lib,IQmath.cmd添加到工程,同时在main()函数之前增加语句:#include “IQmathLib.h”。注意:rts2800.lib和DSP281x_Headers_nonBIOS.cmd也要加到工程里面。
当然也可以不用IQmath.cmd文件,而用自己的CMD文件,只要在你的CMD里面添加以下代码即可:
MEMORY
{
   PAGE 0:
   BOOTROM (RW) : origin = 0x3ff000 , length = 0x000fc0
   RAMH0 (RW)   : origin = 0x3f8000 , length = 0x002000
}
SECTIONS
{
   IQmathTables   : load = BOOTROM , type = NOLOAD , PAGE=0
   IQmath        : load = RAMH0 , PAGE=0           
}
以上代码的红色部分可以适当修改。IQmathTables段必须设置为NOLOAD型。
2、IQmath应用
完成以上几步之后就可以在你的主函数里应用IQmath提供的函数进行计算了。建议在应用之前把IQmathLib.h浏览一下,了解各个函数是怎样实现的。下面举一个简单的例子:
#include "DSP281x_Device.h"
#include "IQmathLib.h"


#define  PI  3.14159


_iq   sinout_iq;
float  sinout_flt;


void main(void)
{
  InitSysCtrl();
  InitXintf();
  DINT;
  IER=0X0000;
  IFR=0X0000;
  
  sinout_iq=_IQ29sin(_IQ29mpy(_IQ29(0.25),_IQ29(PI)));
  sinout_flt=_IQ29toF(sinout_iq);
  for(;;){}
}
上述代码的功能是计算sin(π/4)的值,然后赋给sinout_flt。
 
sinout_iq值的格式为_iq29类型(也就是long型,参见IQmathLib.h),所以要通过函数_IQ29toF(sinout_iq)转化为float类型,才是我们需要的最终结果。
除个别函数外,一般情况下,计算公式里的所有变量都为一个iq类型,如上述主函数的第6行语句,全为_iq29类型。函数的具体讲解请参考IQmath手册,在此不再啰嗦。
3、Q格式的选择
IQmath一共提供了30种Q格式,具体选择哪种格式要兼顾精度和值的大小依据下表而定:
 
例如将数5.0转为Q格式,只能从_iq1~_iq28里面选择,而不能转化为_iq29和_iq30表示,因为_iq29能转化的最大值为3.999999998,否则会发生溢出。所以在定Q格式时要对数的范围做一下估计。也正是由于这个原因,有些三角函数不能采用_iq30格式。
4、计算arcsin与arccos
很多人有这样的疑问,函数表里面为什么没有提供arccos()和arcsin()函数呢?怎样才能计算这两个函数呢?其实只要你的高等数学过关的话,就很容易理解。因为arccos()和arcsin()可以通过反正切函数atan()间接求得,而函数表里面恰好提供了反正切函数,参见以下两个公式:
arcsin(X) = atan(X / sqr(-X * X + 1))                         反正弦
arccos(X) = atan(-X / sqr(-X * X + 1)) + 2 * atan(1)               反余弦
arcsec(X) = atan(X / sqr(X * X - 1)) + sgn((X) - 1) * (2 * atan(1))    反正割
arccosec(X) = atan(X / sqr(X * X - 1)) + (sgn(X) - 1) * (2 * atan(1))  反余割


原文地址:http://blog.csdn.net/yantaoliu/article/details/5487859
IQmath基本使用方法(2812为例子)
一. 配置CMD


PRAMH0         : origin = 0x100000, length = 0x008000     
BOOT_ROM       : origin = 0x3ff000, length = 0x000fc0
IQmathTables   : > BOOT_ROM, type = NOLOAD, PAGE = 0
IQmath         : > PRAMH0,   PAGE = 0


二. 载入gel文件,加入IQmath库和头文件
IQmath.gel
IQmath.lib
IQmathLib.h


三.定义全局Q格式,和调试Q格式
#define GLOBAL_Q     20 //全局为Q20格式,默认为Q24格式
long GlobalQ = GLOBAL    //调试用为Q20格式(这样可以使用_IQ(x)在监视器中查看)


//-----------------------------
IQmath中常用的变量和字符
QN    16bitQ格式
IQN   32bitQ格式 N表示Q多少
int 16bit
long 32bit
_iq = _iqN = long
F 浮点数输入
S 浮点字符串
P 正数最大值
N 负数最大值


格式转化函数
一般情况下IQ都有IQN版本的函数
float _IQtoF(A)         //_iq浮点转成正常浮点
float _IQNtoF(A)
int _IQtoQN(A)          //iq和q(16bit)的转化
long _IQint(A)          //提取iq的整数部分
_IQ(float F)            //浮点转化成iq
_IQN(float F)
_atoIQ(char *s)         //字符串转化成iq
_IQfrac(A)              //提取iq的小数部分
_IQtoIQN(A)             //全局iq和普通iq的转化       
_IQNtoIQ(A)
_QNtoIQ(int A)


算术函数
long _IQmpyI32int(A, B) //N*long IQ乘long 返回整数部分
long _IQmpyI32frac(A, B)//N*long IQ乘long 返回小数部分
_IQmpy(A, B)            //N*N乘法 
_IQrmpy(A, B)           //N*N四舍五入的乘法最后保存结果前(四舍五入)
_IQrsmpy(A, B)          //N*N四舍五入的饱和处理乘法(如果Q26[-32,+32],如果相乘结果超过也会限制到这个范围)
_IQmpyI32(A, B)         //N*long IQ乘long
_IQmpyIQX(A, A1, B, B1) //N1*N2两个不同的Q格式乘法,返回全局Q格式
_IQdiv(A, B)            // N/N iq除法


三角函数
_IQsin(A)
_IQsinPU(A)             //正弦函数(标幺值),你占这个圆周的几分之几为单位如果sin((0.25*PI)/(2*PI))
_IQcos(A)
_IQcosPU(A)
_IQatan2(A, B)           //第四象限反正切 tan-1(sin, cos)
_IQatan2PU(A, B)         //第四象限反正切 tan-1(sin, cos)
_IQatan(A, B)           //定点反正切    tan-1(1),,1=sin/cos


_IQNsin(A)
_IQNsinPU(A)            //正弦函数(标幺值),你占这个圆周的几分之几为单位如果sin((0.25*PI)/(2*PI))
_IQNcos(A)
_IQNcosPU(A)
_IQNatan2(_iqA, B)      //第四象限反正切 tan-1(sin, cos)
_IQNatan2PU(_iqA, B)    //第四象限反正切 tan-1(sin, cos)
_IQNatan(A, B)          //定点反正切    tan-1(1),,1=sin/cos


数学函数
_IQNsqrt(A)             //平方根        a^0.5
_IQNisqrt(A)            //平方根倒数    1/a^0.5
_IQNmag(A, B)           //求模运算(sqrt(A^2 + B^2)


_IQsqrt(A)              //平方根        a^0.5
_IQisqrt(A)             //平方根倒数    1/a^0.5
_IQmag(A, B)            //求模运算(sqrt(A^2 + B^2)


其它函数
_IQsat(A, long P, long N)//IQ数值的限幅函数 把A限制到[N P]之间
_IQNabs(A)              //IQ数据的绝对值    |A|
_IQabs(A)               //IQ数据的绝对值    |A|
  • 36
    点赞
  • 163
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: IQMath是一种一种用于处理定点数的数学库。它提供了一系列的函数和工具,可以用来进行定点数的加减乘除运算、取整、取模和其他数学运算操作。IQMath的基本使用方法如下: 首先,我们需要定义和初始化一个IQ数。IQ数由一个整数部分和一个小数部分组成,以固定的格式表示浮点数。我们可以使用IQ设置函数来将一个浮点数转换为IQ格式,例如: ``` IQ x = IQSET(1.5); ``` 上述代码将把浮点数1.5转换为IQ数,并将其赋值给变量x。 接下来,我们可以使用IQ的数学函数来对IQ数进行各种运算。例如,我们可以使用IQ的加法函数来计算两个IQ数的和,如下所示: ``` IQ sum = IQADD(x, y); ``` 上述代码将计算x和y的和,并将结果赋值给变量sum。 除了基本的加减乘除运算外,IQMath还提供了其他常用的数学函数,如取整函数、取绝对值函数和取模函数等。例如,我们可以使用IQ的整数取整函数来将一个IQ数取整到最接近的整数,如下所示: ``` IQ rounded = IQINT(x); ``` 上述代码将把x取整到最接近的整数,并将结果赋值给变量rounded。 除了数学函数外,IQMath还提供了一些用于调整IQ数精度和格式的函数。例如,我们可以使用IQ的规格化函数来规范化一个IQ数,使其满足一定的精度要求,如下所示: ``` IQ normalized = IQNORM(x, IQ_BITS); ``` 上述代码将规范化x,使其满足IQ_BITS位的精度,并将结果赋值给变量normalized。 总而言之,IQMath是一种用于处理定点数的数学库,可以进行各种数学运算和格式转换。通过使用IQ的数学函数和工具,我们可以方便地处理和操作定点数。 ### 回答2: IQMath是一种用于嵌入式系统中的定点数学计算库。它采用了定点数表示,并提供了高效的整数运算函数。其基本使用方法如下: 1. 定义变量类型:IQMath库提供了一系列的宏定义来定义不同位数的定点数类型。可以根据需求选择合适的类型。 2. 初始化变量:在使用IQMath库之前,需要先初始化相应的变量。可以使用宏定义或直接赋值进行初始化。 3. 数值运算:IQMath库提供了一系列的运算函数,包括加法、减法、乘法、除法、平方根等等。可以根据需要选择相应的函数进行运算。 4. 转换为浮点数:如果需要将IQMath的定点数转换为浮点数,可以使用相应的转换函数。这样可以方便地与其他浮点数进行比较或计算。 5. 输出结果:最后,将结果输出或使用。可以使用printf函数将结果输出到终端或使用其他方式进行处理。 总的来说,IQMath库提供了一种在嵌入式系统中进行高效定点数运算的方法使用IQMath库可以避免使用浮点数运算带来的性能和精度问题,同时提高了嵌入式系统的计算效率。但需要注意的是,在使用IQMath库时要仔细选择定点数的位数,以兼顾精度和性能。 ### 回答3: IQmath是一种基于定点数的数学运算库,用于在嵌入式系统中进行高效的数值计算。其基本使用方法如下: 1. 引入IQmath库:首先需要将IQmath库引入到你的工程中。这可以通过将IQmath库的源文件添加到你的项目中,或者将IQmath库作为静态库或动态库链接到你的项目中来实现。 2. 定义和初始化IQ数:在使用IQmath库之前,需要定义和初始化IQ数。IQ数是一种由整数和小数部分组成的定点数表示方法,可以非常方便地进行数值计算。例如,你可以使用IQ数表示长度、角度、速度等物理量。 IQ数的初始化可以通过将一个整数和一个小数作为参数传递给IQ数的构造函数来实现。 3. 进行数值计算:一旦IQ数被初始化,你可以使用IQmath库提供的各种函数进行数值计算。例如,你可以使用IQmath库中的加法、减法、乘法和除法函数对IQ数进行基本的数学运算。此外,IQmath库还提供了各种高级数学函数,例如三角函数、指数函数和对数函数等,以满足各种复杂的数值计算需求。 4. 结果转换和输出:在完成数值计算后,你可能需要将IQ数转换回常规的整数或浮点数表示。为此,IQmath库提供了将IQ数转换为整数、浮点数以及字符串的功能函数。你可以根据自己的需要选择合适的函数,并将结果输出到合适的输出设备上显示或存储。 总之,使用IQmath库进行数值计算非常简单。你只需引入库文件,定义和初始化IQ数,使用库中的函数进行数值计算,然后将结果转换和输出即可。通过灵活运用IQmath库,我们可以在嵌入式系统中轻松高效地进行各种数值计算。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值