基于MATLAB的IIR滤波器设计与实现

基于MATLAB的IIR滤波器设计与实现

  IIR滤波器的设计主要有经典设计法、直接设计法和最大平滑滤波器设计法三种方法。

  1、经典设计法是基于模拟滤波器的变换原理,首先根据滤波器的技术指标设计出相应的模拟滤波器,然后再离散化为满足给定技术指标的数字滤波器。对应的工具函数由完全设计函数——butter、cheby1、cheby2、ellip、besself;阶数估计函数——buttord、cheb1ord、cheb2ord、ellipord;低通模拟原型滤波器函数——buttap、cheb1ap、cheb2ap、ellipap;频率转换函数——lp2lp、lp2bp、lp2bs;滤波器离散化函数——bilinear、impinvar。

  2、直接设计法是离散域内用最小二乘法逼近给定的幅频特性,对应的工具函数是yulewalk。

  3、最大平滑滤波器设计法是设计一般化低通滤波器,其零点数多于极点,对应的工具函数是maxflat。

分别用几个例子来说明三种方法的应用。

例一、经典法设计滤波器有脉冲响应不变法和双线性变换法两种方式。

  (1)、脉冲响应不变法

    用椭圆滤波器原型设计一个低通滤波器,满足wp=0.2pi、Rp=0.5dB、ws=0.3pi、As=20dB。代码如下:

 1 wp=0.2*pi;
 2 ws=0.3*pi;
 3 rp=0.5;
 4 rs=20;
 5 [n,wn]=ellipord(wp,ws,rp,rs,'s');
 6 [z,p,k]=ellipap(n,rp,rs);
 7 w=logspace(-1,1,1000);
 8 h=freqs(k*poly(z),poly(p),w);
 9 semilogx(w,abs(h));
10 grid;

  波形如下:

命令窗口可得:

n =
     3
wn =
    0.6283

 

  (2)、双线性变换法

    设计带通Chebyshev I型数字滤波器,要求通带边界频率为100~200Hz;通带纹波小于3dB;阻带衰减大于30dB;过渡带宽为30Hz;采样频率为1000Hz。代码如下:

1 fs=1000;
2 wp=[100 200]*2/fs;
3 ws=[30 300]*2/fs;
4 rp=3;
5 rs=30;
6 Nn=128;
7 [N,wn]=cheb1ord(wp,ws,rp,rs)
8 [b,a]=cheby1(N,rp,wn)
9 freqz(b,a,Nn,fs)

波形如下:

 

命令窗口可得:

N =
     3
wn =
    0.2000    0.4000
b =
    0.0066         0   -0.0198         0    0.0198         0   -0.0066
a =
    1.0000   -3.3130    6.1125   -6.9677    5.3979   -2.5753    0.6884

例二、用直接法设计一个多频带数字滤波器。

  幅频响应值f=[0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1]; m=[0 0 1 1 0 0 1 1 1 0 0];

具体操作步骤:(1):计算与分子多项式相应的幅值平方响应的辅助分子式和分母式;(2):由辅助分子式和分母式计算完全的频率响应;(3):计算滤波器的脉冲响应;(4):采用最小二乘法拟合脉冲响应,最终求得滤波器的分子多项式。

代码如下:

 

 1 oder=10;
 2 f=0:0.1:1;
 3 m=[0 0 1 1 0 0 1 1 1 0 0];
 4 [b,a]=yulewalk(oder,f,m)
 5 [h,w]=freqz(b,a,128)
 6 axes('position',[0.2 0.2 0.4 0.4]);
 7 plot(f,m,'b-',w/pi,abs(h),'m--');
 8 xlabel('frequency(pi)');
 9 ylabel('magnitude');
10 title('direct IIR design-yulewalk');
11 legend('理想图形','实际图像');
12 grid;

 

波形如下:

 

命令窗口可得:

b =
  Columns 1 through 9
    0.2774   -0.0460   -0.0761    0.1262   -0.3949   -0.0783    0.1008   -0.0571    0.1488
  Columns 10 through 11
    0.0512    0.0270
a =
  Columns 1 through 9
    1.0000   -0.0185    0.4144    0.0393    0.3588    0.1016    0.2372   -0.0633    0.1727
  Columns 10 through 11
    0.0629    0.0496
