基于MATLAB的语音信号分析与处理系统的设计汇.docxVIP

基于MATLAB的语音信号分析与处理系统的设计汇.docx

  1. 1、本文档共14页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
基于MATLAB的语音信号分析与处理系统的设计汇

数字信号处理大作业基于MATLAB的语音信号分析与处理系统的设计班级:物联网1401学号:姓名:zk一、设计目的综合运用数字信号处理的理论知识进行频谱分析和滤波器设计,通过理论推导得出相应结论,再利用 MATLAB和C语言作为编程工具进行计算机实现,从而加深对所学知识的理解,建立概念。二、设计内容及要求2.1设计内容①录制一段自己的语音信号(我是物联网1401班的张坤),并对录制的信号进行采样。②画出采样后语音信号的时域波形和频谱图。③给定滤波器的性能指标,采用窗函数法或双线性变换设计滤波器,并画出滤波器的频率响应。④利用设计的滤波器对采集的语音信号进行滤波,画出滤波后信号的时域波形和频谱,并对滤波前后的信号进行对比,分析信号的变化,回放语音信号。⑤用 MATLAB 设计一信号处理系统界面。 ⑥利用C语言对录制语音信号进行FFT变换(取其中的1024进行),计算出自己声带的带宽。2.2设计要求① 学会 MATLAB 的使用,掌握MATLAB 的程序设计方法。② 掌握在 Windows 环境下语音信号采集的方法。③ 掌握数字信号处理的基本概念、基本理论和基本方法。④ 掌握 MATLAB 设计 FIR 和 IIR 数字滤波器的方法。⑤ 学会用 MATLAB 对信号进行分析和处理。⑥ 学会用C语言进行FFT程序的编写和算法效果的仿真。三、详细设计过程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的前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)函数。语音信号添加噪声及其频谱分析的主要程序如下: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设计滤波器用窗

文档评论(0)

liwenhua00 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档