ANC主动降噪理论及Matlab代码实现

根据系统是否有参考信号传感器可将ANC系统大致的分为前馈型和反馈型。

前馈控制是产生次级噪声之前就通过传感器测量初级噪声的频率以获取参考信号。

反馈控制不需要测得参考信号就产生次级噪声进行相消干涉

反馈型ANC系统 

反馈型 ANC 系统中没有传感器来测得参考输入信号,仅通过误差传感器获取经相消干涉后的残余噪声并将其送入到反馈控制器,进而达到调节次级声源$y_n$的目的,使其发出与初级噪声幅值相等相位相反的次级噪声

  反馈型ANC系统避免了对初级噪声的提取,也就不存在FM问题,反馈系统因具有一定的主动阻尼而可以有效抑制系统的暂态信号。但是反馈型系统鲁棒性较差,且对宽带噪声的处理能力较差,一般适用于无法安装参考信号传感器的场景。

前馈型ANC系统

  前馈型ANC系统相较于反馈型增加了一个获取参考信号的传感器。误差传感器测得的残余噪声信号连同传感器获取的参考信号均作为控制器的输入。参考信号可由声学传感器获取,也可由非声学传感器(如转速计、加速度计等)获得。但声学传感器的引入容易造成声反馈现象,从而削弱系统的鲁棒性。故而窄带 ANC 系统中的参考信号一般由非声学传感器采集。通过非声学传感器可采集到噪声源信号的同步信号(如转速、加速度等),按照一定的线性关系可将其转换为频率值,根据该频率值可使信号发生器产生与窄带噪声频率一致的参考信号。前馈型 ANC 系统的物理模型如图 2.2 所示。

  其中,控制器以参考信号和残余噪声为输入,产生并调节次级声源信号$y_n$ ,驱动次级扬声器发出次级噪声,与初级声源产生的噪声进行相消干涉,最终使得误差传感器处的声压值最小。前馈型 ANC 系统具有很强的鲁棒性,且不仅适用于窄带噪声信号,也可用于处理宽带噪声信号。

传统ANC算法

  噪声信号随时间的推移而不断变化,其特性无法进行预先估计,这一性质导致噪声很难被实时跟踪。ANC 技术要求对时变的噪声输入信号进行跟踪,从而调节控制器使产生的次级噪声信号能最大的削弱噪声输入信号自适应数字信号处理可以很好的跟踪时变信号,通过某种优化误差准则不断调整产生所需信号。而这种优化误差准则实际上就属于 ANC 算法。

FXLMS算法

ANC系统传统算法结构

  其中$W_n(z)$为自适应滤波器,$S(z)$次级通道;$p(n)$为初级噪声;$e(n)$为系统残余噪声;x(n)为参考噪声。最小均方误差(Least Mean Square, LMS)算法以最陡下降法为奠基石,具有较为出众的迭代更新速度,应用非常广泛。但在ANC系统中,次级通道$S(z)$的存在会导致残余信号和参考信号间存在延时,进而削弱ANC系统的稳定性。

  Morgan 在 LMS 的基础上提出了 FXLMS,在参考信号$x(n)$送入 LMS 算法模块前增加一个对次级通道传递函数的估计$S(z)$,从而解决次级通道所引起的相关延时问题,如图 2.4 所示。FXLMS 算法应用在 ANC 系统中简单且有效,在 ANC 算法中可谓历久而弥新,得到了广泛推广。

FXLMS算法结构

次级通道在线辨识

  在ANC系统中,通常将数模转换(D\A)、信号方法电路、模数转换(A\D)、滤波电路、扬声器、传声器等电子设备以及扬声器到传声器之间的实际管道等物理通道的组合称之为次级通道。就实际应用而言,次级通道的传递函数显然无法明确得知,而 ANC 系统中的自适应滤波器可对次级通道进行估计。当传递函数为时变函数时,采用在线辨识算法,即在 ANC 系统运行的同时对次级通道进行估计。下图给出了含在线辨识的 FXLMS 算法结构,自适应滤波器的输出$y_n$引入线辨识系统,作为LMS 算法的输入。同时将系统中的残余噪声信号与$y_n$经次级通道的估计之后得到的$\hat{y}_p(n)$相比较,将所得到的误差也用作 LMS 算法的激励,调节参数,不断逼近次级通道传递函数,完成对次级通道的实时在线辨识。

