我是靠谱客的博主 可耐高跟鞋,最近开发中收集的这篇文章主要介绍窗函数法FIR滤波器设计,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

FIR滤波器设计通常可以分为窗函数法和频率采样法两类,这里先介绍窗函数法

1. FIR 滤波器简介

考虑一个 N − 1 N-1 N1阶FIR滤波器
z 变 换 z变换 z
H ( z ) = ∑ n = 0 N − 1 h ( n ) z − n H(z) = sum_{n=0}^{N-1}h(n)z^{-n} H(z)=n=0N1h(n)zn
差分方程:
y ( n ) = b 0 x ( n ) + b 1 x ( n − 1 ) + . . . . . b N − 1 x ( n − N + 1 ) y(n)=b_{0}x(n)+b_{1}x(n-1)+.....b_{N-1}x(n-N+1) y(n)=b0x(n)+b1x(n1)+.....bN1x(nN+1)
FIR滤波器只有零点,也叫全零点滤波器(all-zero filter),也有其它的叫法,比如feedforward、non-recursive或者transversal filter等等
FIR滤波器因为只有零点,没有反馈环节,因此是稳定的,另外一个最大的特点就是容易实现严格的线性相位,当FIR的系数满足对称结构,无论是奇对称还是偶对称
奇 对 称 : h ( n ) = h ( N − 1 − n ) 奇对称:h(n)=h(N-1-n) h(n)=h(N1n)
偶 对 称 : h ( n ) = − h ( N − 1 − n ) 偶对称:h(n)=-h(N-1-n) h(n)=h(N1n)
按照冲击响应的奇偶和对称性的奇偶,FIR可以分为以下四种类型

  • Type 1: h ( n ) h(n) h(n)偶对称,系数为奇数(偶数阶),低通、高通、带通
  • Type 2: h ( n ) h(n) h(n)偶对称,系数为偶数(奇数阶),低通、带通
  • Type 3: h ( n ) h(n) h(n)奇对称,系数为奇数(偶数阶),带通
  • Type 4: h ( n ) h(n) h(n)奇对称,系数为偶数(奇数阶),高通、带通
      每种Type适合什么类型的滤波器是根据 H ( w ) H(w) H(w) 0 、 π 、 2 π 0、pi、2pi 0π2π等几个关键地方是否为零或对称性来判断的,在任意一本数字信号处理教材上都会有介绍
    以上几种类型主要是概念上的区分,matlab在设计出一个滤波器后也会给出这些信息,如随便用FDA工具设计一个高通后,给出的信息里可以看到奇数个系数(56,偶数阶),线性相位,Type 1型在这里插入图片描述

2.窗函数法设计FIR滤波器

理想滤波器的冲击响应是非因果、无限长的,窗函数法是从时域出发,用因果、有限长的冲击响应去逼近非因果无限长的理想滤波器。
  设有一理想低通滤波器, H d ( e j ω ) 、 h d ( n ) H_d(e^{jomega})、h_d(n) Hd(ejω)hd(n),
   h d ( n ) = 1 2 π ∫ − π π H d ( e j ω ) e j ω d ω h_d(n) = frac{1}{2pi}int_{-pi}^{pi}H_d(e^{jomega})e^{jomega}domega hd(n)=2π1ππHd(ejω)ejωdω
  因为 H d ( e j ω ) H_d(e^{jomega}) Hd(ejω)是矩形,因此 h d ( n ) h_d(n) hd(n)是非因果无限长的,现在我们用 h ( n ) h(n) h(n)来逼近,最直接的方法就是用有限长的窗来截断
   h ( n ) = h d ( n ) w ( n ) h(n)=h_d(n)w(n) h(n)=hd(n)w(n)
  这里再把 H d ( e j ω ) H_d(e^{jomega}) Hd(ejω)定义的具体些,如一个截止频率为 w c w_c wc的低通滤波器,通带增益为0dB、具有线性相位且群延迟为 α alpha α,则 H d ( e j ω ) H_d(e^{jomega}) Hd(ejω)表示为以下形式
  
