实验基于matlab的fir数字滤波器设计

实验基于matlab的fir数字滤波器设计

ID:23621703

大小:328.51 KB

页数:16页

时间:2018-11-09

实验基于matlab的fir数字滤波器设计_第1页
实验基于matlab的fir数字滤波器设计_第2页
实验基于matlab的fir数字滤波器设计_第3页
实验基于matlab的fir数字滤波器设计_第4页
实验基于matlab的fir数字滤波器设计_第5页
资源描述:

《实验基于matlab的fir数字滤波器设计》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、实验4基于MATLAB的FIR数字滤波器设计实验目的:加深对数字滤波器的常用指标和设计过程的理解。实验原理:低通滤波器的常用指标:通带边缘频率,阻带边缘频率,通带起伏,通带峰值起伏,阻带起伏,最小阻带衰减。数字滤波器有IIR和FIR两种类型,它们的特点和设计方法不同。在MATLAB中,可以用b=fir1(N,Wn,’ftype’,taper)等函数辅助设计FIR数字滤波器。N代表滤波器阶数;Wn代表滤波器的截止频率(归一化频率),当设计带通和带阻滤波器时,Wn为双元素相量;ftype代表滤波器类型,如’high’高通,’stop’带阻等;taper为窗函数类型,默认为海明窗,窗

2、系数需要实现用窗函数blackman,hamming,hanningchebwin,kaiser产生。例1用凯塞窗设计一FIR低通滤波器,通带边界频率,阻带边界频率,阻带衰减不小于50dB。解首先由过渡带宽和阻带衰减来决定凯塞窗的N和,, 上图给出了以上设计的频率特性,(a)为N=30直接截取的频率特性(b)为凯塞窗设计的频率特性。凯塞窗设计对应的MATLAB程序为:wn=kaiser(30,4.55);nn=[0:1:29];alfa=(30-1)/2;hd=sin(0.4*pi*(nn-alfa))./(pi*(nn-alfa));h=hd.*wn;[h1,w1]=freq

3、z(h,1);或者:b=fir1(29,0.4,kaiser(30,4.55));[h1,w1]=freqz(b,1);plot(w1/pi,20*log10(abs(h1)));axis([0,1,-80,10]);grid;xlabel('归一化频率/p');ylabel('幅度/dB');还可以使用[n,Wn,beta,ftype]=kaiserord(f,a,dev)函数来估计滤波器阶数等,得到凯塞窗滤波器:fcuts=[0.30.5];%归一化频率omega/pimags=[10];devs=[0.0510^(-2.5)];[n,Wn,beta,ftype]=kais

4、erord(fcuts,mags,devs);%计算出凯塞窗N,beta的值hh=fir1(n,Wn,ftype,kaiser(n+1,beta),'noscale');freqz(hh);   实际中,一般调用MATLAB信号处理工具箱函数remezord来计算等波纹滤波器阶数N和加权函数W(ω),调用函数remez可进行等波纹滤波器的设计,直接求出滤波器系数。函数remezord中的数组fedge为通带和阻带边界频率,数组mval是两个边界处的幅值,而数组dev是通带和阻带的波动,fs是采样频率单位为Hz。例2利用雷米兹交替算法设计等波纹滤波器,设计一个线性相位低通FIR数

5、字滤波器,其指标为:通带边界频率fc=800Hz,阻带边界fr=1000Hz,通带波动阻带最小衰减At=40dB,采样频率fs=4000Hz。解在MATLAB中可以用remezord和remez两个函数设计,其结果如图2,MATLAB程序如下:fedge=[8001000];mval=[10];dev=[0.05590.01];               fs=4000;[N,fpts,mag,wt]=remezord(fedge,mval,dev,fs);b=remez(N,fpts,mag,wt);[h,w]=freqz(b,1,256);plot(w*2000/pi,2

6、0*log10(abs(h)));grid;                   xlabel('频率/Hz');ylabel('幅度/dB');                   一、实验内容:利用MATLAB编程设计一个数字带通滤波器,指标要求如下:通带边缘频率:,,通带峰值起伏:。阻带边缘频率:,,最小阻带衰减:。分别用窗函数法和等波纹滤波器法设计两种FIR数字滤波器。实验要求:给出FIR数字滤波器的冲激响应,绘出它们的幅度和相位频响曲线,讨论它们各自的实现形式和特点。1-1)用窗函数法实现:调用函数[n,wn,bta,ftype]=kaiserord(f,a,dev,

7、fs)参数:f=[0.30.450.650.8]为对应数字频率,,,,a=[010]为由f指定的各个频带上的幅值向量,一般只有0和1表示;和f长度关系为(2*a的长度)—2=(f的长度)devs=[0.010.10870.01]用于指定各个频带输出滤波器的频率响应与其期望幅值之间的最大输出误差或偏差,长度与a相等,计算公式:阻带衰减误差=,通带波动衰减误差=fs缺省值为2HZ>>[n,wn,bta,ftype]=kaiserord([0.30.450.650.8],[010],[0.010.

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。