6数字滤波器实现_第1页
6数字滤波器实现_第2页
6数字滤波器实现_第3页
6数字滤波器实现_第4页
6数字滤波器实现_第5页
已阅读5页,还剩32页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、第7章数字滤波器1理想低通滤波器2低通、高通、带通与带阻3高通滤波器4带通滤波器5带阻滤波器a.Band-reject byAdding parallel stagesb.Band-reject byin a single stagexnh1nh2nynLow-passxnh1n+h2nynband-passhigh-pass6有限冲击响应(FIR)滤波器式中,yk是时刻t=kT时滤波器的输出信号,xk是最近( t=kT )的输入信号,xk-p是延时了p个采样周期的输入信号, 是第p个延时节的加权值(也就是滤波器系数)。 从这个结构可以看出,因为该滤波器的冲激响应,在N个采样周期后变为0,因此

2、称为有限冲激响应滤波器。FIR滤波器的基本结构,是一个分节的延时线,每一节的输出加权累加,得到滤波器的输出。数学上可以表示为:而IIR滤波器的差分方程后面还需要加上一项7将式 作Z变换,得传输函数:由传输函数可以看出,由于FIR的传输函数H(z)只在Z平面上的原点处有极点,因此,它是稳定的。8FIR滤波器的横截型结构9FIR滤波器的主要特点单位冲激响应只有有限多项可以设计成线性相位系数只在零点处有极点,因此系统总是稳定的便于DSP实现并可用立即数乘加指令编程,节约存储器10系统非线性相移造成输出信号失真系统相位特性决定了信号不同频率的时延,系统的群延时定义为相位函数的导数。11忽略相位信息的后

3、果DFT变换DFT反变换忽略相位信息输入波形输出波形12要求线性相位的例子通信系统:数据通信、调制解调器希尔伯特变换器:要求输入输出信号正交高保真音响系统:音乐的相位失真必须减到最小,尽可能逼真地重现原来的声音理想微分器13线性相位的FIR滤波器系统的群延时14线性相位设计当hp=hN-p 即hp关于中点对称,且:则满足线性相位要求,群延时为:15FIR滤波器的DSP实现 FIR滤波器的基本算法是一种乘法-累加运算,即不断的输入样本x(n),经过 延时后,再进行乘法-累加,最后输出滤波结果y(n) 操作:延迟(一个采样周期)操作,两种方法:1、线性缓冲区实现2、用循环缓冲区实现16线性缓冲区法

4、线性缓冲区法又称延迟线法。其方法是:对于n=N的FIR滤波器,在数据存储器中开辟一个N单元的缓冲区,存放最新的N个样本;滤波时从最老的样本开始,每读一个样本后,将此样本向下移位;读完最后一个样本后,输入最新样本至缓冲区的顶部。以上过程,可以用N=6的线性缓冲区示意图来说明,如图所示: 1718循环缓冲区法下图说明了使用循环寻址实现FIR滤波器的方法。对于N级FIR滤波器,在数据存储区开辟一个称为滑窗的具有N个单元的缓冲区,滑窗中存放最新的N个输入样本值。每次输入新的样本时,新的样本将改写滑窗中最老的数据,其他数据则不需要移动。1920用循环缓冲区实现21FIR滤波器编程实现RPTBD fir_

5、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_loop22计算16阶的FIR滤波

6、器输出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_loop23C54的

7、FIRS指令该指令实现一个对称的FIR滤波器。累加器A的高段和由pmad(程序存储器地址)寻址的pmem相乘,结果加到累加器B中。同时,存储器操作数Xmem和Ymem相加,结果左移16bits,然后装入累加器A。在下一个循环中,pmad加1.语法:FIRS Xmem,Ymem,pmad例:FIRS *AR3+,*AR4+,COEFFS24【例】用循环缓冲区和双操作数寻址方法编写实现FIR滤波的程序。1FIR滤波器设计设计一个FIR低通滤波器,通带边界频率为1500Hz,通带波纹小于1dB;阻带边界频率为2000Hz,阻带衰减大于40dB;采样频率为8000Hz。FIR滤波器的设计可以用MATL

8、AB窗函数法进行。252产生滤波器输入信号的文件按照通常的程序调试方法,先用Simulator逐步调试各子程序模块,再用硬件仿真器在实际系统中与硬件仪器联调。使用CCS的Simulator进行滤波器特性测试时,需要输入时间信号x(n)。本例设计一个采样频率Fs为8000Hz,输入信号频率为1000Hz和2500Hz的合成信号,通过设计的低通滤波器将2500Hz信号滤掉,余下1000Hz信号。263编写FIR数字滤波器的汇编源程序FIR数字滤波器汇编程序fir.asm如下:*一个FIR滤波器源程序 fir.asm*.mmregs.global start.def start,_c_int00IN

9、DEX .set 1KS.set 256 ;输入样本数据个数COEF_FIR.sect COEF_FIR;FIR滤波器系数N .set 17 ;FIR滤波器阶数27.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.usectSTA

10、CK,0FhTOS.usectSTACK,1 .text.asgAR0,INDEX_P28.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_P29STM#DATABUF,DATA_P;数据循环缓冲区清零RPTZA,#N-1STLA,*DA

11、TA_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 30STM#KS-1,BRCRPTBDLOOP-1STM#N,BK;FIR循环缓冲区大小LD*INBUF_P+,A;装载输入数据FIR_FILTER: ;FIR滤波运算STLA,*DATA_P+%;用最新的样本值替代最旧的样本值RPTZA,N-1MAC*DATA_P+0%,*

12、COEF_P+0%,ASTHA,*OUTBUF_P+.end314编写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是数据存储器。32INTRAM3(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

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论