含在线辨识的 FXLMS 算法结构

  次级通道的在线辨识应当满足两个基本要求:实现对次级通道较为精准的估计;同时在线辨识不应该对主降噪系统产生影响。而图 2.5 所示的次级通道的在线辨识对$y(n)$进行直接处理,使得这两个基本要求相互矛盾。故而实际的 ANC 系统应在在线辨识不被干扰与辨识不对主降噪系统产生干扰之间取得一个相对平衡。为在这两者间获取更为适宜的平衡点,Eriksson 提出增加辅助随机噪声作为在线辨识系统的激励,而在主降噪系统中$y(n)$减去辅助噪声之后再驱动扬声器产生声音信号进入次级通道。但辅助噪声又对残余噪声造成了影响,Lan 在研究宽带 ANC系统时提出了通过$|e(n)|$对辅助噪声进行进一步的约束。刘在Lan 的基础上针对窄带前馈 ANC系统,改为利用$|e(n-1)|$对送入系统的辅助噪声进行约束,如图2.6 所示。本文所展开的在线辨识采用的正是该方法。

  次级通道的在线辨识可对时变次级通道传递函数进行估计,但同时增加了整个 ANC 系统的负担,此外,辅助噪声的存在仍在一定程度上削弱了 ANC 系统的鲁棒性。

带自激的在线辨识FXLMS算法结构

次级通道离线辨识

  当次级通道环境不随着时间而改变时,可以使用离线辨识算法。离线辨识是运行 ANC 系统进行降噪之前针对次级通道预先进行训练估计,固定并保存作为训练结果的次级通道模型,再将该模型引入到 ANC 系统并启动系统进行降噪。次级通道的离线辨识原理图如图 2.7 所示。

次级通道离线辨识原理图

  其中,白噪声信号$v(n)$作为系统在第n 时刻的激励,此刻次级通道的输出为$d(n)$,即离线辨识系统的期望信号。$y_v(n)$则是白噪声激励信号经过次级通道的估计函数$\hat{S}_n(z)$的输出,$y_v(n)$与期望信号$d(n)$之差即为辨识误差$e_o(n)$,送入到 LMS 算法中。经过不断迭代更新后当辨识误差$e_o(n)$趋近于零时,$y_v(n)$与期望信号$d(n)$趋近于相同,则可知次级通道的估计函数$\hat{S}_n(z)$趋近于次级通道$S(z)$,实现了对次级通道的离线辨识。

  离线辨识是脱离 ANC 降噪系统,独立进行系统辨识,不会给 ANC 降噪系统增加运行负担,同样不会损害 ANC 降噪系统的鲁棒性。若 ANC 系统的次级通道传递函数时不变,则离线辨识具有一定的优势,在本文后期具体实验时会给出更为直观的说明。

FM 问题及非平稳

  在前馈型 ANC 系统中,对参考信号的提取采用非声学传感器时,若传感器长时间工作将会累积损耗最终致使精度减削,采集到的参考信号频率将与实际初级噪声的频率存在误差。又或者,当信号发生器发出的信号不够精确,与期望存在误差。这些情况最终导致参考信号频率与实际噪声频率间存在误差,即所谓的 FM。

  FM 问题对窄带前馈 ANC 具有致命性的影响力。哪怕系统中仅存在 1%的 FM 量,也将导致系统无法进行有效消噪。本文将在第三章和第六章分别从实时仿真以及实际实验两方面分析说明 FM 问题。

  另外,噪声源设备的速度变化将直接表现为初级噪声信号频率的变化,而频率不稳定的初级噪声对系统的鲁棒性及跟踪能力有着毁坏性的损伤。非平稳一直是存在于实际的 ANC 应用中不可避免的又一问题,当初级噪声表现出非平稳时,采集参考信号的传感器会有响应延时并最终引起非平稳的 FM。在本文的第三章将对非平稳的 FM 进行仿真分析。