h =
   0.0335 + 0.0000i   0.0325 - 0.0013i   0.0295 - 0.0023i   0.0244 - 0.0029i   0.0173 - 0.0028i   0.0079 - 0.0018i
  -0.0036 + 0.0006i  -0.0175 + 0.0046i  -0.0338 + 0.0109i  -0.0525 + 0.0201i  -0.0736 + 0.0329i  -0.0970 + 0.0503i
  -0.1223 + 0.0735i  -0.1488 + 0.1038i  -0.1753 + 0.1429i  -0.1999 + 0.1925i  -0.2196 + 0.2539i  -0.2304 + 0.3281i
  -0.2270 + 0.4142i  -0.2034 + 0.5095i  -0.1545 + 0.6079i  -0.0773 + 0.7003i   0.0265 + 0.7762i   0.1505 + 0.8263i
   0.2845 + 0.8453i   0.4175 + 0.8333i   0.5410 + 0.7943i   0.6497 + 0.7347i   0.7417 + 0.6608i   0.8172 + 0.5776i
   0.8778 + 0.4886i   0.9250 + 0.3956i   0.9602 + 0.2995i   0.9837 + 0.2003i   0.9951 + 0.0978i   0.9931 - 0.0077i
   0.9754 - 0.1156i   0.9391 - 0.2233i   0.8818 - 0.3265i   0.8025 - 0.4191i   0.7033 - 0.4933i   0.5899 - 0.5422i
   0.4714 - 0.5620i   0.3580 - 0.5532i   0.2582 - 0.5209i   0.1767 - 0.4726i   0.1147 - 0.4161i   0.0703 - 0.3575i
   0.0406 - 0.3013i   0.0219 - 0.2498i   0.0112 - 0.2038i   0.0057 - 0.1636i   0.0035 - 0.1287i   0.0030 - 0.0984i
   0.0031 - 0.0720i   0.0031 - 0.0485i   0.0022 - 0.0273i   0.0002 - 0.0076i  -0.0033 + 0.0114i  -0.0085 + 0.0305i
  -0.0154 + 0.0506i   -0.0241 + 0.0725i   -0.0343 + 0.0972i  -0.0455 + 0.1259i  -0.0572 + 0.1597i  -0.0681 + 0.2001i
  -0.0763 + 0.2482i  -0.0793 + 0.3050i  -0.0737 + 0.3708i  -0.0550 + 0.4444i  -0.0190 + 0.5228i   0.0382 + 0.6005i
   0.1178 + 0.6698i   0.2173 + 0.7224i   0.3303 + 0.7512i   0.4478 + 0.7532i   0.5608 + 0.7295i   0.6624 + 0.6847i
   0.7487 + 0.6250i   0.8189 + 0.5562i   0.8740 + 0.4832i   0.9160 + 0.4091i   0.9470 + 0.3361i   0.9691 + 0.2652i
   0.9842 + 0.1968i   0.9936 + 0.1308i   0.9983 + 0.0670i   0.9992 + 0.0051i   0.9967 - 0.0555i   0.9910 - 0.1151i
   0.9824 - 0.1743i   0.9707 - 0.2336i   0.9557 - 0.2933i   0.9367 - 0.3540i   0.9131 - 0.4158i   0.8840 - 0.4790i
   0.8480 - 0.5434i   0.8036 - 0.6086i   0.7489 - 0.6734i   0.6820 - 0.7360i   0.6013 - 0.7932i   0.5059 - 0.8407i
   0.3965 - 0.8730i   0.2765 - 0.8842i   0.1522 - 0.8694i   0.0326 - 0.8265i  -0.0728 - 0.7579i  -0.1561 - 0.6700i
  -0.2133 - 0.5720i  -0.2448 - 0.4730i  -0.2543 - 0.3803i  -0.2472 - 0.2983i  -0.2288 - 0.2289i  -0.2037 - 0.1719i
  -0.1755 - 0.1263i  -0.1464 - 0.0905i  -0.1182 - 0.0630i  -0.0917 - 0.0420i  -0.0675 - 0.0264i  -0.0458 - 0.0151i
  -0.0267 - 0.0071i  -0.0102 - 0.0017i   0.0039 + 0.0017i   0.0156 + 0.0034i   0.0249 + 0.0040i   0.0321 + 0.0037i
   0.0372 + 0.0028i   0.0402 + 0.0015i

(因系数w的数据太多,不予给出)

 

例三、用maxflat函数设计一个通用Butter-worth低通滤波器,满足系统函数分子阶数为8阶,系统函数分母阶数为3阶,截止频率为1pi。代码如下:

1 nb=8;
2 na=3;
3 wn=0.6;
4 [b,a]=maxflat(nb,na,wn,'plots')
5 maxflat(nb,na,wn,'trace')

波形如下:

命令窗口可得:

b =
    0.1650    0.5048    0.4100   -0.1134   -0.2329   -0.0244    0.0202   -0.0043    0.0004
a =
    1.0000   -0.1813    0.2073   -0.3006
 Table:
    L         M         N         wo_min/pi wo_max/pi
 
    8.0000         0    3.0000         0    0.2919
    7.0000    1.0000    3.0000    0.2919    0.4021
    6.0000    2.0000    3.0000    0.4021    0.5000
    5.0000    3.0000    3.0000    0.5000    0.5979
    4.0000    4.0000    3.0000    0.5979    0.7081
    3.0000    5.0000    3.0000    0.7081    1.0000
ans =
    0.1650    0.5048    0.4100   -0.1134   -0.2329   -0.0244    0.0202   -0.0043    0.0004

另:在寻找FIR滤波器设计与实现时找到sunev博主的一篇博文,推荐下《基于MATLAB的FIR滤波器设计与实现》

 

posted @ 2015-08-16 14:39  clairvoyant  阅读(10963)  评论(0编辑  收藏  举报