FIR数字滤波器的DSP编程实现.doc

上传人:飞****2 文档编号:60108251 上传时间:2022-11-13 格式:DOC 页数:6 大小:499.50KB
返回 下载 相关 举报
FIR数字滤波器的DSP编程实现.doc_第1页
第1页 / 共6页
FIR数字滤波器的DSP编程实现.doc_第2页
第2页 / 共6页
点击查看更多>>
资源描述

《FIR数字滤波器的DSP编程实现.doc》由会员分享,可在线阅读,更多相关《FIR数字滤波器的DSP编程实现.doc(6页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、实验4: FIR数字滤波器的DSP编程实现 一、实验目的: 了解一个FIR数字滤波器DSP程序的设计、编写和建立的过程。 学习使用simulator调试滤波器程序的方法。了解使用simulator进行程序调试,如何输入测试信号,观察输出结果。二、实验原理: FIR滤波器的结构和数据存储方式对于一个FIR滤波器,假定其冲激响应为,输入信号为x(n),则有以下差分方程:其对应的滤波器传递函数为:可以用横截型(又称直接型或卷积型)FIR数字滤波器的结构图表示(图8-6-1)。图8-6-1 横截型FIR滤波器的结构图由上面的公式和结构图可知,FIR滤波算法实际上是一种乘法累加运算。它不断地从输入端读入

2、样本值x(n),经延时(),做乘法累加,再输出滤波结果y(n)。在实际编程中,的实现方法有两种:线性缓冲区法和循环缓冲区法。本实验采用了循环缓冲区法。循环缓冲区法的主要特点是:对于N级FIR滤波器,在数据存储区开辟一个称为滑窗的具有N个单元的缓冲区,滑窗中存放最新的N个输入样本值。每次输入新的样本时,新的样本将改写滑窗中最老的数据,其它数据则不需要移动。编写程序时利用片内BK(循环缓冲区长度)寄存器对滑窗进行间接寻址,因而循环缓冲区地址是首尾相邻的。如图8-6-2所示,图中假定N=6。图8-6-2 利用循环缓冲区法实 现假定第一次执行完后,间接寻址的辅助寄存器ARx指向x(n-5)。然后,从I

3、/O口输入数据x(n+1),将原来存放x(n-5)的数据存储器单元改写为x(n+1)。同样,当进行完第二次乘法累加运算后,ARx最后指向x(n-4)。这时,再从I/O口输入数据x(n+2),将原来存放x(n-4)的数据存储器单元改写为x(n+2)。利用循环缓冲区法的主要优点是:不需要移动数据,可将循环缓冲区定位在数据存储器的任何位置(而线性缓冲区则要求必须定位在DARAM中)。本实验是一个使用CCS的simulator进行滤波器基本程序调试的实验,其输入信号x(n)用.inc文件输入。以下灰色字体内容可以不看。 FIR数字滤波器的设计FIR数字滤波器的设计可以采用C、Fortron等高级语言来

4、实现,其编程较为复杂。我们采用MATLAB中信号处理工具箱的有关指令,可以很方便地求出FIR滤波器系数。例:设计一个FIR低通滤波器,通带边界频率为1500Hz,通带波纹小于1dB;阻带边界频率为2000Hz,阻带衰减大于40dB;采样频率为8000Hz。FIR滤波器的设计可以用MATLAB窗函数法进行,例如选择Hamming窗,其程序为:b=fir1(16,1500/8000*2);FIR数字滤波器系数b为:b0=1.16797e-018 b1=0. b2=0. b3=-0. b4=-0. b5=-0. b6=0. b7=0. b8=0. b9=0. b10=0. b11=-0. b12=-

5、0. b13=-0. b14=0. b15=0. b16=1.16797e-018 将上述系数存盘,建立一个数据文件(如fir01.txt)。 建立DSP汇编程序的FIR滤波器系数文件上述系数必须转换成Q15格式,并放置在DSP汇编程序的.inc文件中,进行FIR滤波器的汇编程序的汇编、链接时,inc文件将被自动地加入到工程中去。从MATLAB中产生的fir01.txt文件,通过执行转换命令,将自动变换为firdata.inc滤波器系数文件。转换命令为(在MATLAB下):!firdat fir01.txt将产生firdata.inc文件。其内容如下:N.set17COFF_FIR: .sec

6、t COFF_FIR .word 0.word 158.word 263.word -290.word -1406.word -951.word 3186.word 9287.word 12272.word 9287.word 3186.word -951.word -1406.word -290.word 263.word 158 产生滤波器输入信号的文件在使用CCS的Simulator进行滤波器特性的测试时,需要输入时间信号x(n)。以下是一个产生输入信号的C语言程序,这个信号是频率为1000Hz和2500Hz的正弦波合成的波形。文件名为firinput.c。#include #inclu

7、de void main()int i;double f256;FILE *fp;if(fp=fopen(firin.inc,wt)=NULL)printf(cant open file! n);return;fprintf(fp,INPUT: .sect %cINPUT %c n,);for(i=0;iROM1PAGE 0 .data : INTRAM1 PAGE 1 FIR_COFF: INTRAM2 PAGE 1 FIR_BFR : INTRAM3 PAGE 1 FIR_VARS: INTRAM4 PAGE 1 .stack : B2B PAGE 1 三、实验任务: 在CCS上建立fir

8、工程,并运行fir.out程序。建立fir工程,对汇编程序进行汇编、链接,如有错误则进行修改、调试,当汇编、链接成功后,运行fir.out程序。【即 File 然后 load program 然后运行fir.out程序 】下载程序 观察输入信号的波形及频谱单击ViewGraphTime/Frequency,按图8-6-3改变各选项。其中,由.cmd可知输入信号的数据放在程序区0x00a2开始的地址中。其波形为频率为1000Hz和2500Hz正弦信号的合成信号。将图8-6-3“Display Type”项改为“FFT Magnitude”,则将显示输入信号的频谱图。 观察输出信号的波形及频谱利用Debug菜单下的命令Run运行程序后,仍选择ViewGraphTime/Frequency,将图8-6-3中数据区开始的地址改变为0x2400,按“OK”,将显示滤波器输出信号或者频谱图。四、实验设备:微机主机一台 (已安装CCS C5000和MATLAB软件包)五、思考题:(一)如何确定FIR滤波器的输入、输出等主要数据在DSP存储器中的位置?(二)CCS的Graph功能有何作用,如何使用它观察输入输出波形及其频谱?

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育专区 > 教案示例

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