FxLMS算法

FxLMS算法

版权声明:本文为博主原创文章,转载请附上博文链接!

1 前言

在前一篇中我们简要介绍了有源噪声控制的系统构成和基本应用,现在来详细介绍有源噪声控制中最常用的算法,FxLMS算法。如前文所说,有源噪声控制与传统的自适应信号处理最根本的区别就是多了次级通路。这里的Fx即filtered-x信号,为参考信号经过次级通路滤波得到的。
FxLMS算法为有源噪声控制的基准算法,实现简单且运算量小,它源于Widrow所提出的LMS算法。1980年,在通用电气公司工作的Morgan D. R首先推导了这一算法。1981年,在贝尔实验室工作的Burgess在研究管道噪声控制时提出了这一算法,并命名为FxLMS算法。

2 单通道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(n1),...,x(nL+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滤波器,实现简单,因此在有源噪声控制中被广泛采用。在很多情况下,利用单通道系统并不能在较大的范围内形成静区,因此需要采用多通道有源噪声控制系统,这就需要采用多通道算法。多通道算法在原理上是相同的,只是运算量大幅度增加。

3 多通道FxLMS算法

设系统中有 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(n1),...xi(nL+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=1Ixi(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=1Jyj(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=1KE[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=1Kek(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

4 FxLMS算法编程

为了进一步理解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文件,可以直接运行。初级噪声为宽带与窄带复合噪声。运行结果为
在这里插入图片描述
蓝色为降噪前,红色为降噪后。

  • 15
    点赞
  • 155
    收藏
    觉得还不错? 一键收藏
  • 42
    评论
评论 42
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值