维纳滤波器 (Wiener filter)是由美国数学家诺伯特·维纳 (Norbert Wiener)于1940年代提出,并于1949年首次正式发表的一种线性滤波技术。它的设计目标是在最小均方误差 的准则下,从被杂讯干扰的观测讯号中,恢复出原始讯号。此滤波器的核心假设包括:讯号与杂讯皆为平稳随机过程 ,并且其统计特性(如相关函数与功率谱)已被确定。基于这些假设,维纳滤波器透过统计优化,使得滤波后讯号与真实讯号之间的平均平方差达到最小。
与理想化的通阻型滤波器(如低通 、高通 、带通 或带阻 )不同,维纳滤波器会根据讯号与杂讯的统计特性,动态调整对各频段的保留或抑制程度。它具有两种形式:
非因果版本 :可以利用未来资讯来达成最佳去噪效果,但不适用于即时系统。
因果版本 :只使用当前与过去资料,以适应即时处理需求,但推导上更为复杂。
维纳滤波器广泛应用于音讯降噪、影像复原、通讯无线通道均衡等领域;同时也成为多种自适应滤波演算法 如 LMS、RLS 及卡尔曼滤波器的重要理论基石。
维纳滤波器的理论基础可追溯至维纳与霍夫(Norbert Wiener and Eberhard Hopf)对随机讯号估计问题的研究,其推导出的维纳–霍夫方程提供了解析解,使得在理想条件下可以精确求出滤波器的脉冲响应或系数。在离散时间域中,维纳滤波器可以实作为有限长度(FIR )或无限长度(IIR )形式;而若进一步要求因果性,则必须透过频谱因式分解处理,以确保滤波器可以即时实作。
与传统设计为低通、高通、带通等类型的频率选择性滤波器不同,维纳滤波器不单以频率为设计依据,而是依据输入讯号与期望输出的统计特性,于各频段进行权重调整。其在频域上的滤波器传输函数通常具有非零相位响应,这表示它可能会改变讯号的波形结构,但可保证输出在统计意义下最接近目标讯号。
为解决实务中无法事先得知讯号与杂讯统计特性的限制,维纳滤波器衍生出一系列自适应滤波方法,像是最小均方(LMS)与递回最小平方(RLS)演算法。这些方法可在线估测滤波系数,使滤波器能够追踪动态环境变化而维持近似最小均方误差的性能。
除了用于一维讯号的去杂讯,维纳滤波技术也已扩展至多维资料,例如影像处理中的降噪与去模糊。这类应用中,空间域与频域的维纳滤波器皆可使用,并可根据局部统计特性调整滤波强度,达到空间自适应的效果。
维纳滤波器提供了一种将统计估计与线性系统设计结合的方式,并开启了数位讯号处理中以机率模型为基础的滤波方法发展,其理论影响深远,至今仍是统计讯号处理与通讯系统中的重要工具。
假设维纳滤波器的输入信号是
s
(
t
)
{\displaystyle s(t)}
,叠加噪声
n
(
t
)
{\displaystyle n(t)}
。输出信号
x
(
t
)
{\displaystyle x(t)}
通过滤波器
g
(
t
)
{\displaystyle g(t)}
使用下面的卷积运算得到:
x
(
t
)
=
g
(
t
)
∗
(
s
(
t
)
+
n
(
t
)
)
{\displaystyle x(t)=g(t)*(s(t)+n(t))}
其中
s
(
t
)
{\displaystyle s(t)}
是需要估计的原始信号
n
(
t
)
{\displaystyle n(t)}
是噪声
x
(
t
)
{\displaystyle x(t)}
是估计出的信号(我们希望它能等同于
s
(
t
)
{\displaystyle s(t)}
)
g
(
t
)
{\displaystyle g(t)}
是维纳滤波器
误差是
e
(
t
)
=
s
(
t
+
d
)
−
x
(
t
)
{\displaystyle e(t)=s(t+d)-x(t)}
,方差是
e
2
(
t
)
=
s
2
(
t
+
d
)
−
2
s
(
t
+
d
)
x
(
t
)
+
x
2
(
t
)
{\displaystyle e^{2}(t)=s^{2}(t+d)-2s(t+d)x(t)+x^{2}(t)}
其中
s
(
t
+
d
)
{\displaystyle s(t+d)}
是所期望的滤波器输出
e
(
t
)
{\displaystyle e(t)}
是误差
根据d 的不同,问题名称可以更换为:
如果
d
>
0
{\displaystyle d>0}
那么问题是预测
如果
d
=
0
{\displaystyle d=0}
那么问题是滤波
如果
d
<
0
{\displaystyle d<0}
那么问题是平滑
将
x
(
t
)
{\displaystyle x(t)}
写成卷积 积分:
x
(
t
)
=
∫
−
∞
∞
g
(
τ
)
[
s
(
t
−
τ
)
+
n
(
t
−
τ
)
]
d
τ
{\displaystyle x(t)=\int _{-\infty }^{\infty }{g(\tau )\left[s(t-\tau )+n(t-\tau )\right]d\tau }}
.
计算平方误差的均值 ,可得
E
(
e
2
)
=
R
s
(
0
)
−
2
∫
−
∞
∞
g
(
τ
)
R
x
s
(
τ
+
d
)
d
τ
+
∫
−
∞
∞
∫
−
∞
∞
g
(
τ
)
g
(
θ
)
R
x
(
τ
−
θ
)
d
τ
d
θ
{\displaystyle E(e^{2})=R_{s}(0)-2\int _{-\infty }^{\infty }{g(\tau )R_{x\,s}(\tau +d)d\tau }+\int _{-\infty }^{\infty }{\int _{-\infty }^{\infty }{g(\tau )g(\theta )R_{x}(\tau -\theta )d\tau }d\theta }}
其中
R
s
{\displaystyle \,\!R_{s}}
是
s
(
t
)
{\displaystyle s(t)}
的自相关 函数
R
x
{\displaystyle \,\!R_{x}}
是
x
(
t
)
{\displaystyle x(t)}
的自相关 函数
R
x
s
{\displaystyle R_{x\,s}}
是
x
(
t
)
{\displaystyle x(t)}
和
s
(
t
)
{\displaystyle s(t)}
的互相关 函数
如果信号
s
(
t
)
{\displaystyle s(t)}
和噪声
n
(
t
)
{\displaystyle n(t)}
是不相关的(例如,互相关是0)那么请注意
R
x
s
=
R
s
{\displaystyle R_{x\,s}=R_{s}}
R
x
=
R
s
+
R
n
{\displaystyle \,\!R_{x}=R_{s}+R_{n}}
这个的目的是求最优的
g
(
t
)
{\displaystyle g(t)}
,使得
E
(
e
2
)
{\displaystyle E(e^{2})}
最小。
稳态解(Stationary solution)[ 编辑 ]
维纳滤波对于因果系统 与非因果系统 有两种不同解,如下:
非因果解(Anticausal solution)[ 编辑 ]
G
(
s
)
=
S
x
,
s
(
s
)
e
α
s
S
x
(
s
)
{\displaystyle G(s)={\frac {S_{x,s}(s)e^{\alpha s}}{S_{x}(s)}}}
其中
S
{\displaystyle S}
是谱函数。
只要
g
(
t
)
{\displaystyle g(t)}
是最优的,那么最小均方误差公式简化为
E
(
e
2
)
=
R
s
(
0
)
−
∫
−
∞
∞
g
(
τ
)
R
x
,
s
(
τ
+
d
)
d
τ
{\displaystyle E(e^{2})=R_{s}(0)-\int _{-\infty }^{\infty }{g(\tau )R_{x,s}(\tau +d)d\tau }}
那么方程的解
g
(
t
)
{\displaystyle g(t)}
就是
G
(
s
)
{\displaystyle G(s)}
的双边拉普拉斯变换逆变换(inverse two-sided Laplace transform)。
G
(
s
)
=
H
(
s
)
S
x
+
(
s
)
{\displaystyle G(s)={\frac {H(s)}{S_{x}^{+}(s)}}}
其中
H
(
s
)
{\displaystyle H(s)}
是
S
x
,
s
(
s
)
e
α
s
S
x
−
(
s
)
{\displaystyle {\frac {S_{x,s}(s)e^{\alpha s}}{S_{x}^{-}(s)}}}
的拉普拉斯逆变换positive time解
S
x
+
(
s
)
{\displaystyle S_{x}^{+}(s)}
是
S
x
(
s
)
{\displaystyle S_{x}(s)}
的拉普拉斯逆变换positive time解
S
x
−
(
s
)
{\displaystyle S_{x}^{-}(s)}
是
S
x
(
s
)
{\displaystyle S_{x}(s)}
的拉普拉斯逆变换negative time解
离散序列FIR维纳滤波器框图。输入信号 w [n ]与维纳滤波器 g [n ]进行卷积,输出结果与参考信号 s [n ]进行比较,得到滤波误差 e [n ].
因果的有限冲激响应(FIR)维纳滤波器通过使用输入和输出信号的统计信息,而不是使用一些给定的数据矩阵X和输出矢量Y,来发现最佳的抽头权重。它将输入信号的自相关的估计(T)代入输入矩阵X,将输出和输入信号的互相关估计(V)代入的输出向量Y。
为了获得维纳滤波系数,考虑将信号w[n]输入到一个N阶维纳滤波器,系数
{
a
i
}
{\displaystyle \{a_{i}\}}
,
i
=
0
,
…
,
N
{\displaystyle i\,=\,0,\,\ldots ,\,N}
,N的滤波器的输出被记作x[n],这是由下式给出
x
[
n
]
=
∑
i
=
0
N
a
i
w
[
n
−
i
]
{\displaystyle x[n]=\sum _{i=0}^{N}a_{i}w[n-i]}
。
剩余误差来表示e[n]的,被定义为e [n ] = x [n ] − s [n ](参见相应的框图)。维纳滤波器被设计成最小化均方误差(MMSE准则),它可以如下简而言之:
a
i
=
arg
min
E
{
e
2
[
n
]
}
{\displaystyle a_{i}=\arg \min ~E\{e^{2}[n]\}}
,
E
{
⋅
}
{\displaystyle E\{\cdot \}}
表示期望算子。在一般情况下,系数
a
i
{\displaystyle a_{i}}
可能是复数,在w[n]的和s[n]是复数的情况下可能推导出。对于复信号,待求解矩阵是一个共轭对称 Toeplitz矩阵 ,而不是对称 Toeplitz矩阵 。为简单起见,下面只考虑所有这些量实数的情况。均方误差(MSE)可改写为:
E
{
e
2
[
n
]
}
=
E
{
(
x
[
n
]
−
s
[
n
]
)
2
}
=
E
{
x
2
[
n
]
}
+
E
{
s
2
[
n
]
}
−
2
E
{
x
[
n
]
s
[
n
]
}
=
E
{
(
∑
i
=
0
N
a
i
w
[
n
−
i
]
)
2
}
+
E
{
s
2
[
n
]
}
−
2
E
{
∑
i
=
0
N
a
i
w
[
n
−
i
]
s
[
n
]
}
.
{\displaystyle {\begin{array}{rcl}E\{e^{2}[n]\}&=&E\{(x[n]-s[n])^{2}\}\\&=&E\{x^{2}[n]\}+E\{s^{2}[n]\}-2E\{x[n]s[n]\}\\&=&E\{{\big (}\sum _{i=0}^{N}a_{i}w[n-i]{\big )}^{2}\}+E\{s^{2}[n]\}-2E\{\sum _{i=0}^{N}a_{i}w[n-i]s[n]\}.\end{array}}}
矢量
[
a
0
,
…
,
a
N
]
{\displaystyle [a_{0},\,\ldots ,\,a_{N}]}
减少上面的表达式,计算其关于
a
i
{\displaystyle a_{i}}
的导数
∂
∂
a
i
E
{
e
2
[
n
]
}
=
2
E
{
(
∑
j
=
0
N
a
j
w
[
n
−
j
]
)
w
[
n
−
i
]
}
−
2
E
{
s
[
n
]
w
[
n
−
i
]
}
i
=
0
,
…
,
N
=
2
∑
j
=
0
N
E
{
w
[
n
−
j
]
w
[
n
−
i
]
}
a
j
−
2
E
{
w
[
n
−
i
]
s
[
n
]
}
.
{\displaystyle {\begin{array}{rcl}{\frac {\partial }{\partial a_{i}}}E\{e^{2}[n]\}&=&2E\{{\big (}\sum _{j=0}^{N}a_{j}w[n-j]{\big )}w[n-i]\}-2E\{s[n]w[n-i]\}\quad i=0,\,\ldots ,\,N\\&=&2\sum _{j=0}^{N}E\{w[n-j]w[n-i]\}a_{j}-2E\{w[n-i]s[n]\}.\end{array}}}
假设,
w
[
n
]
{\displaystyle w[n]}
和
s
[
n
]
{\displaystyle s[n]}
均为平稳和联合平稳,记序列
R
w
[
m
]
{\displaystyle R_{w}[m]}
和
R
w
s
[
m
]
{\displaystyle R_{ws}[m]}
为
w
[
n
]
{\displaystyle w[n]}
的自相关和
w
[
n
]
{\displaystyle w[n]}
和
s
[
n
]
{\displaystyle s[n]}
之间的互相关,定义如下:
R
w
[
m
]
=
E
{
w
[
n
]
w
[
n
+
m
]
}
R
w
s
[
m
]
=
E
{
w
[
n
]
s
[
n
+
m
]
}
.
{\displaystyle {\begin{aligned}R_{w}[m]=&E\{w[n]w[n+m]\}\\R_{ws}[m]=&E\{w[n]s[n+m]\}.\end{aligned}}}
因此,注意到
R
w
s
[
−
i
]
=
R
s
w
[
i
]
{\displaystyle R_{ws}[-i]\,=\,R_{sw}[i]}
,导数的MSE可以改写为
∂
∂
a
i
E
{
e
2
[
n
]
}
=
2
∑
j
=
0
N
R
w
[
j
−
i
]
a
j
−
2
R
s
w
[
i
]
i
=
0
,
…
,
N
{\displaystyle {\frac {\partial }{\partial a_{i}}}E\{e^{2}[n]\}=2\sum _{j=0}^{N}R_{w}[j-i]a_{j}-2R_{sw}[i]\quad i=0,\,\ldots ,\,N}
.
令该导数等于零,得到
∑
j
=
0
N
R
w
[
j
−
i
]
a
j
=
R
s
w
[
i
]
i
=
0
,
…
,
N
{\displaystyle \sum _{j=0}^{N}R_{w}[j-i]a_{j}=R_{sw}[i]\quad i=0,\,\ldots ,\,N}
,
上式可以改写为矩阵形式
T
a
=
v
⇒
[
R
w
[
0
]
R
w
[
1
]
⋯
R
w
[
N
]
R
w
[
1
]
R
w
[
0
]
⋯
R
w
[
N
−
1
]
⋮
⋮
⋱
⋮
R
w
[
N
]
R
w
[
N
−
1
]
⋯
R
w
[
0
]
]
[
a
0
a
1
⋮
a
N
]
=
[
R
w
s
[
0
]
R
w
s
[
1
]
⋮
R
w
s
[
N
]
]
{\displaystyle {\begin{aligned}&\mathbf {T} \mathbf {a} =\mathbf {v} \\\Rightarrow &{\begin{bmatrix}R_{w}[0]&R_{w}[1]&\cdots &R_{w}[N]\\R_{w}[1]&R_{w}[0]&\cdots &R_{w}[N-1]\\\vdots &\vdots &\ddots &\vdots \\R_{w}[N]&R_{w}[N-1]&\cdots &R_{w}[0]\end{bmatrix}}{\begin{bmatrix}a_{0}\\a_{1}\\\vdots \\a_{N}\end{bmatrix}}={\begin{bmatrix}R_{ws}[0]\\R_{ws}[1]\\\vdots \\R_{ws}[N]\end{bmatrix}}\end{aligned}}}
这些方程被称作Wiener-Hopf方程。出现在方程中的矩阵T是一个对称的Toeplitz矩阵。当
R
{\displaystyle R}
在适当条件下,这些矩阵是正定的,也就是非奇异的,从而使得有唯一解来确定维纳滤波器系数矢量,
a
=
T
−
1
v
{\displaystyle \mathbf {a} \,=\,\mathbf {T} ^{-1}\mathbf {v} }
。此外,Wiener-Hopf方程存在一个求解的有效算法,称为Levinson-Durbin 算法,因此并不需要对矩阵
T
{\displaystyle \mathbf {T} }
的显式求逆。
维纳滤波器的设计优势在于:它能以最小化均方误差(MSE)为目标,达成线性估计的最优效果,这使其在理想统计条件下(讯号与杂讯的功率谱已知)能充分发挥精准去噪与讯号恢复性能;此外,在某些案例中,滤波器系数可以求得封闭形式解,因此能利用简单的物理元件(RC、LC网络)加以实现。因其理论明确、可计算性高,维纳滤波常成为后续 LMS、RLS 及卡尔曼滤波自适应方法的基础。
然而,其实务上的限制也不容忽视:首先,在真实环境中精确获得信号和噪声的功率频谱或自相关函数十分困难,尤其在非平稳或时变噪声条件下更难以估计到位;其次,维纳滤波为线性方法,这意味其无法处理非线性现象(如讯号高次谐波、混叠),可能导致滤波后结果出现模糊、振铃(ringing)等失真现象;第三,设计 FIR 或 IIR 滤波器时需要进行矩阵反演或频谱因式分解,对计算能力要求较高,尤其在高维或大规模案例中亦不易即时实现。
此外,在应用中也遇到频率分布重叠与生态噪声模式的挑战,维纳滤波解对小幅频谱估计误差通常十分敏感,实务效能可能因此明显下降。而且在一些影像去模糊案例中,若参数估计不精准,更可能导致“过度钝化”(over-smoothing)或不必要的边缘损失。
综上所述,尽管维纳滤波在统计理论上具备无可匹敌的最佳特性,但其使用条件限制(已知统计特性、线性假设、计算开销)与对估计误差敏感性,使其在较复杂或动态环境中常被替代或与其他自适应、非线性技术(如 LMS、卡尔曼或小波滤波)结合使用,以求更稳健且实用的处理效果。
^ [1]: Wiener, Norbert (1949), Extrapolation, Interpolation, and Smoothing of Stationary Time Series . New York: Wiley. ISBN 0-262-73005-7
^ [2]: Brown, Robert Grover and Patrick Y.C. Hwang (1996) Introduction to Random Signals and Applied Kalman Filtering . 3 ed. New York: John Wiley & Sons. ISBN 0-471-12839-2
^ [3]: Neil Gershenfeld, The Nature of Mathematical Modeling, Cambridge University Press, 1999