《基于rls算法的多麦克风降噪课程设计正文--大学论文.doc》由会员分享,可在线阅读,更多相关《基于rls算法的多麦克风降噪课程设计正文--大学论文.doc(32页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、课 程 设 计题 目基于RLS 算法的多麦克风降噪学 院专 业班 级姓 名指导教师信息处理课群综合训练与设计任务书题 目: 基于RLS 算法的多麦克风降噪 初始条件:Matlab软件、信号与系统、通信处理等要求完成的主要任务: (包括课程设计工作量及其技术要求,以及说明书撰写等具体要求)设计任务:给定主麦克风录制的受噪声污染的语音信号和参考麦克风录制的噪声,实现语音增强的目标,得到清晰的语音信号。设计的要求:(1)阅读参考资料和文献,明晰算法的计算过程,理解RLS算法基本过程;(2)主麦克风录制的语音信号是RLSprimsp.wav,参考麦克风录制的参考噪声是RLSrefns.wav,用mat
2、lab指令读取;(3)根据算法编写相应的MATLAB程序;(4)算法仿真收敛以后,得到增强的语音信号;(5)用matlab指令回放增强后的语音信号;(6)分别对增强前后的语音信号作频谱分析。参考书:1 刘泉,信号与系统, 高等教育出版社, 2006年。2 刘泉,数字信号处理,电子工业出版社,2008年。3 Edward W. Kamen, Bonnie S.Heck 编,信号与系统基础应用Web 和MATLAB(第二版),科学出版社,2002 年。时间安排:1、理论讲解,老师布置课程设计题目,学生根据选题开始查找资料;2、课程设计时间为2周。(1)理解相关技术原理,确定技术方案, 时间2天;(
3、2)选择仿真工具,进行仿真设计与分析,时间6天;(3)总结结果,完成课程设计报告,时间2天。指导教师签名: 年 月 日系主任(或责任教师)签名: 年 月 日目 录摘要IAbstractII1 绪论11.1绪论11.2任务与要求22 信号处理基本原理32.1自适应滤波器组成32.2自适应干扰抵消原理32.3自适应滤波原理42.4 RLS算法基本原理53 方案设计73.1最小二乘算法RLS算法实现73.2 RLS算法程序程序设计94 RLS算法滤波方案实现114.1信号的获取114.2读取语音文件114.3RLS算法实现114.4提取语音信号125仿真结果与分析15 5.1原始音频信号155.2麦
4、克风主语音信号165.3噪声语音信号175.4降噪后语音信号185.5信号处理分析195.5.1原始语音信号与主语音信号分析195.5.2主语音信号与降噪后语音信号分析205.5.3原始语音信号与降噪后语音信号分析216总结22参考文献23附录 源程序24武汉理工大学信息处理课群综合训练与设计报告摘要本次课程设计题目为基于RLS 算法的多麦克风降噪,要求使用MATLAB软件,运用自适应滤波中的RLS算法实现麦克风降噪。MATLAB即矩阵实验室,是一个可视化的计算程序,被广泛的运用在科学计算领域,包括数值计算、数据拟合图形图像处理、系统模拟仿真功能。除具备卓越的数值计算能力用外,它还提供了专业水
5、平的符号计算,文字处理,可视化建模仿真和实时控制等功能。在了解RLS算法的原理后,选择了一段音频文件,并利用它产生随机噪声,将噪声和源文件叠加作为受噪声污染的语音信号,而随机噪声则作为参考麦克风语音信号,通过MATLAB编程实现语音增强的目标,利用RLS算法对语音信号进行降噪,得到清晰的语音信号。关键词:MATLAB,自适应滤波,RLS算法,麦克风降噪AbstractThe curriculum design topic for noise reduction based on RLS algorithm microphone, requires the use of MATLAB softw
6、are, the RLS adaptive kalman filtering algorithm microphone noise reduction.MATLAB matrix lab, is a visual calculation program, has been widely used in the field of scientific computing, including numerical calculation, data fitting of image processing, system simulation function. Besides excellent
7、ability in numerical calculation with, it also provides a professional level of symbolic computation, word processing, visual modeling simulation and real-time control, and other functions.After knowing the principle of RLS algorithm, chose an audio file, and use it to produce random noise, the nois
8、e and the superposition of the source file as speech signal polluted by noise, and random noise is used as a reference microphone voice signal, through the MATLAB programming to realize the goal of speech enhancement, RLS algorithm is used to analyse the speech signal de-noising, get clear speech si
9、gnal.Keywords: MATLAB, adaptive filter, RLS algorithm, microphone noise reduction261 绪论1.1绪论自适应噪声滤波是指从信号被噪声干扰所淹没的环境中检测和提取有用信号,而自适应抵消是以噪声干扰为处理对象,将它们抑制掉或进行非常大的衰减,以提高信号传递和接收的信噪比质量。自适应滤波处理技术可以用来检测平稳的和非平稳的随机信号。自适应数字系统具有很强的自学习、自跟踪能力和算法的简单易实现性,它在噪声信号的检测增强,噪声干扰的抵消,波形编码的线性预测,雷达声纳系统的阵列处理和波束形成,通信系统的自适应分割,以及未知系
10、统的自适应参数辨识等方面获得了广泛的应用。例如,在工业生产过程中,由于生产环境的影响,许多静电或电磁场会对控制器输入给定信号造成干扰,产生信号噪声,导致操作精度下降甚至输入错误信号,加快执行机构的磨损,严重时造成生产事故,后果不堪设想,这就需要设计一个自适应信号处理系统来过滤噪声干扰。再如水下侦察系统中发射器与接收器靠得很近,但为了探测水下远程潜艇等目标,发射信号的功率很强,就会串扰到接收器中,因此所接收的远程目标的反射波就淹没在串扰信号中,大大妨碍了对目标定位距离的测量,这时也必须采用干扰抵消措施。所以,自适应噪声干扰抵消技术有着重要的应用。通过本次课程设计,我们可以加强对信号处理的理解,学
11、会查寻资料方案比较,以及设计算法等。灵活运用所学信号与系统、数字信号处理等信息处理知识,分析和解决工程技术问题,将理论知识与应用实际结合起来。本次课程设计的题目为基于RLS的多麦克风语音降噪,主要是对给定主麦克风录制的受噪声污染的语音信号和参考麦克风录制的噪声,实现语音增强的目标,得到清晰的语音信号。 1.2任务与要求给定主麦克风录制的受噪声污染的语音信号和参考麦克风录制的噪声,实现语音增强的目标,得到清晰的语音信号。要求:(1)阅读参考资料和文献,明晰算法的计算过程,理解RLS算法基本过程;(2)主麦克风录制的语音信号是RLSprimsp.wav,参考麦克风录制的参考噪声是RLSrefns.
12、wav,用matlab指令读取;(3)根据算法编写相应的MATLAB程序;(4)算法仿真收敛以后,得到增强的语音信号;(5)用matlab指令回放增强后的语音信号;(6)分别对增强前后的语音信号作频谱分析。2 信号处理基本原理2.1自适应滤波器组成自适应滤波器通常由两部分组成,其一是滤波子系统,根据它所要处理的功能而往往有不同的结构形式。另一是自适应算法部分,用来调整滤波子系统结构的参数,或滤波系数。在自适应调整滤波系数的过程中,有不同的准则和算法。算法是指调节自适应滤波系数的步骤,以达到在所描述准则下的误差最小化。自适应滤波器含有两个过程,即自适应过程与滤波过程。前一过程的基本目标是调节滤波
13、系数(k),使有意义的目标函数或代价函数F()最小化,滤波器输出信号y(n)逐步逼近所期望的参考信号d(n),由两者之间的估计误差e(n)驱动某种算法对滤波(权)系数进行调整,使滤波器处于最佳工作状态以实现滤波过程。但是,由于目标函数F()是输入信号x(k)、参考信号d(k)及输出信号y(k)的函数,即F()=Fx(k),d(k),y(k),因此目标函数必须具有以下两个性质:(1)非负性(2)最佳性2.2自适应干扰抵消原理图2-1自适应干扰抵消原理图自适应滤波器在实际应用中,由于没有充足的信息来设计固定系数的数字滤波器,或者设计规则会在滤波器正常运行时改变,因此我们需要研究自适应滤波器。凡是需
14、要处理未知统计环境下运算结果所产生的信号或需要处理非平稳信号时,自适应滤波器可以提供一种吸引人的解决方法,而且其性能通常远优于用常方法设计的固定滤波器。此外,自适应滤波器还能提供非自适应方法所不可能提供的新的信号处理能力。自适应噪声抵消技术是自适应信号处理的一个应用分支,其主要理论和框架在1975年提出,经过三十多年的丰富和扩充,现在已经应用到了很多领域,比如车载免提通话设备,房间或无线通讯中的回声抵消在母体上检测胎儿心音,机载电子干扰机收发隔离等,都是用自适应干扰抵消的办法消除混入接收信号中的其他声音信号。如图所示的是自适应干扰抵消器的基本结构,它有着很广泛的应用。期望响应是信号和噪声之和,
15、即,自适应处理器的输入是与相关的另一个噪声。当与不相关时,自适应处理器将调整自己的参数,以力图使成为的最佳估计。这样,将逼近信号,且其均方值为最小。噪声就得到了一定程度的抵消。2.3自适应滤波原理 图2-2 自适应滤波原理图自适应滤波器由递归计算最小二乘估计(RLS)应用自适应权值控制机制来进行(图3-2)。自适应滤波机制在估计滤波器的权重或者系数时,需要将输入信号转换成所需的信号,通过滤波器的信号输入端口进行连接。该输入信号可以是基于采样的标量或一个单位信道的基于帧的信号。将所需端口的信号必须具有相同的数据类型、帧状态、复杂性,才能作为所需的信号作为输入信号,输出端口输出滤波后的输入信号,它
16、可以是基于样品或帧输入信号。使用递归最小二乘(RLS)算法,从输入信号中减去噪声得到输出信号。RLS自适应线性自适应滤波器使用的输入端口上的参考信号与输出的期望信号端口自动匹配,滤波过程在噪声滤波器内进行去噪。由于通过滤滤器的输入信号进行收敛,过滤的噪声应完全从“信号加噪声”的信号中减去,继而使得输出信号应该只包含原始信号。这样完成一次去噪滤波,可以减少噪声对信道的影响,更有利于进行信道估计。通过上面的分析讨论,将带有噪声的原始信号输入到系统中,通过将线性自适应滤波器与RLS算法相结合进行信道估计,来改进RLS估计算法,减小噪声对信道的影响,这样就能有效的较少信道干扰和载波间干扰,从而优化信道
17、的估计算法。2.4 RLS算法基本原理所谓自适应实现是指利用前一时刻获得的滤波器参数,根据估计误差自动调节现时刻的参数,使得某个代价函数达到最小,从而实现最优滤波。 (公式1) 下降算法:最广泛使用的自适应算法包括自适应梯度算法(LMS)、自适应高斯-牛顿算法(RLS)。RLS算法:(Recursive Least-Squares),递归最小二乘算法。它是利用在已知n-1时滤波器抽头权系数的情况下,通过简单的更新,求出n时刻的滤波器抽头权系数。代价函数:使用指数加权的误差平方和 (公式2) (01,称为遗忘因子)引入遗忘因子作用是离n时刻近的误差附较大权重, 离n时刻远的误差赋较小权重,确保在
18、过去某一段时间的观测数据被“遗忘”,从而使滤波器可以工作在非平稳状态下。估计误差定义: (公式3) (公式4)可取滤波器的实际输入d*(i)作为期望响应d(i)。将误差代入代价函数得到加权误差平方和的完整表达式: (公式5) 抽头权向量取的是n时刻的w(n)而不是i时刻的w(i)。i=n时刻, (公式6) (公式7)故代价函数比更合理。为了使代价函数取得最小值,可通过对权向量求导: (公式8) 解得 其中 (公式9) (公式10) 由此可见指数加权最小二乘法的解转化为Wiener滤波器的形式:下面研究它的自适应更新过程:由公式9可得 令、原式可化为 由矩阵求逆引理得 令,则,其中k(n)为增益
19、向量。 (公式11) 又由式中3 方案设计3.1最小二乘算法RLS算法实现图3-1自适应横向滤波器结构框图自适应横向滤波器有两路输入,一为输入信号x(n),含有样本x(1),x(2),x(N);另一为期望信号序列为d(n),含有样本d(1),d(2),d(N)如图2所示。滤波器滤波系数是对延迟线抽头信号加权的系数w1(n),w2(n),w3(n),Wm (n),实质上,这也是滤波器的冲激响应序列。这里滤波器长度M必须低于或等于信号数据长度n。滤波器输出信号y(n)等于输入信号x(n)与冲激响应序列Wi (n)的卷积和,如式。 误差信号为,由此得到自适应横向滤波器按最小平方准则设计的代价函数:
20、将代入式中,展开得:式中,MN。简短的表示滤波器的代价函数,将上式有关项定义为以下参数:(1)确定性相关函数表示输入信号在抽头k与抽头m之间两信号的相关性, (2)确定性互相关函数表示期望响应与在抽头k输入型号之间的互相关性: (3)期望响应序列的能量为: 将上述定义的三个参数代入式中,得: 为了估算滤波器的最佳滤波系数,把式对滤波系数(权系数)微分一次,并令其导数等于0: 得: 这是最小二乘法自适应滤波的正则方程。RLS递推计算公式为:式中为增益矢量,它等于相关矩阵的逆矩阵与延迟线抽头输入阵的乘积。是真正的估计误差,它等于:自适应递归最小二乘算法的信号流程图如图3:图3-2 RLS算法信号流
21、程图RLS算法的计算步序如图4:图3-3 RLS算法步序3.2 RLS算法程序程序设计在理解RLS算法的基本原理后,我决定自行编写RLS算法程序块,RLS算法可以理解为将输出反馈给滤波器来调整相关参数,达到校正误差的目的。算法实现模块代码如下所示:Worder=32; %滤波器阶数lambda=1 ; % 设置遗忘因子Delta=0.001 ; p=(1/Delta) * eye ( Worder,Worder ) ;w=zeros(Worder,1);output=primary; %主语音输出loopsize=max(size(primary); for i=1+Worder:loopsi
22、ze %写RLS算法公式 z=primary(i)-w*(fref(i-Worder+1:i); n2=fref(i-Worder+1:i); k=(1/lambda)*p*n2; K=k/(1+n2*k); w = w + K*z; p0=K*n2; p= (p-p0*p)/lambda; output(i-Worder)=z; disp(i);end; 4 RLS算法滤波方案实现4.1信号的获取本次课程设计对我们自行处理和灵活运用的能力提出了很高的要求。首先,设计中未要求所需要用到的语音信号;其次,录制噪声和被噪声污染的语音信号也是一个的问题。经过考虑,原始音频信号选择从网上下载的一段WA
23、V格式的5秒铃声,然后用randn(length(source),1)函数输出作为噪声,记做RLSrefns.wav。将这两段语音信号叠加并保存下来记做RLSprimsp.wav。4.2读取语音文件主麦克风录制的语音信号是RLSprimsp.wav,参考麦克风录制的参考噪声是RLSrefns.wav,都是.wav格式,用waveread指令读取音频信号;指令写为如下:primary = wavread(RLSprimsp.wav); primary = primary;ref = wavread(RLSrefns.wav); fref = fref;4.3RLS算法实现RLS算法的收敛特性较L
24、MS算法优越,但相应的复杂度也要高许多,考虑到收敛时间的影响,从起始时间到收敛时间经滤波器处理得到到输出误差依然很大,故直接将前32项去掉,先通过两输入作差得到预期值,再将所有预期值与对应时刻的实际输出值作差求平方,将这些平方值相加可以得到一个变量为W的函数,取W是函数的值最小。另外,显然距离n最近的量与Y(n)最接近,引入遗忘因子使得从n-1到0,相关程度逐渐减小。最后求得相关偏差,反馈给滤波器以矫正输出,达到减小误差的目的。% 初始化Worder=32; %滤波器阶数Delta=0.001 ; p=(1/Delta) * eye ( Worder,Worder ) ; w=zeros(Wo
25、rder,1);output=primary; %主语音输出loopsize=max(size(primary); for i=1+Worder:loopsize %写RLS算法公式 z=primary(i)-w*(fref(i-Worder+1:i); n2=fref(i-Worder+1:i); k=p*n2; K=k/(1+n2*k); w = w + K*z; p0=K*n2; p = (p-p0*p); output(i-Worder)=z;end;4.4提取语音信号用MATLAB中的wavread指令分别读取被噪声污染后的语音文件RLSprimsp.wav和噪声文件RLSrefns
26、.wav后,进行RLS算法处理,滤除噪声后,得到语音文件,先由plot指令绘出语音文件波形,再用Y=fft()函数求出频谱,由plot指令绘出语音文件频谱图,然后通过MATLAB中的sound命令播放语音文件。代码如下所示:%*figure; %作图%*subplot(2,4,1);plot(source); %画出原始语音波形title(原始语音波形);y1,Fs1,bits1=wavread(hen.wav);Y1=fft(y1,4096);subplot(2,4,5);plot(abs(Y1); %画出原始语音频谱title(原始语音频谱);%*subplot(2,4,2);plot(p
27、rimary); %画出麦克风主语音波形title(麦克风主语音波形);y2,Fs2,bits2=wavread(RLSprimsp.wav);Y2=fft(y2,4096);subplot(2,4,6);plot(abs(Y2); %画出麦克风主语音频谱title(麦克风主语音输入频谱);%*subplot(2,4,3);plot(fref); %画出噪声语音波形title(噪声语音波形);y3,Fs3,bits3=wavread(RLSrefns.wav);Y3=fft(y3,4096);subplot(2,4,7);plot(abs(Y3); %画出噪声语音频谱title(噪声输入频谱)
28、;%*subplot(2,4,4);plot(output); %画降噪后的语音波形title(降噪后语音波形);wavwrite(output,fs,asd); %生成降噪后的语音y,Fs4,bits4=wavread(asd.wav);Y=fft(y,4096);subplot(2,4,8);plot(abs(Y); %画出降噪后语音频谱title(降噪后语音输出频谱);%*f=1;while f=1flag=input(请选择输出语音;1-原始语音 2-加噪主语音 3-噪声语音 4-降噪后语音 : );switch flag case 1 sound(source,fs,bits); c
29、ase 2 sound(y2,Fs2,bits2); case 3 sound(y3,Fs3,bits3); case 4 sound(output,Fs4,bits4);endf=input(是否重新选择? 是 输入1 否 输入0 :);End5仿真结果与分析5.1原始音频信号(1)原始语音波形图5-1原始语音波形图(2)原始语音频谱图5-2原始语音频谱5.2麦克风主语音信号(1)麦克风主语音波形图5-3增强的语音信号波形图(2) 麦克风主语音频谱图5-4麦克风主语音频谱5.3噪声语音信号(1) 噪声语音波形图5-5噪声语音波形(2) 噪声语音频谱图5-6噪声语音频谱5.4降噪后语音信号(1
30、)降噪后语音波形图5-7降噪后语音波形(2)降噪后语音频谱图5-8降噪后语音频谱5.5信号处理分析5.5.1原始语音信号与主语音信号分析主语音信号为原始语音信号加噪声信号得到的合成信号,由于噪声信号波形的幅值相对原始语音信号幅值较小,因此原始语音信号加噪前后的波形差异并不十分明显,如图5-9,但通过对比频谱还是可以看出原始语音信号加噪前后有所不同,如图5-10。图5-9原始语音与主语音波形对比图5-10原始语音与主语音频谱对比5.5.2主语音信号与降噪后语音信号分析由于噪声信号波形的幅值相对主语音信号幅值较小,因此主语音信号降噪前后的波形差异并不十分明显,如图5-11,但通过对比频谱(如图5-
31、12)可以看出降噪后的语音信号波形刚好滤除了噪声波形,得到的波形图也更清晰。图5-11主语音信号与降噪后语音信号波形对比图5-12主语音信号与降噪后语音信号频谱对比5.5.3原始语音信号与降噪后语音信号分析原始语音信号与降噪后语音信号几乎相同,如图5-13,对比频谱可以看出两信号频谱也几乎相同,如图5-14。说明主语音信号经过RLS算法降噪的效果很好,主语音信号得到增强。图5-13原始语音信号与降噪后语音信号波形对比图5-14原始语音信号与降噪后语音信号频谱对比6总结在课程设计的过程中,首先查阅资料了解了基于RLS多麦克风语音信号降噪的过程以及RLS的原理及实现方法,通过MATLAB编程及仿真
32、,实现了语音信号的降噪,并且从不清楚的语音信号中通过RLS降噪得到了清晰的语音信号,充分体会了基于RLS多麦克风语音信号降噪这一技术的作用。同时,也学会了对语音信号进行频谱分析,以及进一步熟悉了MATLAB的使用过程,加深了对这一软件的了解,提高了自己动手的能力。通过此次学科课程设计,我掌握了自适应算法的一些基本知识,加强了我对MATLAB软件的应用能力,提高了运用RLS算法进行滤波器设计的基本能力。提高自己的基础理论知识、基本动手能力,并帮助我掌握基本的文献检索和文献阅读的方法,同时提高自己正确地撰写论文的基本能力。当然,经过此次RLS算法多麦克风语音降噪课程设计,我也发现了自己的很多不足。
33、但是通过自己的动手动脑和努力,既增加了知识,又给了我专业知识以及专业技能上的提升。这个过程也让我明白了学无止尽的道理,而且理论只有与实际联系起来才能更好地去学习与理解。我也会更加努力,认真学习,争取在以后的课程中做得更好。参考文献1陈怀琛.MATLAB及在电子信息课程中的应用. 西安电子科技大学出版社,20002胡广书.数字信号处理理论、算法与实现. 清华大学出版社,20033何振亚.自适应信号处理.科学出版社,20024安颖、侯国强.自适应滤波算法研究与DSP实现.现代电子技术出版社,20075王洪元主编.MATLAB语言以及在电子信息工程中的应用.清华大学出版社,20046 郑宝玉.自适应
34、滤波器原理M.北京:电子工业出版社,2006附录 源程序clc;source,fs,bits=wavread(hen.wav);noise=0.01*randn(length(source),1);source=source(:,1);source1=source+noise;wavwrite(noise,fs,RLSrefns); %输出模拟噪声信号wavwrite(source1,fs,RLSprimsp); %输出模拟主语音信号primary=wavread(RLSprimsp.wav); %读入麦克风语音信号primary=primary;fref=wavread(RLSrefns.w
35、av); fref=fref;Worder=32; %滤波器阶数Delta=0.001;p=(1/Delta)*eye(Worder,Worder); w=zeros(Worder,1);output=primary; %主语音输出loopsize=max(size(primary); for i=1+Worder:loopsize %写RLS算法公式z=primary(i)-w*(fref(i-Worder+1:i);n2=fref(i-Worder+1:i);k=p*n2;K=k/(1+n2*k);w=w+K*z;p0=K*n2;p=(p-p0*p);output(i-Worder)=z;
36、end%*figure; %作图%*subplot(2,4,1);plot(source); %画出原始语音波形title(原始语音波形);y1,Fs1,bits1=wavread(hen.wav);Y1=fft(y1,4096);subplot(2,4,5);plot(abs(Y1); %画出原始语音频谱title(原始语音频谱);%*subplot(2,4,2);plot(primary); %画出麦克风主语音波形title(麦克风主语音波形);y2,Fs2,bits2=wavread(RLSprimsp.wav);Y2=fft(y2,4096);subplot(2,4,6);plot(abs(Y2); %画出麦克风主语音频谱title(麦克风主语音输入频谱);%*subplot(2,4,3);plot(fref); %画出噪声语音波形title(噪声语音波形);y3,Fs3,bits3=wavread(RLSrefns.wav);Y3=fft(y3,4096);subplot(2,4,7);plot(abs(Y3); %画出噪声语音频谱title(噪声输入频谱);%*subplot(2,4,4);plot(output); %画降噪后的语音波形