dsp处理浮点数_DSP编程技巧---详解浮点运算的定点编程

在定点处理器上,由于不支持硬件浮点运算,使用浮点类型会导致程序执行时间延长和资源消耗增加。通过规定定点数的整数和小数位数,可以将浮点数转换为定点数进行处理。本文介绍了定点数与浮点数的转换,以及不同Q格式定点数的运算规则,并提到了TI DSP的IQMath库在定点运算中的应用,以提高效率。
摘要由CSDN通过智能技术生成

我们使用的处理器一般情况下,要么直接支持硬件的浮点运算,比如某些带有FPU的器件,要么就只支持定点运算,此时对浮点数的处理需要通过编译器来完成。在支持硬件浮点处理的器件上,对浮点运算的编程最快捷的方法就是直接使用浮点类型,比如单精度的float来完成。但是在很多情况下,限于成本、物料等因素,可供我们使用的只有一个定点处理器时,直接使用float类型进行浮点类型的运算会使得编译器产生大量的代码来完成一段看起来十分简单的浮点数学运算,造成的后果是程序的执行时间显著加长,且其占用的资源量也会成倍地增加,这就涉及到了如何在定点处理器上对浮点运算进行高效处理的问题。本文引用地址:http://www.eepw.com.cn/article/201612/332390.htm

既然是定点处理器,那么其对定点数,或者说字面意义上的“整数”进行处理的效率就会比它处理浮点类型的运算要高的多。所以在定点处理器上,我们使用定点的整数来代表一个浮点数,并规定整数位数和小数位数,从而方便地对定点数和浮点数进行转换。以一个32位的定点数为例,假设转换因子为Q,即32位中小数的位数为Q,整数位数则为31-Q(有符号数的情况),则定点数与浮点数的换算关系为:

定点数=浮点数×2^Q

例如,浮点数-2.0转换到Q为30的定点数时,结果为:

定点数=-2×2^30=-2147483648

32位有符号数的表示范围是:-2147483648到2147483647。如果我们把有符号定点数的最大值2147483647转换为Q为30对应的浮点数,则结果为:

浮点数2147483647/2^30=1.999999999

从上面的两个计算例子中也可以看出,在Q30格式的情况下,最大的浮点数只能表示到1.999999999,如果我们想把浮点数2.0转换为Q30的定点数,则产生了溢出,即造成了1e-9的截断误差。在此我们列出Q0到Q30对应的范围和分辨率如下表所示:

3704803206182b6aabc0fdb9a8be71cf.png

如果你嫌自己计算麻烦的话,可以借助Matlab的命令来求取它们的转换,例如,在Matlab的命令窗口中输入

浮点运算计算机中一种常见的数值计算方法,但在某些场景中,如嵌入式系统或低成本设备中,使用浮点数的硬件支持可能较差。此时,定点编程可以作为一种替代方案来处理数值计算定点编程是一种使用固定的小数点位置来表示数值的编程方法。我们可以选择一个合适的定点位置,将浮点数转化为定点数来进行运算。例如,我们可以选择一个定点位置为2的定点数表示方法,其中整数部分占据16位,小数部分占据16位。这样,定点数10.5将被表示为10500。 在定点编程中,我们需要注意以下几个技巧: 1. 定点数的运算:定点数的加减法运算与整数运算相同,只需保持小数点位置不变即可。乘法和除法运算需要特殊处理,可通过移位操作模拟乘以或除以2的幂次方的运算。 2. 范围和精度控制:定点数的范围和精度取决于选择的小数点位置。选择小数点位置较高可以提高精度,但会减小表示的范围,选择小数点位置较低则相反。需要根据具体需求权衡范围和精度的平衡。 3. 数据类型转换:在定点编程中,需要注意在不同数据类型之间进行转换。如果需要将定点数转换为整数,可以通过移位操作和取整来实现。如果需要将整数转换为定点数,可以通过移位操作和适当的缩放来实现。 4. 数值截断和溢出处理定点编程中,数值的截断和溢出是需要注意的问题。如取整操作可能导致数值的丢失,而乘法或加法可能导致数值的溢出。需要根据具体情况进行合适的处理,如舍入或截断操作来避免数值的损失或溢出。 总之,定点编程是一种用于替代浮点运算的数值计算方法。通过选择合适的小数点位置,使用定点编程可以在某些硬件受限的环境中实现高效的数值计算。需要注意的是,定点编程需要根据具体场景进行适当的调整和处理,以实现所需的范围和精度,并避免数值截断和溢出的问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值