资源描述:
《基于matlab的语音信号分析与处理系统的设计》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库。
1、基于MATLAB的语音信号分析与处理系统的设计数字信号处理大作业基于MATLAB的语音信号分析与处理系统的设计班级:物联网1401学号:姓名:zk14基于MATLAB的语音信号分析与处理系统的设计目录一、设计目的3二、设计内容及要求32.1设计内容32.2设计要求3三、详细设计过程43.1语音信号的采集43.2原始语音信号的时域频域分析43.3原始语音信号加噪53.4设计滤波器63.5MATLAB语音信号处理界面设计83.6利用C语言得出声音带宽11四、调试结果12五、结论12参考文献1314基于MATLAB的语音信
2、号分析与处理系统的设计一、设计目的综合运用数字信号处理的理论知识进行频谱分析和滤波器设计,通过理论推导得出相应结论,再利用MATLAB和C语言作为编程工具进行计算机实现,从而加深对所学知识的理解,建立概念。二、设计内容及要求2.1设计内容①录制一段自己的语音信号(我是物联网1401班的张坤),并对录制的信号进行采样。②画出采样后语音信号的时域波形和频谱图。③给定滤波器的性能指标,采用窗函数法或双线性变换设计滤波器,并画出滤波器的频率响应。④利用设计的滤波器对采集的语音信号进行滤波,画出滤波后信号的时域波形和频谱,并对
3、滤波前后的信号进行对比,分析信号的变化,回放语音信号。⑤用MATLAB设计一信号处理系统界面。⑥利用C语言对录制语音信号进行FFT变换(取其中的1024进行),计算出自己声带的带宽。2.2设计要求①学会MATLAB的使用,掌握MATLAB的程序设计方法。②掌握在Windows环境下语音信号采集的方法。③掌握数字信号处理的基本概念、基本理论和基本方法。④掌握MATLAB设计FIR和IIR数字滤波器的方法。⑤学会用MATLAB对信号进行分析和处理。⑥学会用C语言进行FFT程序的编写和算法效果的仿真。14基于MATLAB的
4、语音信号分析与处理系统的设计三、详细设计过程3.1语音信号的采集利用PC机上的声卡和Windows操作系统实现语音信号的的采集。打开“开始”菜单,选择“程序附件娱乐录音机”项,打开Windows中自带的录音机程序,点击录音机程序界面中的录音按钮,开始声音录制。录完后点击放音按钮,可以实现所录音的重现。以文件名“zhangkun”保存入D:中。文件存储器的后缀默认为.wav,这是Windows操作系统规定的声音文件存的标准。3.2原始语音信号的时域频域分析利用MATLAB中的“audioread”命令来读入(采
5、集)语音信号,将它赋值给某一向量。再对其进行采样,记住采样频率和采样点数。根据help文档,下面介绍audioread函数三种调用格式。(1)[y,Fs]=audioread(filename)从指定filename,文件中读取数据并返回采样数据, y和对于该数据,Fs的采样率。(2)[y,Fs]=audioread(filename,samples)。读取所选的范围的音频采样在文件中,samples在哪里一个向量形式[start,finish]。(3)[y,Fs]=audioread(___,dataType)返回
6、采样数据在数据范围对应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后面补零
7、。当N小于xn的长度时,fft函数计算14基于MATLAB的语音信号分析与处理系统的设计xn的前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('原始语音信号频谱分析')%
8、sound(x,Fs)图1原始信号波形及频谱3.3原始语音信号加噪由于条件有限,找不到适当频率的噪声源,所以采用白噪声。MATLAB中产生高斯白噪声非常方便,直接用randn函数产生高斯分布序列。randn函数有两种基本调用格式:randn(n)和randn(m,n),前者产生n×n服从标准高斯分布的随机数矩阵,后者产生m×n的随机数矩阵。实际