与afreez一起学习DSP中浮点转定点运算--举例及编程中的心得

 

5.举例及编程中的心得

51举例

“第3  DSP芯片的定点运算.doc”这篇文章中给了一个很简单有能说明问题的例子,不想动大脑了,直接引用过来如下。

这是一个对语音信号(0.3kHz~3.4kHz)进行低通滤波的C语言程序,低通滤波的截止频率为800Hz,滤波器采用19点的有限冲击响应FIR滤波。语音信号的采样频率为8kHz,每个语音样值按16位整型数存放在insp.dat文件中。

3.7  语音信号800Hz 19FIR低通滤波C语言浮点程序

#include <stdio.h>

const  int length = 180 /*语音帧长为180点=22.5ms@8kHz采样*/

void  filter(int xin[ ],int xout[ ],int n,float h[ ]); /*滤波子程序说明*/

/*19点滤波器系数*/

static  float h[19]=

               {0.01218354,

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值