本章小结

  本章对 ANC 技术的理论基础进行了详细介绍。首先,针对 ANC 系统分别从反馈型和前馈型两种类型对 ANC 系统类型进行概要描述。其次,详细描述了传统 ANC 算法,对 FXLMS 算法的基础 LMS 略有介绍,重点以 FXLMS 算法展开论述,继而详解了次级通道的在线辨识与离线辨识,并对在线辨识与离线辨识的应用场景进行了简要说明。最后,针对存在于前馈型 ANC系统中的 FM 及非平稳问题进行简要说明。

代码实现

x(n):参考信号

u(n):控制信号

d(n):期望信号

y(n):输出信号

r(n):x滤波后的信号

e(n):误差信号

W(z):自适应滤波器

G(z):真实的次级通道

$\hat{G}(z)$:估计的次级通道

%              +-----------+                       +
% x(k) ---+--->|   P(z)    |--yp(k)----------------> sum --+---> e(k)
%         |    +-----------+                          ^-   |
%         |                                           |    |
%         |        \                                ys(k)  |
%         |    +-----------+          +-----------+   |    |
%         +--->|   C(z)    |--yw(k)-->|   S(z)    |---+    |
%         |    +-----------+          +-----------+        |
%         |            \                                   |
%         |             \----------------\                 |
%         |                               \                |
%         |    +-----------+          +-----------+        |
%         +--->|   Sh(z)   |--xs(k)-->|    LMS    |<-------+
%              +-----------+          +-----------+        

% LMS最小均方误差
% S(z)次级通道传递函数      % ys(k)次级声源
% P(z)主通道传递函数        % yp(k)初级声源
% C(z)控制器               % yw(k)控制器
% Sh(z)传感器函数          % xs(k)传感器参考信号

clear
T=1000; % 仿真持续时间

% 我们不知道p(z)和S(z),所以我们必须建立dummy虚拟路径
Pw=[0.01 0.25 0.5 1 0.5 0.25 0.01];
Sw=Pw*0.25;

x_iden=randn(1,T); % 产生shape=(1,1000)的白噪声信号估计S(z)

% 送至actuator执行,在传感器位置测量,
y_iden=filter(Sw, 1, x_iden);

% 然后,开始识别过程
Shx=zeros(1,16);       % 传感器Sh(z)的状态
Shw=zeros(1,16);       % 传感器Sh(z)的权重
e_iden=zeros(1,  T);   % 识别错误的数据缓冲区

%LMS 算法
% [Shy,Shw]=lms(Shx,y_iden,x_iden,Shw,e_iden,T);
mu=0.1;                         % 学习率
for k=1:T                      % 离散时间 k
    Shx=[x_iden(k) Shx(1:15)];  % 更新传感器的状态
    Shy=sum(Shx.*Shw);            % 计算传感器Sh(z)的输出
    e_iden(k)=y_iden(k)-Shy;    % 计算误差
    Shw=Shw+mu*e_iden(k)*Shx;   % 调整权重
end

% 检查结果
subplot(2,1,1)
plot((1:T), e_iden)
ylabel('Amplitude');
xlabel('Discrete time k');
legend('Identification error');
subplot(2,1,2)
stem(Sw)
hold on
stem(Shw, 'r*')
ylabel('Amplitude');
xlabel('Numbering of filter tap');
legend('S(z)系数', 'Sh(z)系数')

% 第second task二个任务是主动控制
X=randn(1,T);

% 测量传感器位置接收的噪声,
Yd=filter(Pw, 1, X);

