无限冲激响应滤波器,简称IIR数字滤波器(英语:infinite impulse response filter),是数字滤波器的一种。由于无限冲激响应滤波器中存在反馈回路,因此对于脉冲输入信号的响应是无限延续的。滤波器的任务是通过一定运算关系,改变输入信号的频谱。数字滤波器是利用计算机程序、专用芯片等软、硬件改变数字信号频谱。如果要处理的是模拟信号可以通过A/D在信号形式上进行变换,在利用数字滤波器处理后经过D/A恢复为模拟信号。
利用选频滤波器的特性可以提取有用的信号频率分量,这类滤波器适用输入信号中有用信号频带与干扰信号频带不同的情况。
选频数字滤波器设计过程一般归纳为以下三个步骤:
- 按照实际需求性能要求确定滤波器技术指标。
- 用一个因果稳定的系统函数IIR去逼近这个要求。
- 用一个有限精度的运算(软、硬件)去实现这个传递函数
无限冲激响应滤波器的冲激响应无限长,不像有限冲激响应滤波器,所以有以下问题:
- 如何使能量集中在
附近。
- 如何正向Z变换(forward Z transform)以及逆向Z变换(inverse Z transform)为稳定。
能使用最小相位滤波器(minimum phase filter)来解决以上问题,使一无限冲激响应滤波器为稳定且能量集中在
附近。
- 最小相位滤波器(minimum phase filter):所有的极点(poles)以及零点(zeros)都在单位圆以内。
- 最小相位滤波器为稳定(stable)且因果(causal),且最小相位滤波器的逆向(inverse)变换也为稳定(stable)且因果(causal)。
![{\displaystyle H(z)=C{\frac {(z-z_{1})(z-z_{2})(z-z_{3})...(z-z_{R})}{(z-p_{1})(z-p_{2})(z-p_{3})...(z-p_{S})}}\,}](https://wikimedia.org/api/rest_v1/media/math/render/svg/b2185d792cb09eca9e90307743a6753a5b2e272d)
![{\displaystyle H^{-1}(z)=C^{-1}z^{S-R}{\frac {(1-p_{1}z^{-1})(1-p_{2}z^{-1})(1-p_{3}z^{-1})...(1-p_{S}z^{-1})}{(1-z_{1}z^{-1})(1-z_{2}z^{-1})(1-z_{3}z^{-1})...(1-z_{R}z^{-1})}}\,}](https://wikimedia.org/api/rest_v1/media/math/render/svg/63ac5288d5a3a5429b161665026bbdadfd1b0698)
- 其中
为
个零点,
为
个极点,
个零点和
个极点都在单位圆内。
![{\displaystyle H(z)=C{\frac {(z-z_{1})(z-z_{2})(z-z_{3})...(z-z_{R})}{(z-p_{1})(z-p_{2})(z-p_{3})...(z-p_{S})}}\,}](https://wikimedia.org/api/rest_v1/media/math/render/svg/b2185d792cb09eca9e90307743a6753a5b2e272d)
- 假设
在单位圆外。
![{\displaystyle H_{1}(z)=C{\frac {(z-z_{1})(z-z_{2})(z-z_{3})...(z-z_{R})}{(z-p_{1})(z-p_{2})(z-p_{3})...(z-p_{S})}}\times z_{2}{\frac {z-{\overline {(z_{2}^{-1})}}}{(z-z_{2})}}\,}](https://wikimedia.org/api/rest_v1/media/math/render/svg/02350a9034f20f78fcba500f300a5b3436fb2a26)
![{\displaystyle =z_{2}C{\frac {(z-z_{1})(z-{\overline {(z_{2}^{-1})}})(z-z_{3})...(z-z_{R})}{(z-p_{1})(z-p_{2})(z-p_{3})...(z-p_{S})}}\,}](https://wikimedia.org/api/rest_v1/media/math/render/svg/31179dd8cf0d3ddcf63388b8b5b32061fdeda0f4)
为最小相位滤波器(minimum phase filter),符合
且
和
只有相位不同。
- 另外,
称为全通滤波器(all pass filter)。
- 无限冲激响应滤波器为一个最小相位滤波器和一个全通滤波器串接(cascade):
![{\displaystyle H(z)=H_{mp}(z)H_{ap}(z)\,}](https://wikimedia.org/api/rest_v1/media/math/render/svg/39234bd2810fab4aa3e0d4a6d9101b56a32516d0)
- 其中
:无限冲激响应滤波器,
:最小相位滤波器,
:全通滤波器。
无限冲激响应滤波器(IIR filter)的优点:
无限冲激响应滤波器(IIR filter)的缺点:
- 冲激响应(impulse response)为无限长:造成当输入数码信号为有限长的时候,输出数码信号会变成无限长。
- 比有限冲激响应滤波器(FIR filter)较不易最佳化(optimize)。
- 不一定是稳定的(stable):因为Z变换(Z transform)后所有的极点(pole)不一定都在单位圆内。
IIR数字滤波器设计有以下几种基本方法:
- 零、极点累试法:由于频率响应在靠近集点频处会出现峰值,在靠近零点频率处会出现谷值,并且零、极点越靠近单位圆峰谷越明显。所以在设计时通过不断调整零、极点位置,达到设计标准,对要求不高的简单滤波器,可以用此方法设计。
- 最优化设计:这种设计方法一般事先确定最好的推测,找出最好推测下误差最小的系统函数H(z)。在得到最佳结果之前,因为设计需要大量反复计算,所以必须用到CAD技术,而此类设计随着技术发展,应用也越来越多。
- 用模拟滤波器理论设计数字滤波器:利用模拟滤波器理论先设计模拟滤波器,得到其系统函数Ha(s)。然后经过一定的变换,得到满足要求的数字滤波器系统函数H(z)。这样设计的优点是模拟滤波器设计理论成熟,有许多现成的公式、曲线、表格可以直接使用。并且在许多场合下就是用数字滤波器代替模拟滤波器。这种由模拟滤波器设计数字滤波器的方法,其实就是从s平面到z平面的映射变换,对这个变换基本要求是:
- 数字滤波器的频率响应要保持模拟滤波器的频率响应,所以s平面的虚轴jΩ应当映射到z平面的单位圆ejw上。
- 模拟滤波器的因果稳定性经映射数字滤波器仍应保持,所以s平面的左半平面应当映射到z平面的单位圆内。
脉冲响应不变法也称冲激响应不变法,是满足s平面到z平面的映射两个基本要求的常用方法之一。实现方法是已知模拟滤波器的冲冲响应ha(t),让数字滤波器h(n)的包络为ha(t),即
![{\displaystyle h(n)=h_{a}(t)|_{t=nT}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/536527d0fc52e119ff2b32feca06c89dc4a9dd7c)
故此得名冲激不变法,这种方法的实质上是时域采样法,基本设计步骤是先得到模拟滤波器的系统函数Ha(s);然后对冲激响应ha(t)采样,得到数字滤波器的单位脉冲响应h(n);最后,h(n)所对应的z变换,正是所要求的数字系统的系统函数
H(z),即
冲激不变法又称标准z变换法。根据理想采样串行z变换与拉普拉斯变换的关系式,我们可以得到
—(1)
其映射关系为
或 ![{\displaystyle s={\frac {1}{T}}\ln z}](https://wikimedia.org/api/rest_v1/media/math/render/svg/6428a8accd580ce526464f4ccfcaaf6e085fc676)
由(1)式当s = jΩ 时,得到的数字滤波器的响应为
—(2)
由(2)式可见,数字滤波器的频率响应不是简单的重现模拟滤波器的频率响应,而是模拟滤波器频率响应的周期展开,其中频率映射关系为![{\displaystyle \omega =\Omega T}](https://wikimedia.org/api/rest_v1/media/math/render/svg/537765f90f519be74e2ce60020ae3379176f2083)
若模拟滤波器是带限的,即
,则
—(3)
这时,数字滤波器可在折叠频率内不失真的重现模拟滤波器的频率响应。但是实际模拟滤波器频率响应不可能是真正带限的,所以脉冲响应不辨法总会有混叠失真。
下面以Ha(s)均为单极点为例,讨论冲激不变法设计IIR滤波器的具体方式。Ha(s)可展开为部分分式
![{\displaystyle H_{a}(s)=\sum _{k=1}^{N}{\frac {A_{k}}{s-s_{k}}}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/36c5f20e74c881bfde15ea4308a56e938123b79d)
上面式子中
是H_a(s)的极点,对应的模拟系统单位冲激响应为
![{\displaystyle h_{a}(t)=\sum _{k=1}^{N}A_{k}e^{s_{k}t}u(t)}](https://wikimedia.org/api/rest_v1/media/math/render/svg/917d91c22d91cce2e09702c89e94bb5eca98c47e)
对ha(t)采样,所有连续时间便量t由离散时间便量nT代替,则
![{\displaystyle h_{a}(nT)=\sum _{k=1}^{N}A_{k}e^{s_{k}nT}u(nT)}](https://wikimedia.org/api/rest_v1/media/math/render/svg/f9ea1d247cabf6d16c904911dcedcf5d2b656b40)
对Ha(n)取z变换
![{\displaystyle {\mathcal {L}}\left\{h(n)\right\}=H(z)=\sum _{k=1}^{N}{\frac {A_{k}}{1-e^{s_{k}T}z^{-1}}}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/0eabf2817afba79e44db8a1cff62e7cd589779f9)
上式中
是z平面的极点,当极点sk在s平面的左半平面时,
,则
,
,H(z)的极点在单位圆内。由此可知,s平面与z平面的极点一一对应,并且稳定的模拟系统变换后仍为稳定的数字系统。
在(3)式
,考虑到若采样频率很高时,会使得数字系统的福频特性的增益很高。为防止溢出,通常在采样时做修正,令h(n)=Tha(n),这样实际数字滤波器的系统函数及频率响应特性分别为
![{\displaystyle H(z)=\sum _{k=1}{N}{\frac {TA_{k}}{1-e^{s_{k}T}z^{-1}}}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/878fce0a7ac9c41f445248ec10924d7e8f048e3c)
![{\displaystyle H(e^{j\omega })=\sum _{k=-\infty }^{\infty }H_{a}\left(j{\frac {\omega }{T}}-jk\Omega _{s}\right)\approx H_{a}\left({\frac {\omega }{T}}\right)\qquad \qquad |\omega |\leq \pi }](https://wikimedia.org/api/rest_v1/media/math/render/svg/0f6d7568550d48b618e109caa7467df1cf59204c)
由以上分析可见,按照
变换过程,从模拟滤波器Ha(s)得到数字滤波器H(z),设计还是相当冗繁,不过由于s平面与z平面的极点一一对应,我们可以简化变换步骤。
设Ha(s)均为一阶极点,省略中间步骤,从
设计过程分为两个步骤:
![{\displaystyle H_{a}(s)=\sum _{k=1}{N}{\frac {A_{k}}{s-s_{k}}}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/615dfbd726570905acf8fe26e87e4b060b9e7e1e)
![{\displaystyle H(z)=\sum _{k=1}{N}{\frac {TA_{k}}{1-e^{s_{k}T}z^{-1}}}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/878fce0a7ac9c41f445248ec10924d7e8f048e3c)
如果Ha(s)还有m阶的重极点,我们给出对应的z变换的有理分式为
![{\displaystyle {\frac {1}{(s-s_{k})^{m}}}\rightarrow {\frac {(-1)^{m-1}}{(m-1)!}}{\frac {d^{m-1}}{ds_{k}^{m-1}}}{\frac {1}{1-e^{s_{k}T}z^{-1}}}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/730e9c1ad759f8d5678e8b606ebfb0a1f300b951)
除了单极点与重极点外,对Ha(s)的共轭极点,我们也给出对应的z变换的一般有理分式
![{\displaystyle {\frac {s+a}{(s+a)^{2}+b^{2}}}\rightarrow {\frac {1-e^{-aT}\cos(bT)*z^{-1}}{1-2e^{-aT}\cos(bT)*2^{-1}+e^{-2aT}z^{-2}}}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/2d12f2595acf2cf03b9a4c7c8dd9752563f4a6fa)
![{\displaystyle {\frac {s+b}{(s+a)^{2}+b^{2}}}\rightarrow {\frac {1-e^{-aT}\sin(bT)*z^{-1}}{1-2e^{-aT}\cos(bT)*2^{-1}+e^{-2aT}z^{-2}}}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/1206182e8878c55cb567fddea540c370cfdca392)
这样,当Ha(s)部分分式展开式中如果有重极点或共轭极点,在上述设计过程第二步做相应修改即可。
冲激不变法的频率变换
是线性关系,所以在幅度及相位上数字滤波器都保留着模拟滤波器的频率响应特点。但是由于脉冲不变法本身具有频谱周期延展拓宽的特性,所以失真较大。尤其是对衰减特性差的滤波器频率响应会有严重的混叠现象,适用范围受到限制。
下面给出用脉冲不变法设计数字滤波器的一般步骤
- 确定数字滤波器的性能要求及各数字临界频率
![{\displaystyle {\omega _{k}}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/cbb78e8831166835529a2c33165fe518b8ceacee)
- 由脉冲不变法的变换关系将
变换为模拟域临界频率![{\displaystyle {\Omega _{k}}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/092c9539a66866f9c7a4a4a8d3b1582155cdebd4)
- 按
及衰减指标求出模拟滤波器的传递函数Ha(s)。这个模拟低通滤波器也称为模拟原型滤波器。
- 由脉冲不变法的变换关系将Ha(s)变换为数字滤波器的系统函数H(z)
在设计过程中,除了第一步求数字临界频率
时,要用到采样间隔T或采样频率fs以外,最后的结果与其他各步骤中T或fs的取值无关。所以为了简化运算,在实际运算时,除了第一步外,通常取T=1。
这是由解出和模拟滤波器在同样的采样时间下有一样输出值的T(z)所获得,且当这两者的输入接为一个脉冲时才适用。
有一点需要注意的是,借由此种方法产生的数字滤波器的所有输入皆是一个近似值,除了只对于脉冲输入非常精确。这是一种最简单的IIR滤波器设计方法,它在低频是最精确的,所以通常被用在低通滤波器上。
对于拉普拉斯变换(Laplace transform)或是z-transform,变换过后的输出只是输入乘上相对应的变换函数,T(s)或T(z)。Y(s)和Y(z)分别是输入X(s)和输入X(z)变换过后的输出。
![{\displaystyle Y(s)=T(s)X(s)}](https://wikimedia.org/api/rest_v1/media/math/render/svg/f299612af0fd3cffa58799bdb57d5386d6f3dc61)
![{\displaystyle Y(z)=T(z)X(z)}](https://wikimedia.org/api/rest_v1/media/math/render/svg/8154e2e59a4b5d0701e1770a830f397542601b48)
然而,当拉普拉斯变换和z-transform对单位脉冲作变换时为1,变换后的输出结果分别为
![{\displaystyle Y(s)=T(s)}](https://wikimedia.org/api/rest_v1/media/math/render/svg/a493bc7f05f911668e91e4c75c05a68ee48bb66a)
![{\displaystyle Y(z)=T(z)}](https://wikimedia.org/api/rest_v1/media/math/render/svg/f21bbe843b7e8680b68c236bda9e3a2dd9c585c3)
现在模拟滤波器的输出在时域上就只是拉普拉斯逆变换(inverse Laplace transform)
![{\displaystyle y(t)=L^{-1}[Y(s)]=L^{-1}[T(s)]}](https://wikimedia.org/api/rest_v1/media/math/render/svg/e4d65de5e6987206b0abf44e1a6f9e0fbc8cb1e5)
如果我们用nT代替t,可以得到在采样时间下源于脉冲的输出,y(nT),又可以为了便利性表为y(n)
![{\displaystyle y(n)=y(nT)=y(t)|_{t=sT}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/3768c956a77eabf53703d446dfb305eca353c378)
这个离散时间信号可以被z-transform得到T(z)
![{\displaystyle T(z)=Y(z)=Z[y(n)]}](https://wikimedia.org/api/rest_v1/media/math/render/svg/46c93d98c58336fc2617d98df851c3b9dc731762)
![{\displaystyle T(z)=Z[y(n)]=Z[y(nT)]}](https://wikimedia.org/api/rest_v1/media/math/render/svg/f6acbf6cbca467b58e91b491c472bd03b3fac0b4)
![{\displaystyle T(z)=Z\left\{L^{-1}[T(s)]_{t=nT}\right\}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/648a7c90004126b80ab0e374c2c518c56771677f)
最后这条等式指出在数学领域描述数字IIR滤波器就是对采样完经拉普拉斯变换为T(s)的模拟信号作z-transform,通常会简化为
![{\displaystyle T(z)=Z[T(s)]*T}](https://wikimedia.org/api/rest_v1/media/math/render/svg/0bad4e315aa3364439123c484b4ae4bcc51c185b)
虽然在数学领域上不是完全正确的。
需特别注意有一个乘法数T出现在式子中,这是因为就算拉普拉斯变换和z-transform对单位脉冲为1,脉冲本身不一定是一样的。对模拟信号而言,脉冲在t=0时有无限大的值但是面积为1,但在离散时间的脉冲t=0时为1,所以为了这个情况,需要乘法数T的存在。
这通常相较于impulse invariant昰一个更好的设计方法,数字滤波器正是在采样时有几段不同常数的输入,也就是由离散步阶(step)组成。step invariant IIR 滤波器和同样输入步阶信号至ADC相比是较低精确度的,然而,和impulse invariant相比这对任何输入而言是一个较好的近似法。
当T(z)和T(s)两者都是步阶(step)输入时,step invariant解决一样采样值的困扰,对数字滤波器的输入为u(s),对模拟滤波器的输入是u(t),z-transform和拉普拉斯转对这两个输入作变换以得到变换后的输出信号。
z-transform的变换函数为![{\displaystyle Z[u(n)]={\dfrac {z}{z-1}}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/dddae176f885dd5e3461d82c703d6fe05ee758ea)
经z-transform的输出![{\displaystyle Y(z)=T(z)U(z)=T(z){\dfrac {z}{z-1}}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/1ae76a5b02e9c194b681e6cf784dd356ac427314)
Laplace transform的变换函数为![{\displaystyle L[u(t)]={\dfrac {1}{s}}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/dacbca492c680892cdc61b8fb67bb646a65636c4)
经Laplace transform的输出![{\displaystyle Y(s)=T(s)U(s)={\dfrac {T(s)}{s}}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/7c3d91a73ae9342f99f9328ed332d58ba8f23faf)
模拟滤波器的输出是y(t),就是Y(s)的拉普拉斯逆变换。如果每经过T秒就被采样一次,它就是y(n),也就是Y(z)的逆变换。这些信号被用来解出数字滤波器的和模拟滤波器在采样时间下有着相同输出
以下的等式指出T(z)的解法,也就是对模拟滤波器取近似的公式
![{\displaystyle T(z)={\dfrac {z-1}{z}}Y(z)}](https://wikimedia.org/api/rest_v1/media/math/render/svg/ae2d312413658941765cd18ce5a1aa5d46d0820b)
![{\displaystyle T(z)={\dfrac {z-1}{z}}Z[y(n)]}](https://wikimedia.org/api/rest_v1/media/math/render/svg/218124b8b56174ceba89930d844301416585b904)
![{\displaystyle T(z)={\dfrac {z-1}{z}}Z[Y(s)]}](https://wikimedia.org/api/rest_v1/media/math/render/svg/b44af0b2b081dd8935ba00712381b082ca35bfe2)
![{\displaystyle T(z)={\dfrac {z-1}{z}}Z[{\dfrac {T(s)}{s}}]}](https://wikimedia.org/api/rest_v1/media/math/render/svg/11b2d1a4450be2c60297c67dade0debc8d614781)
BLT公式利用拉普拉斯变换(Laplace transform)的特性:对于一个x(t)经Laplace变换成的X(s)而言,它的积分在没有初始条件下相当于X(s)/s。所以得出将拉普拉斯变换的信号乘上1/s相当于对此信号在时域下做积分。
然而,接下来这个不同的等式一样也是用近似积分x(t)信号的特性达成:利用x(nT)=x(n)。
在没有初始条件下积分信号相当于计算信号下的面积
![{\displaystyle y(n)=y(n-1)+{\dfrac {x(n)+x(n-1)}{2}}*T}](https://wikimedia.org/api/rest_v1/media/math/render/svg/bab3ed7af2c45e92ebef0d7b9a412616b7619137)
此等式告诉我们再经过一个新的数入信号x(n)后计算新的面积y(n),就只是将先前运算的面积y(n-1) 加上新输入和先前输入的平均乘上采样时间。借由z变换先前的等式变为以下的式子
![{\displaystyle Y(z)=z^{-1}Y(z)+0.5[X(z)+z^{-1}X(z)]*T}](https://wikimedia.org/api/rest_v1/media/math/render/svg/57cc8630057c8402a262402ab2ba66a994a2abfc)
![{\displaystyle Y(z)(1-z^{-1})=0.5TX(z)(1+z^{-1})}](https://wikimedia.org/api/rest_v1/media/math/render/svg/2b674eacd2856fd8718cda7a6e81ca70b1858f48)
![{\displaystyle T(z)={\dfrac {Y(z)}{X(z)}}={\dfrac {T}{2}}{\dfrac {1+z^{-1}}{1-z^{-1}}}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/0972f95e339457e0863044441c03f53b642a614e)
当我们得出X(z)和Y(z)后,我们将解出T(z)
先前的等式是一个数码信号处理系统中的变换函数,此函数将一个系统中的模拟变换函数趋近成作积分,并在分子分母同乘上z后开始解s
![{\displaystyle {\dfrac {T}{2}}{\dfrac {z+1}{z-1}}\approxeq {\dfrac {1}{s}}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/822c7a77ef22c56f662cf0490c296756bf3bd9b8)
![{\displaystyle s={\dfrac {2}{T}}{\dfrac {z-1}{z+1}}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/0bd955e55b680ba8b4fc80f06e26070862441806)
这个关系被用在任何模拟滤波器的拉普拉斯变换函数,以或取近似于模拟滤波器的数字无限冲激响应(IIR)滤波器T(z)。这个结果被标示在下列公式中,此公式用来运算BLT IIR数字滤波器,并从模拟滤波器的拉普拉斯变换函数开始运算起
![{\displaystyle T(z)=T(s)|_{s={\dfrac {2}{T}}{\dfrac {z-1}{z+1}}}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/387f50d1d4ca674f1123713303d345beb6ec5d1b)
这条公式指出近似模拟滤波器的bilinear transform数字IIR滤波器可以从把模拟变换函数T(s)中的s替换成和z的关系得出