数字滤波器实现.ppt
第7章数字滤波器,理想低通滤波器,低通、高通、带通与带阻,高通滤波器,带通滤波器,带阻滤波器,a.Band-reject byAdding parallel stages,b.Band-reject byin a single stage,有限冲击响应(FIR)滤波器,式中,yk是时刻t=kT时滤波器的输出信号,xk是最近(t=kT)的输入信号,xk-p是延时了p个采样周期的输入信号,是第p个延时节的加权值(也就是滤波器系数)。从这个结构可以看出,因为该滤波器的冲激响应,在N个采样周期后变为0,因此称为有限冲激响应滤波器。,FIR滤波器的基本结构,是一个分节的延时线,每一节的输出加权累加,得到滤波器的输出。数学上可以表示为:,而IIR滤波器的差分方程后面还需要加上一项,将式 作Z变换,得传输函数:,由传输函数可以看出,由于FIR的传输函数H(z)只在Z平面上的原点处有极点,因此,它是稳定的。,FIR滤波器的横截型结构,FIR滤波器的主要特点,单位冲激响应只有有限多项可以设计成线性相位系数只在零点处有极点,因此系统总是稳定的便于DSP实现并可用立即数乘加指令编程,节约存储器,系统非线性相移造成输出信号失真,系统相位特性决定了信号不同频率的时延,系统的群延时定义为相位函数的导数。,忽略相位信息的后果,要求线性相位的例子,通信系统:数据通信、调制解调器希尔伯特变换器:要求输入输出信号正交高保真音响系统:音乐的相位失真必须减到最小,尽可能逼真地重现原来的声音理想微分器,线性相位的FIR滤波器,系统的群延时,线性相位设计,当hp=hN-p 即hp关于中点对称,且:,则满足线性相位要求,群延时为:,FIR滤波器的DSP实现,FIR滤波器的基本算法是一种乘法-累加运算,即不断的输入样本x(n),经过 延时后,再进行乘法-累加,最后输出滤波结果y(n)操作:延迟(一个采样周期)操作,两种方法:1、线性缓冲区实现2、用循环缓冲区实现,线性缓冲区法,线性缓冲区法又称延迟线法。其方法是:对于n=N的FIR滤波器,在数据存储器中开辟一个N单元的缓冲区,存放最新的N个样本;滤波时从最老的样本开始,每读一个样本后,将此样本向下移位;读完最后一个样本后,输入最新样本至缓冲区的顶部。以上过程,可以用N=6的线性缓冲区示意图来说明,如图所示:,循环缓冲区法,下图说明了使用循环寻址实现FIR滤波器的方法。对于N级FIR滤波器,在数据存储区开辟一个称为滑窗的具有N个单元的缓冲区,滑窗中存放最新的N个输入样本值。每次输入新的样本时,新的样本将改写滑窗中最老的数据,其他数据则不需要移动。,用循环缓冲区实现,FIR滤波器编程实现,RPTBD fir_filter_loop-1STM#k_FIR_BFFR,BK;FIR circular bffr sizeLD*INBUF_P+,A;load the input valueFir_filter:STL A,*FIR_DATA_P+%;replace oldest sample with newest sampleRPTZ A,(K_FIR_BUFF-1)MAC*FIR_DATA_P+0%,*FIR_COFF_P+0%,A;filteringSTH A,*OUTBUF_P+;replace the oldest bffr valuefir_filter_loop,计算16阶的FIR滤波器输出256个点,.sect”fir_prog”STM#255,BRC;Repeat 256 timesRPTBD fir_filter_loop STM#16,BK;FIR circular buffer sizeLD*AR7+,A;load the input valueSTL A,*AR4+%;replace oldest sample with newest sampleRPTZ A,#15MAC*AR4+0%,*AR3+0%,A;filteringSTH A,*AR5+;replace the oldest buffer valueFir_filter_loop,C54的FIRS指令,该指令实现一个对称的FIR滤波器。累加器A的高段和由pmad(程序存储器地址)寻址的pmem相乘,结果加到累加器B中。同时,存储器操作数Xmem和Ymem相加,结果左移16bits,然后装入累加器A。在下一个循环中,pmad加1.语法:FIRS Xmem,Ymem,pmad例:FIRS*AR3+,*AR4+,COEFFS,【例】用循环缓冲区和双操作数寻址方法编写实现FIR滤波的程序。1FIR滤波器设计设计一个FIR低通滤波器,通带边界频率为1500Hz,通带波纹小于1dB;阻带边界频率为2000Hz,阻带衰减大于40dB;采样频率为8000Hz。FIR滤波器的设计可以用MATLAB窗函数法进行。,2产生滤波器输入信号的文件按照通常的程序调试方法,先用Simulator逐步调试各子程序模块,再用硬件仿真器在实际系统中与硬件仪器联调。使用CCS的Simulator进行滤波器特性测试时,需要输入时间信号x(n)。本例设计一个采样频率Fs为8000Hz,输入信号频率为1000Hz和2500Hz的合成信号,通过设计的低通滤波器将2500Hz信号滤掉,余下1000Hz信号。,3编写FIR数字滤波器的汇编源程序FIR数字滤波器汇编程序fir.asm如下:*一个FIR滤波器源程序 fir.asm*.mmregs.global start.def start,_c_int00INDEX.set 1KS.set 256;输入样本数据个数COEF_FIR.sect COEF_FIR;FIR滤波器系数N.set 17;FIR滤波器阶数,.word 0,158,264,-290,-1406,-951,3187,9287,12272.word9287,3187,-951,-1406,-290,264,158,0.dataINPUT.copy firin.inc;输入数据在数据区0 x2400OUTPUT.space1024;输出数据在数据区0 x2500COEFTAB.usectFIR_COEF,NDATABUF.usectFIR_BFR,NBOS.usectSTACK,0FhTOS.usectSTACK,1.text.asgAR0,INDEX_P,.asgAR4,DATA_P;输入数据x(n)循环缓冲区指针.asgAR5,COEF_P;FIR系数表指针.asg AR6,INBUF_P;模拟输入数据指针.asgAR7,OUTBUF_P;FIR滤波器输出数据指针_c_int00b start nopnopstart:SSBxFRCT;小数乘法编程时,设置FRCT(小数方式)位MVPD#COEF_FIR,*COEF_P+STM#INDEX,INDEX_P,STM#DATABUF,DATA_P;数据循环缓冲区清零RPTZA,#N-1STLA,*DATA_P+STM#(DATABUF+N-1),DATA_P;数据循环缓冲区指针指向xn-(N-1)STM#COEFTAB,COEF_PSTM#COEFTAB,COEF_P;将FIR系数从程序存储器移到数据存储器RPT#N-1 FIR_TASK:STM#INPUT,INBUF_PSTM#OUTPUT,OUTBUF_P,STM#KS-1,BRCRPTBDLOOP-1STM#N,BK;FIR循环缓冲区大小LD*INBUF_P+,A;装载输入数据FIR_FILTER:;FIR滤波运算STLA,*DATA_P+%;用最新的样本值替代最旧的样本值RPTZA,N-1MAC*DATA_P+0%,*COEF_P+0%,ASTHA,*OUTBUF_P+.end,4编写FIR滤波器链接命令文件对应以上汇编程序的链接命令文件fir.cmd如下:fir.obj-m fir.map-ofir.outMEMORYPAGE 0:ROM1(RIX):ORIGIN=0080H,LENGTH=100HPAGE 1:INTRAM1(RW):ORIGIN=2400H,LENGTH=0200H INTRAM2(RW):ORIGIN=2600H,LENGTH=0100H,将输出文件名改成fir.out,如果不使用-o,则输出文件省缺名为a.out。,-m选择项建立映射列表文件,该映射列表描述存储器划分、输入与输出断的位置以及外部符号重新定位后的地址。,PAGE说明一个存储器空间,用户最多可以说明255页。通常,page0是程序存储器,page1是数据存储器。,INTRAM3(RW):ORIGIN=2700H,LENGTH=0100HB2B(RW):ORIGIN=0070H,LENGTH=10H SECTIONS.text:ROM1PAGE 0.data:INTRAM1 PAGE 1FIR_COEF:INTRAM2 PAGE 1FIR_BFR:INTRAM3 PAGE 1.stack:B2B PAGE 1,程序代码装入ROM区,5CCS集成开发环境下上机操作过程(1)在CCS上建立fir工程并运行fir.out程序。(2)观察输入信号的波形及频谱(如图7-137-15所示)。(3)观察输出信号的波形及频谱(如图7-16、7-17所示)。,图7-13 Graph 属性设置窗口,图7-14 输入信号的时域波形,图7-15 输入信号的频谱图,图7-16 滤波器输出信号时域波形,图7-17 滤波器输出信号频谱图,