% 启动系统
Cx=zeros(1,16);       % C(z)的状态
Cw=zeros(1,16);       % C(z)的权重
Sx=zeros(size(Sw));   % secondary次路径的虚拟状态
e_cont=zeros(1,T);    % 控制错误的数据缓冲区
Xhx=zeros(1,16);      % 过滤后x(k)的状态

% FxLMS 算法
% [Cy,Cw]=FxLMS(X,Cx,Cw,Sx,Sw,Shx,Shw,e_cont,Xhx,T,Yd);
mu=0.1;                            % 学习率
for k=1:T                          % 离散时间 k
    Cx=[X(k) Cx(1:15)];            % 更新控制器状态
    Cy=sum(Cx.*Cw);                % 计算控制器输出
    Sx=[Cy Sx(1:length(Sx)-1)];    % 传播到secondary path
    e_cont(k)=Yd(k)-sum(Sx.*Sw);   % 测量残差
    Shx=[X(k) Shx(1:15)];          % 更新Sh(z)的状态
    Xhx=[sum(Shx.*Shw) Xhx(1:15)]; % 计算过滤后的x(k)
    Cw=Cw+mu*e_cont(k)*Xhx;        % 调整controller的权重
end

% 结果
figure
subplot(2,1,1)
plot((1:T), e_cont)
ylabel('Amplitude');
xlabel('Discrete time k');
legend('Noise residue')
subplot(2,1,2)
plot((1:T), Yd)
hold on
plot((1:T), Yd-e_cont, 'r:')
ylabel('Amplitude');
xlabel('Discrete time k');
legend('噪声信号', '控制信号')

参考文献

窄带主动噪声控制系统实时仿真及硬件实现_毛梦菲

(0)

