版权声明:本文为博主原创文章,转载请附上博文链接!
在前一篇中我们简要介绍了有源噪声控制的系统构成和基本应用,现在来详细介绍有源噪声控制中最常用的算法,FxLMS算法。如前文所说,有源噪声控制与传统的自适应信号处理最根本的区别就是多了次级通路。这里的Fx即filtered-x信号,为参考信号经过次级通路滤波得到的。
FxLMS算法为有源噪声控制的基准算法,实现简单且运算量小,它源于Widrow所提出的LMS算法。1980年,在通用电气公司工作的Morgan D. R首先推导了这一算法。1981年,在贝尔实验室工作的Burgess在研究管道噪声控制时提出了这一算法,并命名为FxLMS算法。
如图中所示的有源噪声控制模型。
控制滤波器长度为 L L L,次级通路长度为 M M M。参考信号为 x ( n ) x(n) x(n),在误差传感器处,期望信号为 d ( n ) d(n) d(n),抵消信号 s ( n ) = y ( n ) ∗ h ( n ) s(n)=y(n)*h(n) s(n)=y(n)∗h(n),它是滤波器输出 y ( n ) y(n) y(n)经过次级通路后得到的响应。
设第 n n n时刻滤波器权系数和参考输入分别为
w ( n ) = [ w 1 ( n ) , w 2 ( n ) , . . . , w L ( n ) ] T \bm{w}(n)=[w_1(n),w_2(n),...,w_L(n)]^T w(n)=[w1(n),w2(n),...,wL(n)]T x ( n ) = [ x ( n ) , x ( n − 1 ) , . . . , x ( n − L + 1 ) ] T \bm{x}(n)=[x(n),x(n-1),...,x(n-L+1)]^T x(n)=[x(n),x(n−1),...,x(n−L+1)]T
则滤波器的输出为 y ( n ) = x T ( n ) w ( n ) y(n)=\bm{x}^T(n)\bm{w}(n) y(n)=xT(n)w(n)如果认为在 L L L个采样点内滤波器权系数基本保持不变,那么 s ( n ) = v T ( n ) w ( n ) s(n)=\bm{v}^T(n)\bm{w}(n) s(n)=vT(n)w(n)式中 v ( n ) \bm{v}(n) v(n)即为滤波-x信号。有 v ( n ) = x ( n ) ∗ h ( n ) \bm{v}(n)=x(n)*h(n) v(n)=x(n)∗h(n)误差传声器接收到的信号为 e ( n ) = d ( n ) + s ( n ) e(n)=d(n)+s(n) e(n)=d(n)+s(n)
根据最小均方误差准则,有源控制系统的目标函数为 J ( n ) = E [ e 2 ( n ) ] J(n)=E[e^2(n)] J(n)=E[e2(n)]根据最速下降法原理,有 w ( n + 1 ) = w ( n ) − 2 μ e ( n ) v ( n ) \bm{w}(n+1)=\bm{w}(n)-2\mu e(n)\bm{v}(n) w(n+1)=w(n)−2μe(n)v(n)以上即为单通道前馈FxLMS算法的原理,可以看到控制器采用横向FIR滤波器,实现简单,因此在有源噪声控制中被广泛采用。在很多情况下,利用单通道系统并不能在较大的范围内形成静区,因此需要采用多通道有源噪声控制系统,这就需要采用多通道算法。多通道算法在原理上是相同的,只是运算量大幅度增加。
设系统中有 I I I个参考信号, J J J个次级声源, K K K个误差传感器。单个横向滤波器长度为 L L L,次级通路长度为 M M M。为了表述清晰,我们采用和单通道算法同样的思路。自适应滤波器共有 I J IJ IJ个,单个滤波器权系数为 w i j ( n ) = [ w i j ( 1 ) , w i j ( 2 ) , . . . w i j ( n ) ] T \bm{w}_{ij}(n)=[w{ij}(1),w{ij}(2),...w{ij}(n)]^T wij(n)=[wij(1),wij(2),...wij(n)]T第 i i i个参考信号为 x i ( n ) = [ x i ( n ) , x i ( n − 1 ) , . . . x i ( n − L + 1 ) ] T \bm{x}_i(n)=[x_i(n),x_i(n-1),...x_i(n-L+1)]^T xi(n)=[xi(n),xi(n−1),...xi(n−L+1)]T
则第 j j j个次级声源的输出为 y j ( n ) = ∑ i = 1 I x i ( n ) w i j ( n ) y_j(n)=\sum_{i=1}^I\bm{x}_i(n)\bm{w}_{ij}(n) yj(n)=i=1∑Ixi(n)wij(n)第 k k k个误差传感器处的抵消信号为 s k ( n ) = ∑ j = 1 J y j ( n ) ∗ h j k s_k(n)=\sum_{j=1}^Jy_j(n)*h_{jk} sk(n)=j=1∑Jyj(n)∗hjk则误差信号为 e k ( n ) = d k ( n ) + s k ( n ) e_k(n)=d_k(n)+s_k(n) ek(n)=dk(n)+sk(n)根据最小均方误差准则,多通道控制系统的目标函数为 J ( n ) = ∑ k = 1 K E [ e k 2 ( n ) ] J(n)=\sum_{k=1}^KE[e_k^2(n)] J(n)=k=1∑KE[ek2(n)]根据最速下降法原理,有 w i j ( n + 1 ) = w i j ( n ) − 2 μ ∑ k = 1 K e k ( n ) v i j k ( n ) \bm{w}_{ij}(n+1)=\bm{w}_{ij}(n)-2\mu\sum_{k=1}^Ke_k(n)\bm{v}_{ijk}(n) wij(n+1)=wij(n)−2μk=1∑Kek(n)vijk(n)式中 v i j k ( n ) \bm{v}_{ijk}(n) vijk(n)为第 i i i个参考信号经过第 j j j个次级声源到第 k k k个误差传感器之间的次级通路后产生的滤波-x信号,即 v i j k ( n ) = x i ( n ) ∗ h j k ( n ) \bm{v}_{ijk}(n)=x_i(n)*h_{jk}(n) vijk(n)=xi(n)∗hjk(n)
算法运算量如表中所示
算法运算步骤 | 乘加次数 |
---|---|
计算滤波器输出 | I J L IJL IJL |
计算滤波-x信号 | I J K M IJKM IJKM |
权系数迭代 | I J K L IJKL IJKL |
为了进一步理解FxLMS法,作者在这里进行了Matlab编程,如果您有兴趣,请参考有源噪声控制FxLMS算法。程序为Matlab函数文件,不可以直接运行,需要您自行输入参数。下面为具体说明。
X(1:L)'*W //计算滤波器输出
X(1:M)'*Hs_m //计算滤波-x信号
//滤波权系数迭代
for j=1:J
W(:,j)=W(:,j)-u(j)*F(:,(j-1)*K+1:j*K)*e(:,n);
end
另外请参考宽带与窄带信号有源噪声控制,为Matlab中.m文件,可以直接运行。初级噪声为宽带与窄带复合噪声。运行结果为
蓝色为降噪前,红色为降噪后。