您好,欢迎访问三七文档
当前位置:首页 > 临时分类 > 基于MATLAB的语音信号分析与处理系统的设计
数字信号处理大作业基于MATLAB的语音信号分析与处理系统的设计班级:物联网1401学号:姓名:zk基于MATLAB的语音信号分析与处理系统的设计2目录一、设计目的......................................................................................3二、设计内容及要求..........................................................................32.1设计内容..................................................................................32.2设计要求..................................................................................3三、详细设计过程..............................................................................43.1语音信号的采集......................................................................43.2原始语音信号的时域频域分析.............................................43.3原始语音信号加噪..................................................................53.4设计滤波器..............................................................................63.5MATLAB语音信号处理界面设计.........................................83.6利用C语言得出声音带宽...................................................11四、调试结果....................................................................................12五、结论.............................................................................................12参考文献.............................................................................................13基于MATLAB的语音信号分析与处理系统的设计3一、设计目的综合运用数字信号处理的理论知识进行频谱分析和滤波器设计,通过理论推导得出相应结论,再利用MATLAB和C语言作为编程工具进行计算机实现,从而加深对所学知识的理解,建立概念。二、设计内容及要求2.1设计内容①录制一段自己的语音信号(我是物联网1401班的张坤),并对录制的信号进行采样。②画出采样后语音信号的时域波形和频谱图。③给定滤波器的性能指标,采用窗函数法或双线性变换设计滤波器,并画出滤波器的频率响应。④利用设计的滤波器对采集的语音信号进行滤波,画出滤波后信号的时域波形和频谱,并对滤波前后的信号进行对比,分析信号的变化,回放语音信号。⑤用MATLAB设计一信号处理系统界面。⑥利用C语言对录制语音信号进行FFT变换(取其中的1024进行),计算出自己声带的带宽。2.2设计要求①学会MATLAB的使用,掌握MATLAB的程序设计方法。②掌握在Windows环境下语音信号采集的方法。③掌握数字信号处理的基本概念、基本理论和基本方法。④掌握MATLAB设计FIR和IIR数字滤波器的方法。⑤学会用MATLAB对信号进行分析和处理。⑥学会用C语言进行FFT程序的编写和算法效果的仿真。基于MATLAB的语音信号分析与处理系统的设计4三、详细设计过程3.1语音信号的采集利用PC机上的声卡和Windows操作系统实现语音信号的的采集。打开“开始”菜单,选择“程序\附件\娱乐\录音机”项,打开Windows中自带的录音机程序,点击录音机程序界面中的录音按钮,开始声音录制。录完后点击放音按钮,可以实现所录音的重现。以文件名“zhangkun”保存入D:\中。文件存储器的后缀默认为.wav,这是Windows操作系统规定的声音文件存的标准。3.2原始语音信号的时域频域分析利用MATLAB中的“audioread”命令来读入(采集)语音信号,将它赋值给某一向量。再对其进行采样,记住采样频率和采样点数。根据help文档,下面介绍audioread函数三种调用格式。(1)[y,Fs]=audioread(filename)从指定filename,文件中读取数据并返回采样数据,y和对于该数据,Fs的采样率。(2)[y,Fs]=audioread(filename,samples)。读取所选的范围的音频采样在文件中,samples在哪里一个向量形式[start,finish]。(3)[y,Fs]=audioread(___,dataType)返回采样数据在数据范围对应dataType的'native'或'double',及可以在以前的语法中包含的任何输入参数。对zhangkun.wav进行采样,选用方式(1)。程序如下:Fs=16000;[x,Fs]=audioread('D:\ai.wav');然后,画出语音信号的时域波形,再对语音信号进行频谱分析。MATLAB提供了快速傅里叶变换算法FFT计算DFT的函数fft,其调用格式如下:y=fft(x,N);参数xn为被变换的时域序列向量,N是DFT变换区间长度,当N大于xn的长度时,fft函数自动在xn后面补零。当N小于xn的长度时,fft函数计算xn基于MATLAB的语音信号分析与处理系统的设计5的前N个元素,忽略其后面的元素。在本次设计中,利用fft对语音信号进行快速傅里叶变换,即可以得到信号的频谱特性。其程序如下:figure(1)subplot(2,1,1)plot(x,'b');title('原始语音信号的时域波形')N=length(x);n=0:N-1;q=n*2^pi/N;y=fft(x,N);subplot(2,1,2)plot(q/pi,abs(y),'b');title('原始语音信号频谱分析')%sound(x,Fs)图1原始信号波形及频谱3.3原始语音信号加噪由于条件有限,找不到适当频率的噪声源,所以采用白噪声。MATLAB中产生高斯白噪声非常方便,直接用randn函数产生高斯分布序列。randn函数有两种基本调用格式:randn(n)和randn(m,n),前者产生n×n服从标准高斯分布的随机数矩阵,后者产生m×n的随机数矩阵。实际选用randn(m,n)函数。语基于MATLAB的语音信号分析与处理系统的设计6音信号添加噪声及其频谱分析的主要程序如下:Noise=zeros(N,2);Noise=0.01*randn(N,2);Si=x+Noise;figure(2)subplot(2,1,1)plot(Si,'b');title('原始语音信号加噪时域波形');sound(Si);S=fft(Si);subplot(2,1,2)plot(q/pi,abs(S),'b')title('原始语音信号加噪频谱分析');程序结果如下图:图2语音信号添加噪声及其频谱分析3.4设计滤波器用窗函数法设计FIR滤波器的步骤如下:(1)根据对阻带衰减及过渡带的指标要求,选择串窗数类型(矩形窗、三角窗、汉宁窗、哈明窗、凯塞窗等),并估计窗口长度N。先按照阻带衰减选择窗函数类型。原则是在保证阻带衰减满足要求的情况下,尽量选择主瓣的窗函基于MATLAB的语音信号分析与处理系统的设计7数。(2)构造希望逼近的频率响应函数。(3)计算h(n)。(4)加窗得到设计结果。MATLAB信号处理工具箱提供了两个函数进行FIR数字滤波器的设计,分别为fir1和fir2。可以用来设计具有标准频率响应的FIR数字滤波器。这里采用fir1函数设计kaiser凯塞窗低通滤波器,fir1调用格式如下:b=fir1(n,Wn,window);参数window用来制定所用的窗函数的类型,其长度为n+1。默认时自动认为window为汉宁窗。在这里window应为kaiser根据语音信号的特点给出低通滤波器的技术指标设计低通滤波器指标为:fp=700Hz,fs=800Hz,fc=fp+fs2π=604Hz,,Ap=1dB,As=30dB,采样频率16000Hz。滤波器程序如下:fp=700;fs=800;rs=40;wp=2*pi*fp/Fs;ws=2*pi*fs/Fs;Bt=ws-wp;alph=0.5842*(rs-21)^0.4+0.07886*(rs-21);M=ceil((rs-8)/2.285/Bt);wc=(wp+ws)/2/pi;hn=fir1(M,wc,kaiser(M+1,alph));凯塞窗滤波器频率响应图如下:图3凯塞窗滤波器频率响应滤波前后语音信号时域波形对比:基于MATLAB的语音信号分析与处理系统的设计8图4滤波前后语音信号时域波形对比滤波前后语音信号频谱图对比:图5滤波前后语音信号频谱图对比滤波前后声音回放结果发现噪声被滤除还原之前没有噪声污染的语音信号。3.5MATLAB语音信号处理界面设计MATLAB提供了强大的集成GUI开发环境,图形用户界面(graphicaluserinterfaces,GUI)则是由窗口、光标、按键、菜单、文字说明等对象(objects)构成的一个用户界面。用户通过一定的方法(如鼠标或键盘)选择、激活这些图形对象,使计算机产生某种动作或变化。在MATLAB中GUI是一中包含多种对象基于MATLAB的语音信号分析与处理系统的设计9的图形窗口,并为GUI开发者提供一个方便高效的集成开发环境GUIDE。GUIDE主要是一个界面设计工具集,MATLAB将所有GUI支持度控件都集成在这个环境中,并提供界面外观、属性和行为响应方式的设置方法。通过设计,界面如下图所示:图6语音信号处理界面界面功能介绍:(1)原始语音信号的时域及频谱波形显示,原始语音信号的播放。运行结果如下:基于MATLAB的语音信号分析与处理系统的设计10图7原始信号GUI界面显示(2)滤波后语音信号的时域及频谱波形显示,语音信号的播放。运行结果如下:图8滤波后信号GUI界面显示(3)凯塞窗滤波器频率响应曲线显示。运行结果如下所示:图9凯塞窗频率响应曲线基于MATLAB的语音信号分析与处理系统的设计11(4)退出语音处理系统界面。3.6利用C语言得出声音带宽利用VC++6.0软件编写FFT的C语言程序变换。输入数字1,2,3,4,5,6,7,8,求解其快速傅里叶变换,运行结果与MATLAB运算结果一致,说明FFT的程序是正确的。运行截图如下:图10C语言8点FFT结果图图11MATLAB8点FFT结果图通过MATLAB自身声音的采样1024点,并通过C语言FFT变换,通过变换后的对变换后幅值的分析得出自己的声音带宽。运行结果如下图所示:图10声音带宽结果图基于MATLAB的语音信号分析与处理系统的设计12四、调试结果结果调试结果如下图所示:图11功能调试结果图五、结论通过对有噪声语音信号的分析与处理,进一步加深了对数字信号处理的学习,作为存储于计算机中的语音信号,其本身就是离散化了的向量,只需将这些离散的量提取出来,就可以对其进行处理了。这一过程的实现,用到了处理数字信号的强有力工具MATLAB。通过M
本文标题:基于MATLAB的语音信号分析与处理系统的设计
链接地址:https://www.777doc.com/doc-4628967 .html