相关推荐

  • 学术简报|基于单通道盲源分离算法的局部放电特高频信号去噪方法

    摘要 国网安徽省电力有限公司电力科学研究院的研究人员刘宇舜.程登峰等,在2018年第23期<电工技术学报>上撰文,为有效抑制现场检测局部放电特高频信号背景噪声中的周期性窄带干扰和高斯白噪声 ...

  • 这样选用麦克风,耳机降噪效果会更好

    降噪耳机已经越来越普及,降噪耳机要想实现好的降噪效果面临很多挑战,其中如何正确选用麦克风又是一项具有重要影响的基础工作.本文目的旨在帮助读者正确选用麦克风以实现更好的耳机降噪性能,当然也可以帮助您更好 ...

  • 【译】图解卡尔曼滤波(Kalman Filter)

    译者注:这恐怕是全网有关卡尔曼滤波最简单易懂的解释,如果你认真的读完本文,你将对卡尔曼滤波有一个更加清晰的认识,并且可以手推卡尔曼滤波.原文作者使用了漂亮的图片和颜色来阐明它的原理(读起来并不会因公式 ...

  • MATLAB中基于CEEMDAN与FastICA算法的单通道信号规律噪声的滤除方法

    本文章思想主要来源于下面的一篇文献,将其用matlab实现. [1]罗志增,严志华,傅炜东.基于CEEMDAN-ICA的单通道脑电信号眼电伪迹滤除方法[J].传感技术学报,2018,31(08):12 ...

  • 不用塞入耳朵的“外放”式主动降噪设备

    majer @ 2020.12.30 , 01:03 主动降噪/控制(ANC)耳机,耳塞中的衬垫和外套可制造出无源声音衰减.这就是ANC降噪的机制,但长时间佩戴可能会感到不舒服,甚至造成伤害. 悉尼科 ...

  • 【学术论文】窄带噪声主动控制系统的FPGA实现

    摘要: 基于FPGA的窄带噪声主动控制系统,采用并行计算能力强的FPGA作为核心处理器,能够应对多频率.多通道情况下计算量成倍增加的情况:系统实现了并联结构的窄带前馈FxLMS算法,可以针对噪声中的不 ...

  • 汽车ANC主动降噪技术

    一.汽车噪声基础 现在大家对舒适性需求越来越高,一些高端车型为了提升豪华舒适感,往往会配备ANC主动降噪技术. 汽车噪声有很多种,动力传动噪声,路噪和风噪,人类的听力范围通常是20到20000Hz,而 ...

  • [科普]汽车ANC主动降噪技术

    小星被问起现在汽车音响功能越来越多,不但可以配置各种音效,还有ANC主动降噪技术.那么什么是主动降噪呢?让小星来给大家科普一下吧. 什么是主动降噪 传统的噪音控制方法被称为被动降噪,它主要由控制噪声源 ...

  • 基于扰动跟踪法的变压器有源降噪系统研究

    武汉大学电气工程学院.国网湖北省电力公司技术培训中心的研究人员王晋伟.应黎明.刘勤.杨鹏,在2018年第1期<电工技术学报>上撰文指出,变压器噪声是变电站中主要噪声来源,开展变压器有源噪声 ...

  • ANC主动降噪硅麦那些事

    如果要问当前TWS耳机什么方案最火,那一定是ANC主动降噪和ENC双麦通话降噪,许多新案子都在加入此功能,各大品牌跃跃欲试,抢占先机. 犹记得3年前,我和客户讨论ENC双麦通话降噪的可行性及市场,普遍 ...

  • 汽车ANC主动降噪开发技术!

    "最近现代汽车发布了路噪主动降噪技术,至于他们的技术是不是第一,我们肯定不得而知也不能全信一面之词,但是现代的技术解释,非常直接易懂,值得学习". 主动降噪实现的声学基础是声波的相 ...

  • Dyplay ANC Sport 主动降噪蓝牙耳机体验测评报告

    趣听官方QQ群:369372120 在群内可获得耳机推荐,进行心得交流,还有最新动态. ··················· 样机来源:厂商送测 样机类型:市售量产版 Dyplay是一个创立没多久的 ...

  • 【评测图集】Dyplay ANC Sport 主动降噪蓝牙耳机图集

    趣听官方QQ群:369372120 在群内可获得耳机推荐,进行心得交流,还有最新动态. ··················· 样机来源:厂商送测 样机类型:市售量产版 Dyplay是一个创立没多久的 ...

  • 还在花钱做隔音?主动降噪ANC了解一下?是不是智商税?

    汽车行驶中会产生各种各样的噪音,其中包括来自底盘的沙石打击音.轮胎滚动噪音.发动机振动导致的声音.变速箱以及传动系统高速旋转的振荡噪音.排气系统的"爆破音".还有风噪--等等等等 ...

  • vivo双箭齐发:TWS 2无线耳机发布,主动降噪+HIFI品质

    本月vivo又有两个大招杀到,第一是首款LCD屏旗舰iQOO Neo5活力版确认,该机是今年首款配置顶级的LCD屏手机,在一众"瞎眼屏"手机的衬托下,其必将成为一股清流,爆款机型可 ...

  • 拆解报告:Cleer TREK主动降噪入耳式有线耳机

    -----我爱音频网拆解报告第584篇----- TWS耳机的火爆带动了蓝牙耳机的快速发展,随着技术的进步,众多新功能的加入,无线蓝牙耳机越来越受到用户的认同.而有线耳机相较于无线耳机有着同等配置下音 ...

  • TWS耳机纷纷支持主动降噪,相关芯片厂商或将受益

    真无线蓝牙耳机(TWS)市场规模不断成长,各大品牌厂如苹果.三星及OPPO等也规划在2021年再度端出新品应战,加速2021年TWS朝向主动式降噪(ANC)功能发展.法人预期,瑞昱.原相等TWS芯片供 ...

  • 拆解报告:声智TA来了真无线主动降噪智能耳机

    -----我爱音频网拆解报告第566篇----- 随着TWS真无线耳机在技术上越来越成熟,很多品牌正在尝试把TWS耳机当作新的人机交互入口,像是TWS翻译耳机.TWS智能耳机等产品越来越多. 近期,知 ...