H d ( e j ω ) = { e − j ω α , − ω c ≤ ω ≤ ω c 0 , ω c &lt; ∣ ω ∣ &lt; ω c H_d(e^{jomega})=left{begin{matrix} e^{-jomegaalpha},-omega_cleq omegaleq omega_c\ 0,omega_c&lt;|omega|&lt; omega_c end{matrix}right. Hd(ejω)={ejωα,ωcωωc0,ωc<ω<ωc
则相应的时域 h d ( n ) h_d(n) hd(n)
h d ( n ) = 1 2 π ∫ − π π e − j ω α e j ω d ω = s i n [ ω c ( n − α ) ] π ( n − α ) h_d(n) = frac{1}{2pi}int_{-pi}^{pi}e^{-jomegaalpha}e^{jomega}domega =frac{sin[omega_c(n-alpha)]}{pi(n-alpha)} hd(n)=2π1ππejωαejωdω=π(nα)sin[ωc(nα)]
  这个 h d ( n ) h_d(n) hd(n)还是非因果无限长的,最直接的方法,用一个因果的矩形窗 R N ( n ) R_N(n) RN(n)去截断,同时,我们还要满足FIR的对称结构,因为因果的矩形窗对称中心为 ( N − 1 ) / 2 (N-1)/2 (N1)/2,先将理想滤波器也延迟 ( N − 1 ) / 2 (N-1)/2 (N1)/2,即
α = ( N − 1 ) / 2 alpha=(N-1)/2 α=(N1)/2
因此,延迟后 h d ( n ) h_d(n) hd(n)变为下式
h d ( n ) = s i n [ ω c ( n − ( N − 1 ) 2 ) ] π ( n − ( N − 1 ) 2 ) ) , − ∞ &lt; n &lt; + ∞ h_d(n) = frac{sin[omega_c(n-frac{(N-1)}{2})]}{pi(n-frac{(N-1)}{2}))},-infty &lt;n&lt;+infty hd(n)=π(n2(N1)))sin[ωc(n2(N1))]<n<+
再截断变为有限长,因为矩形窗非零部分等于1,逼近得到的因果有限长 h ( n ) h(n) h(n)直接
h ( n ) = s i n [ ω c ( n − ( N − 1 ) 2 ) ] π ( n − ( N − 1 ) 2 ) ) , 0 ≤ n ≤ N − 1 h(n) = frac{sin[omega_c(n-frac{(N-1)}{2})]}{pi(n-frac{(N-1)}{2}))},0 leq nleq N-1 h(n)=π(n2(N1)))sin[ωc(n2(N1))]0nN1

2.1 talk is cheap,show me code

以上步骤其实就基本完成了一个窗函数法设计低通滤波器的过程,看起来挺简单,用代码验证下

close all
Nd = 16385;             % 很长很长,代表理想滤波器的无限长
fs = 16000;
fc = 4000.0;               %cut-off frequency
wc = 2*pi*fc/fs;
n = -(Nd-1)/2:1:(Nd-1)/2;
% n = 
hd = sin(n*wc)./(pi*n);
center = (Nd+1)/2;
hd(center)=wc/pi;
figure,plot(n,hd),title('理想低通')
N_FFT_hd = 16384*2;
Hd = fft(hd,N_FFT_hd);
Hd_freResp = abs(Hd(1:N_FFT_hd/2+1));
Hd_freResp = 2*pow2db(Hd_freResp/max(Hd_freResp));
figure,plot((1:N_FFT_hd/2+1)*fs/N_FFT_hd,Hd_freResp),title('理想低通频率响应'),grid on

N = 257;  %截断长度
win = hamming(N)';
cut_index = center-(257-1)/2:center+(257-1)/2;
h = hd(cut_index).*win;
figure,plot(h),title('截断h(n)')
N_FFT_h = 16384;
H = fft(h,N_FFT_h);
H_freResp = (abs(H(1:N_FFT_h/2+1)));
H_freResp = 2*pow2db(H_freResp/max(H_freResp));
figure,plot(H_freResp(1:N_FFT_h/2+1)),title('逼近低通频率响应'),grid on

在这里插入图片描述
在这里插入图片描述

可以对比看到截断后的逼近得到的滤波器阻带衰减更少,并且过渡带纹波更大

3.窗函数选择

在第二部分中实现利用窗函数设计低通滤波器的过程,截断过程是窗与理想滤波器相乘,由复卷积定理可知时域相乘等于频域卷积
   H ( e j ω ) = 1 2 π ∫ − π π H d ( θ ) W R ( ω − θ ) d θ H(e^{jomega})= frac{1}{2pi}int_{-pi}^{pi}H_d(theta)W_R(omega-theta)dtheta H(ejω)=2π1ππHd(θ)WR(ωθ)dθ
  贴一张图说明这个卷积过程
  在这里插入图片描述
  从这个卷积过程可以看到,窗的形状会对过渡带以及肩峰(吉布斯效应)产生影响,还是上面的代码,改变截断窗为汉明窗,结果得到的低通滤波器如下
  在这里插入图片描述
  可以看到,最终得到的结果与使用矩形窗相比有了较大的改善,过渡带更平稳、阻带衰减更大,更接近理想滤波器的性能。这个结果也可以与直接使用FDA工具设计出来的做对比,结果是一样的。
  在窗的选择上,只有当窗函数的能量集中在主瓣,旁瓣能量越小,即窗的形状越接近冲击函数时, H ( ω ) H(omega) H(ω)才能逼近 H d ( ω ) H_d(omega) Hd(ω)
  因此,在实际设计中,需要根据不同窗的主瓣宽带、旁瓣峰值、过渡带宽、阻带衰减等指标选择合适的窗,各个窗的一些指标在各书籍中都能查到。矩形窗的主瓣宽度最小,但是旁瓣衰减也最小,hamming窗是折中主瓣宽度与旁瓣衰减常用的一种窗。

Design of FIR Filters

最后

以上就是可耐高跟鞋为你收集整理的窗函数法FIR滤波器设计的全部内容,希望文章能够帮你解决窗函数法FIR滤波器设计所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(64)

评论列表共有 0 条评论

立即
投稿
返回
顶部