dsp实现语音噪声滤波设计方案.docx
- 文档编号:6805081
- 上传时间:2023-01-10
- 格式:DOCX
- 页数:26
- 大小:160.36KB
dsp实现语音噪声滤波设计方案.docx
《dsp实现语音噪声滤波设计方案.docx》由会员分享,可在线阅读,更多相关《dsp实现语音噪声滤波设计方案.docx(26页珍藏版)》请在冰豆网上搜索。
dsp实现语音噪声滤波设计方案
dsp实现语音噪声滤波设计方案
1、设计背景语音通信的目的是传递声音信息。
位于甲地的通信者发出的声音经语音传感器变换成为电信号,经发送端设备变换为适合传输的形式,通过传输信道传输到乙地。
在乙地经接收端设备恢复出原来的语音信号,经耳机或者喇叭转换为接收者可以听到的声音信号。
这就是最基本的语音通信系统,但是由于周围环境的原因,我们采集到语音信号经常含有不同程度的噪声。
典型语音通信系统中的噪声来自三个方面:
①信号处理设备产生的电噪声及传输信道中的电噪声;②信号发送端空间环境中的音频噪声信号经麦克风变换为电信号之后,与有用信号其同传递到接收端;③信号接收端空间环境中的音频噪声对信号接收者的影响。
噪声是由于发生体作无规则振动产生的。
在很多情况下,环境中的背景噪声是通信系统中噪声干扰的主要来源。
当语音信号受到背景噪声干扰时语音通信质量变得不可接受,因此要对语音信号中的噪声滤除。
DSP利用直接存储器访问方式DMA(DirectMemoryAccess)采集数据时不打扰CPU因此利用DMA方式工作时,CPU可以对语音信号进行实时地滤波。
本设计要求利用DSP的DMA方式进行信号采集和信号输出,对语音信号进行数字编码,滤波后进行解码。
2、设计要求及目标
基本部分:
(1)对DM进行初始化;
(2)对A/D、D/AS行初始化;
(3)编写DM中断服务程序和滤波算法程序,实现语音信号的实时滤波;发挥部分:
(1)使用DS产生带回波的语音信号;
(2)利用自适应滤波实现语音信号的回波对消。
3、设计思路
首先利用DS的DM方式对外部含噪声的语音信号进行实时采集,语音信号先经过A/D转换为数字信号,利用MCBS的接收寄存器接收数据。
编写滤波算法程序,或调用DSPLI沖的滤波函数,对信号进行滤波。
滤波后的数据利用DM方式送到D/A转换器转换为模拟信号。
4、要求完成的任务
(1)编写Cg言程序,并在CCSM成开发环境下调试通过;
(2)将包含噪声的语音信号进行滤波,从扬声器输出端口输出,比较滤波前后的信号的变化;
(3)按要求撰写设计报告。
、设计容
随着现代科学的蓬勃发展,人类社会愈来愈显示出信息社会的特点。
通信或信息交换已成为人类社会存在的必要条件,正如衣食住行对人类是必要的一样。
语音作为语言的声学表现,是人类交流信息最自然、最有效、最方便的手段之一。
然而,人们在语音通信过程中不可避免地会受到来自周围环境和传输媒介引入的噪声、通信设备部电噪声、乃至其他讲话者的干扰。
这些干扰最终将使接收者接收到的语音不再是纯净的原始语音,而是被噪声污染过的带有噪声的语音信号。
例如,汽车、街道、机场中的,常受到强背景噪声的干扰,严重影响通话质量。
而环境噪声的污染使得许多语音处理系统的性能急剧恶化。
例如,语音识别已取得重大进展,正步入使用阶段。
但目前语音识别系统大多都是在安静环境中工作的,在噪声环境中尤其是强噪声环境,语音识别系统的识别率将受到严重影响。
在上述情况下,必须加入语音增强系统,或者抑制背景噪声,以提高语音通信质量,或者作为预处理器,以提高语音处理系统的抗干扰能力,维持系统性能。
因此,语音增强技术在实际中有重要价值。
目前,语音增强已在语音处理系统、通信技术、多媒体技术、数字化家电等领域得到了越来越广泛的应用。
三、设计方案、算法原理说明
1、信道干扰滤波部分
首先利用DSP的DMA方式对外部含噪声的语音信号进行实时采集,语音信号先经过A/D转换为数字信号,利用MCBS的接收寄存器接收数据。
编写滤波算法程序,或调用DSPLIB中的滤波函数,对信号进行滤波。
滤波后的数据利用DMA方式送到
D/A转换器转换为模拟信号。
这就是我们的设计思路。
具体的设计方案原理图如下。
模拟输入信号通过DSK勺MIC端口输入,经A/D
转换,然后到达DSP的DMA通道2,DSP接收到信号后,调用中断服务程序进行滤波,滤波后的信号可以在CCS上显示,也可以通过DMAS道3将信号输出到D/A转换器,经D/A转换后从SPEAKEI端口输出。
(1)直接存储器访问DMA
直接存储器访问(DirectMemoryAccess)是C54xDSP非常重要的片上外设,
DM控制器可以在不影响CPU勺情况下完成数据的传输,因此数据传输速度快,在要求信号实时采集和处理的系统中常采用DM方式进行信号采集和传输。
C5402有6个可独立编程的DMAS道,每个DM通道受各自的5个16位寄存器控制:
源地址寄存器DMSR、目的地址寄存器DMDST单元计数寄存器DMCTfl同步事件和计数寄存器DMSFC发送模式控制寄存器DMMCRI的地址寄存器DMDS规定DM要传送数据目的地址和首地址。
单元计数寄存器DMCT规定DM传送数据的个数为DMCTS存器的值加1。
同步事件和桢计数寄存器DMSF规定DM传送数据的同步事件类型和传送一块数据所含桢信号的个数。
发送模式控制寄存器DMMCR定DM通道的传输模式,当DM工作在自动初始化模式时,CP在—个DM事件完成后自动装载下一个DM初始化设置并继续进行数据传送。
DINM位和IMO位设置DM中断产生方式。
CTMOD设置发送计数模式控制,CTMO位为0时,DM工作在多桢模式,CTMO位为1时,DM工作在自动缓冲ABUS式。
SIND位和DIND位用来设置源地址和目的地址的自动调整方式。
此外,DM的6个通道
还受通道优先级和使能控制寄存器DMPREC制。
本实验利用DM通道2与MCBSPS道结合来读取A/D转换器的数据,利用DM通道3与MCBSPS道结合来将处理后的数据发送至D/A转换器。
选择MCBSPS道的接收寄存器DRR11(41H)为DM传送数据的首地址,并选择DM源地址工作在不调整方式,选择MCBSP接收事件为DM同步事件,以实现DM和MCBS的结合。
A/D转换器的数据按MCBSP的设置被传送到DS部接收寄存器DRR1中,再由DM通道2将DRR1中的数据读到指定数据存储区inp_buffer中完成数据采集。
DM在传送外部来的数据时不会影响CPU勺正常运行,当DM通道2采集完一组数据后产生一个DM中断事件中断CPU来通知CPU寸其进行相应的处理,此时DMAS道2可以按照设定继续采集下一组数据,实现了数据采集与CP处理的并行操作。
当一组数据处理完成后,将数据存放在数据存储区out_buffer中,选择out_buffer为DM通道3的首地址,并选择源工作地址工作在不调整方式。
选择MCBSP1通道的发送积存器DXR11(43H)为DM通道3传送数据的目的地址,并选择DM源地址工作在不调整方式,选择MCBSP接收事件为DM同步事件,以实现DM和MCBS的结合。
在CC集成开发环境中,与DM相关的头文件有regs54xx.h和dma54xx.h。
在这两
个头文件中,定义了DM的寄存器资源、使用方法和DM寄存器的地址和基本访问方式,以及寄存器的各个比特域和访问方法,因此需要进行C源程序的开始处包含这两个头文件。
输入信号经A/D转换后,利用DM通道2进行传输进入DS处理,而滤波后的信号输出利用了DM通道3进行传输进入D/A转换器等输出,因此需要对DM通道2和通道3进行初始化配置。
(2)A/D和D/A转换器
本实验要用到A/D和D/A转换器。
A/D转换器能够将接收的语音信号(模拟信号)转化为数字信号,供CPUS行处理;D/A转换器能够将数字信号转换为语音信号送SPEAKER口输出。
要使用A/D和D/A转换器,必须首先对A/D和D/A转换器进行初始化设置,即设置A/D转换器的工作模式(15+1bit模式,16bit模式)、输入增益(0dB,6Db,12dB)以及抽样频率(8000Hz,16000Hz)等。
2、回波去噪部分
初始化FIR延迟输出数组dbuffer_h[]、FIR输出数组、自适应滤波器系数矢量coff_w[]和自适应滤波器的输出数组out_w[]以及DSI板之后,采集输入的语音信号,根据模式的不同进行不同的处理以输出不同的信号来进行效果的比较。
我们的做法是利用设置参数mod来改变板子的功能。
mode=时信号通过FIR滤波器后产生回声,为使现象更明显可以附加一个延迟;mode=2寸用自适应滤波器逼近FIR滤波器以使之输出近似的信号,用信号通过两个系统产生的信号之差(即剩余回声)来调整自适应
滤波器的系数,使剩余回声逐渐收敛于0。
(1)自适应滤波器的基本原理:
自适应滤波原理:
禾U用前一时刻获得的滤波结果,自动调节现时刻的滤波器参数,以适应信号和噪声的未知特性,从而实现最优滤波。
自适应滤波器主要由系数可调的数字滤波器和调整滤波器系数的自适应算法两部分构成.自适应滤波器的一般结构如图I所示.自适应滤波其最重要的性能是能有效地在未知环境中跟踪时变的输入信号,使输出信号达到最优。
因而在电信、雷达、
声纳、实时控制以及图像处理等领域都有成功的应用。
常规滤波器具有特定的特性,对于输入信号根据这个滤波器特性产生相应的输出。
也就是,先有了滤波器构成的权系数,然后决定相应输出值。
但有些实际应用往往是反过来要求的,即对滤波器输出的要求是明确的,而滤波器特性是无法预先知道的。
例如长话系统,回波相消器的理想输出是无回波信号,这个要求是明确的,而系统本身却不能一开始就确定下来,因为它取决于长话系统话路传输条件的变化,像这样的应用技术就必须依赖自适应滤波技术。
團1自适应建谯器的一般结构图
图I中d(n)为期望响应,x(n)为自适应滤波器的输入,y(n)为自适应滤波器的输出,e(n)为估计误差,P(n)=x(n)-y(n)•前置级完成跟踪信号的选择,确定是信
号还是噪声;后置级根据前置级的不同选择对数字滤波器输出作不同的处理,以得到信号输出•自适应滤波器的滤波器系数受误差信号e(n)控制,根据e(n)的值和自
适应算法自动调整.
(2)
回声消除器的基本原理:
回声消除的基本原理是采用一个自适应滤渡器自动识别回声通道,通过自适应
滤波算法的调整,使其冲激响应与实际回声路径逼近,从而得到回声预测信号y(n),
再将预测信号从近端采样的语音信号d(n)中减去,即可实现回声消除。
自适应算法要求收敛速度快、计算复杂度低、稳定性好和失调误差小。
虽然许多自适应算法在理论上实现回声消除都是可行的,但通常采用的是较简单的算法。
例如广泛应用的LMS自适应算法。
(3)LMS算法:
本设计中自适应算法是根据最小均方误差判据来设计的,即理想信号与滤波器输出之差的平方值的期望值最小,并且根据这个判据来修改权系数。
均方误差&表示为E[e2(n)]=E[d(n)-y(n)]2
对于横向结构滤波器,代入y(n)的表达式,有
£=E[d2(n)]+WT(n)RW(n)-2WT(n)P
其中,R=E[X(n)XT(n)]是N*N的自相关矩阵,它是输入信号采样值间的相关性矩阵。
P=E[d(n)X(n)]为N*1互相关矢量,代表理想信号d(n)与输入矢量的相关性。
在均方误差&达到最小时,得到最佳权系数W*=[w0*,w1*,w2*,,
wN-1*]T。
它应满足下列方程
W(n)W(n)W*=0
即R*W-P=0
显然,①x(m)=[x(n)x(n-m)]是x(n)的自相关值,①xd(R)=E[x(n)d(n-k)]是
x(n)与d(n)的互相关值。
在有些应用中,把输入信号的采样值分成相同的段(每段称为一帧),再求出R和P估计值,以得到每帧的最佳权系数。
这种方法称为块对块自适应算法。
如语音信号的线性预测编码LPC就是把语音信号分成帧进行处理
的。
R和P的计算,要求出期望值E,在实际运算中不易实现。
为此,可通过下式进行估计:
用以上方法获得最佳w的运算量很大,对于一些在线或实时应用的场合,无法满足
其时间要求。
大多数场合使用迭代算法,对每次采样值求出较佳权系数,称为采样值对采样值迭代算法。
迭代算法可以避免复杂的R-1和P的运算,又能实时求得式的近似解,因而切实可行。
LMS算法是以最快下降法为原则的迭代算法,即W(n+1)矢量是W(n)矢量按
均方误差性能平面的负斜率大小调节相应一个增量。
W(n+1)=W(n)-u▽(n)
这个u是由系统稳定性和迭代运算收敛速度来决定的自适应步长。
▽(n)为n
次迭代的梯度。
对于LMS算法,▽(n)是E[e2(n)]的斜率。
2
E[e(n)]2E[e(n)X(n)]
由式W(n+1)=W(n)-u▽(n),产生了求解最佳权系数的两种方法,一种是最陡梯度法。
其思路为,设定初始权系数,用上式迭代公式计算,直到W(n+1)与
W(n)误差小于规定围。
其中▽(n)的E计算,可用估计值表达式
1k1
E{e(n)X(n)}_匸e(ni)X(ni)
一Ki0
式中K的取值应该足够大。
如果用瞬时-2e(n)X(n)来代替上式对-2E{e(n)X(n)}的估计运算,就产生了另一种算法一一随机梯度法,即WidrowHoff的LMS算法。
此时迭代公式为
W(n+1)=W(n)+2ue(n)X(n)
以上讨论的自适应算法都是基于WidrowHoff的LMS算法。
上式的迭代公式,假定滤波器结构为横向结构。
对于对称横向型结构,也可推出类似的迭代公式
W(n+1)=W(n)+2ue(n)[X(n)+X(n-N+1)]
其中,
xn,xn1,...,xnN/21T
X(n丿=
LMS算法流程图
自适应控制可以看作是一个能根据环境变化智能调节自身特性的反馈控制系统以使系统能按照一些设定的标准工作在最优状态。
一般地说,自适应控制在航空、导弹和空间飞行器的控制中很成功。
可以得出结论,传统的自适应控制适合
(1)没有大时间延迟的机械系统;
(2)对
设计的系统动态特性很清楚。
但在工业过程控制应用中,传统的自适应控制并不如意。
PID自
整定方案可能是最可靠的,广泛应用于商业产品,但用户并不怎么喜欢和接受。
传统的自适应控制方法,要么采用模型参考要么采用自整定,一般需要辨识过程的动态特性。
它存在许多基本问题
(1)需要复杂的离线训练;
(2)辨识所需的充分激励信号和系统平稳运行的矛盾;(3)
对系统结构假设;(4)实际应用中,模型的收敛性和系统稳定性无法保证。
另外,传统自适应控制方法中假设系统结构的信息,在处理非线性、变结构或大时间延迟时很难。
3、脉冲式滤波:
我们的方式先求个点的平均值,然后根据实际,大于这个平均值的5倍以上的信
号幅度进行衰减,这样可以在时域直接进行处理。
进而得到需要的声音,将乱入的声音滤掉,保护听者。
四、程序设计、调试与结果分析
1、调试过程
a、首先设计FIR滤波器。
FIR滤波器的算法可以由MATLAB设计。
打开MATLAB在命令窗中输入FDAtool,打开滤波器设计与分析工具。
因为语音信号的频率成分主要分布在300Hz到3400Hz,所以我们只要设计4000HZ勺低通FIR滤波器就可以实现对语音信号中掺杂的噪声的滤除。
在FDA中选择带低通FIR滤波器,
阶数选择15,抽样频率选择16kHz。
就可以设计所要的滤波器了。
然后将设计好的结
果导出为fir.c文件。
设计好滤波器后,还要进行对A/D和D/A以及DM的初始化,并编写主程序和中断服务程序,以及控制调用中断时程序流向的中断向量表,详细容请见程序清单。
由于DSK540板上存储器分配方式基本相同,所以.cmd文件可以采用其他程序中
的.cmd文件。
b、信号滤波部分:
(1)通过MIC向计算机输入语音信号。
但此种方式不能很好的听出声音到底有什么变化,因为其实板子的噪声即不准。
所以最好是用输入正弦波再利用CCS!
图形的方式。
(2)编译滤波工程之前先在CC下选择Tools/LinkerConfiguration,出现连接器配置对话框,选择UsetheVisualLinker,然后再对程序进行编译。
(3)编译通过则会产生Firlab.out文件,并可执行文件Firlab.out下载到DSP中。
(4)在中断服务程序dmac2isr.c中的有效行上设置断点,以便观察图形。
(5)选择Debug/Animate,激活程序。
Animate=Run-Halt-Run。
(6)在CC中选择View/Graph/Time/Frequency,出现图形属性对话框。
图形属性对话框中,StartAdress设置为输入变量名、AcquisitionBufferSize为十进制256、DisplayDataSize为十六进制、DSPDataType为16位有符号整形数,其它设置不变。
确定后出现如下图所示时域波形。
c、扩展回波对消部分:
(1)由麦克将产生的语音信号输入到J5端口。
J6端口接入音响或耳机,对比处理前后的语音信号。
(2)编译滤波工程之前先在CC下选择Tools/LinkerConfiguration,出现连接器配置对话框,选择UsethetextLinker,然后再对程序进行编译。
(3)通过设置mod的值,对不同算法处理过的信号分别观察。
0代表产生输入原声;1代表产生带回波噪声的声音;2代表用自适应消除回波后的声音;;3代表产生添加正弦频率噪音的信号;4代表用自适应方法滤除正弦噪音后的声音;5代表音调降低;6代表近音调升高;7代表滤除脉冲噪音
(4)选择Debug/Animate,激活程序。
Animate=Run-Halt-Run。
(5)在程序运行过程中,输入语音信号分别进行语音输出观察。
2、结果分析
(1)理论上的滤波输入输出信号:
女变男:
明显看出有失真。
五、设计(安装)与调试的体会
这次的dsp实验我们可以用辛酸来形容,500多人排不到20块板子,必须要起个大早才可以用到板子,所以我们的用板时间真的不是太多•当然有我们前几天的大意这方面的因素,后来当我们把理论知识研究到一定深度的准备实践的时候,实验室已
经门可罗雀了,唉~~~~我们的辛酸的借板子的历程就开始了•虽然资源不够,但这
同样给与了我们提高,锻炼了我们非常娴熟的调试技术,可以用神速来形容我们俩生成工程的速度!
所以,什么样的情况都是一种经历,这种艰苦的经历对于我们更是一种锻炼和提高,对于我们这种从小没怎么吃苦的孩子们也是一次额外的经历,也许到
了我们老了,还会想起交大小学期排板子的经历•那时我们俩要是一起聊天,一定会相视一笑的~
因为本课题的基本语音滤波部分老师在课上给予了我们讲解,因此我们就在原本的基础上进行改善和增加拓展。
因为课题要求是DMA进行语音滤波,因此我们
一开始从DMA通道的初始化使能着手,然后了解到整个程序模板中真正对DMA采集到的音频信号进行滤波的是中断服务程序,这与我们学得单片机有惊人的类似.所以这方面的初始化,我们还是掌握的不错的,但是dme寄存器实在是太多了,我们只能照着书一点一点的翻,一点一点的写,当然书上的初始化程序还是给的很细,我们也借鉴了很多,但我们想,这些都是死的.我们没有必要在这上面浪费很多时间,还是以理解为主吧~~
之后就是研究中断中具体的滤波程序了,我们是从噪声的种类角度下手,一点一点的进行的,考虑了很多噪声,这在报告的前面部分中也都提到了,然后我们就研究具体的解决办法,一步一步地下手.再查找具体的滤波函数的时候,我们也发现我们的数学水平真的还欠缺,或者说我们很强的耐心看很长的数学公式,这在日后的学习过程中还待加强阿~~
接着,我们在原来的基础上,想到了变声。
我们最初想对实时滤波处理过后的256个语音样本点间的距离进行适当的拉长和压短,这样应该就会产生一定的变声。
因为女生普遍比男生发生的频率高,这样音调高,所以对语音样本点间的距离进行压缩后,就能将一段男声近似变成“女声”;同理,对语音样本点间的距离进行拉长后,这样频率变低,就相应地实现女声变“男声”。
最后经过反复实验,我们做出了近似变声功能。
然后,我们用自适应滤波器滤除回波。
比对了几种自适应滤波器后,我们最终决定采用dims滤波器进行滤波,最后我们用了将近一天的时间dims的参数使用和定义搞清楚。
一开始我们遇到了不小的麻烦,不管怎么样都不出声,最后我们想到参考资料上介绍的是用cpu采集方式,数据一个一个的采集,而我们用的是DMA传输,是一串一串的采集,所以我们猜想是不是自适应滤波器的步长参数设置得过低,使得其自适应的过程中容量不够,因此我们尝试着将步长由原来的100该为25600,最后一试还真的实现了回波消除。
用dsp板的一个语音输入端模拟一方的用户,而再用软件产生一个接近2kHz的正弦信号模拟另一端用户传来的语音,将这两端传来的信号叠加在一起后就类似于我们日常通话中能听到自己回声的现象,再采用dims自适应滤波,滤除一方信号后就能实现回声消除!
最后我们自己模仿了脉冲噪音的形式,自己录制了一段声音,然后想在MODE7中应用阈值滤波法滤波,但是因为时间有限,主要是因为板子太少,在我们答辩以前,我俩还没有利用板子尝试过,但是我们的原理很清晰,并准备在答辩时现场尝试。
综上,就是我们对这次实验的感想,最后我们表达一下对小学期的情感.虽然说这小学期比上课还要累,但我们从理论逐步向实践过渡了,把两门信号处理的大课的知识结合到实践中去做了.我们不再是只会算题的学生了,更像是两个工程师,虽然研究的东西不太高端,但对我们应经是受益匪浅了,用一句玩笑来形容就是,这些实践为我们回去和朋友吹嘘自己在大学学到了什么提供了很强的说服力.最后的最后,感谢老师为我们上课打下的最原始的基础,感谢那些借我们板子的可爱的同学们,更要感谢学院开设这么有意义的课.
六、源程序代码
1、FIRlab.C
/***********************************************************************
******/
/*FIRlab.CAIC,McBSP,DMAinitializationforFIRlabFilter
*/
/*
*/
/*Goal:
*/
/*
*/
/*
*/
/*
*/
/*
/*
Thiscodeperformsthefollowingfunctions:
-togglethethreeLEDsontheDSK
-setupAIC(CODEC)parameters
-initializeDMAChannel(CH2-input)
-turnoninterrupts
-runforever(waitingforDMAinterruptstotransferdata)
*/
*/
/*
/*Author:
ScottBlandDate:
03/20/2000
*/
/**********************************************
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- dsp 实现 语音 噪声 滤波 设计方案