资源描述:
《dsp课程设计--有限冲击响应fir滤波器的设计》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库。
1、课程名称:DSP原理及应用课程设计实验项目:有限冲击响应FIR滤波器的设计实验地点:起点机房专业班级:测控1002学号2010001356学生姓名:魏志明指导教师:贾海蓉同组人:王帝王志芳王伟魏浩松孙小伟汪军唐坤龙2012年12月17日一、设计目的1使学生加深对DSP芯片TMS320C55x的结构、工作原理的理解;2了解FIR的原理和特性;3熟悉设计FIR数字滤波器的原理和方法;4学习FIR滤波器的DSP实现原理;5学习使用ccs的波形观察窗口观察输入、输出信号波形和频谱变化情况。二、设计原理滤波器就是在时间域或频域内,对已知激励产生规定响应的网络,使
2、其能够从信号中提取有用的信号,抑制并衰减不需要的信号,滤波器的设计实质上就是对提出的要求给出相应的性能指标,再通过计算,使物理可实现的实际滤波器响应特性逼近给出的频率响应特性。FIR数字滤波器是一种非递归系统,其传递函数为:=由此可得到系统的差分方程为:则,FIR滤波器的结构如下图:bN-1bN-2b1b0x(n-N+1)x(n-1)aZ-1Z-1Z-1X(n)y(n)其冲激响应是有限长序列,它滤波器系数向量,N为FIR滤波器的阶数。在数字信号处理应用中往往需要设计线性相位的滤波器,FIR滤波器在保证幅度特性满足技术要求的同时,很容易做到严格的线性相位
3、特性为了使滤波器满足线性相位条件,要求其单位脉冲响应为实序列,且满足偶对称或奇对称条件,即或.这样,当N为偶数时,偶对称线性相位FIR滤波器的差分方程表达为由上可见,FIR滤波器不断地对输入样本延时后,再做乘法累加运算,将滤波器结果输出。因此,FIR实际上是一种乘法累加运算。而对于线性相位FIR滤波器系数的对称特性,可以采用结构精简的FIR结构将乘法器数目减少一半。应用MATLAB设计FIR滤波器的主要任务就是根据给定的性能指标设计一个,使其逼近这一指标,进而计算并确定滤波器的系数,再将所设计滤波器的幅频响应、相频响应曲线作为输出,与设计要求进行比较,
4、对设计的滤波器进行优化,设计完成之后将得到的FIR滤波器的单位冲激响应序列的各个参数值。三、总体方案设计1启动CCS,在CCS中建立一个汇编源文件、建立一个C源文件和一个命令文件,并将这三个文件添加到工程,再编译并装载程序2设置波形时域观察窗口,得到其滤波前后波形变化图;3设置频域观察窗口,得到其滤波前后频谱变化图。四、源程序1、新建工程文件打开SetupCCS选择c55芯片,打开CCS软件,选择project/new,命名为myproject。2、添加文件到工程(1)建立文件选择file/new,汇编源程序,如下:.global_fir,_init,
5、_B,_outdata_firbsetfrctamov#_B,xdpmov#_B,cdpmovt0,ac0sub#1,ac0movac0,mmap(csr)addac0,ar0mov#0,ac0rptcsrmacmz*ar0-,*cdp+,ac0movhi(ac0),t0ret_initmovmmap(t0),ac0sub#1,ac0movac0,ar7rptzac0,ar7movac0,*ar0+ret_outdatamovt1,ac0sub#2,ac0movac0,mmap(csr)addac0,ar0rptcsrdelay*ar0-mar*ar0
6、+movt0,*ar0retc文件#include"s.h"#include"math.h"#definesignal_1_f200#definesignal_2_f620#definesignal_sample_f2000#definepi3.1415926#definecoff_L23#definebufer_L256intdata_in[bufer_L];intout[bufer_L];intfirout;intx[coff_L+1];intk=0;intbufer=bufer_L;externintfir(int*,int);externint
7、init(int*,int);externintoutdata(int*,int,int);voidinputwave();voidmain(){inputwave();init(x,BL);while(1){x[0]=data_in[k];firout=fir(x,BL);outdata(out,firout,bufer);k++;if(k>=bufer_L){k=0;}}}voidinputwave(){floatwt1;floatwt2;inti;for(i=0;i<=bufer_L;i++){wt1=2*pi*i*signal_1_f;wt1=
8、wt1/signal_sample_f;wt2=2*pi*i*signal_2_f;wt2=w