应用Matlab对含噪声的语音信号进行频谱分析及滤波.docVIP

应用Matlab对含噪声的语音信号进行频谱分析及滤波.doc

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

应用Matlab对含噪声的语音信号进行频谱分析及滤波 实验目的 巩固所学的数字信号处理理论知识,理解信号的采集、处理、传输、显示和存储过程; 综合运用专业及基础知识,解决实际工程技术问题的能力; 学习资料的收集与整理,学会撰写课程设计报告。 实验环境 微型电子计算机(PC); 安装Windows 10操作系统,MATLAB7.0,FormatFactory等开发工具。 实验原理: 在MATLAB环境中,有关声音(wave)录制、播放、存储和读取的函数有: y=wavrecord(N,fs,Dtype) 利用系统音频输入设备录音,以fs为采样频率,默认值为11025,即以11025H进为采样数据的存储格式,用字符串指定,可以是:‘double’‘single’、’int16’、 ‘int8’其中只有int8是采用8位精度进行采样,其它三种都是16位采样结果转换为指定的MATLAB数[x,fs,bits]=wavread(myrecordsound.wav) x=x(:,1); %假设声音是双声道,只取单声道作分析 上述语句表示读入存放在当前工作目录下的声音文件myrecordsound.wav,并以fs为采样频率进行采样后存储在数组x中。其中nbit是采样精度,比如16就是指16位精度的采样。取单声道后,得到的数值x是一个列向量。 sound(); 该函数的输入参量是音频数据向量、采样频率和转换位数。 例如:sound(sin(2*pi*25*(1:4000)/100)); 响两声就是:sound(sin(2*pi*25*(1:4000)/100)); sleep(1); sound(sin(2*pi*25*(1:4000)/100)); 实验内容和任务要求 1.采集语音信号并进行频谱分析 2.对加入噪声的语音信号进行频谱分析 3. 设计数字滤波器对加入噪声的语音信号进行滤波 问题分析 本实验要求设计IIR和FIR两种形式的滤波器对带有噪音的信号进行滤波。 对于任务1,我们采用张学友的一段歌曲作为原始音频,利用FormatFactory软件对该音频进行截取转换最终得到一段时长22s,采样频率为11025Hz,转换位数为16bits的双声道音频信号,保存在Matlab软件work文件夹下。实验中利用wavread()函数读取音频并取双声道中的第一声道作为信号,病利用FFT对信号进行频谱分析; 对于任务2,我们加入两个高频正弦信号至原始信号中,模仿声音被污染,然后利用FFT进行频谱分析; 对于任务3,我们设计出了巴特沃斯低通滤波器和采用了Hamming窗的FIR低通滤波器并对其相关参数进行了分析,最后利用这两种滤波器对带噪信号进行滤波,然后对滤波后的信号分别利用FFT进行频谱分析。 Matlab代码 clear all; %%提取原始视音频信号并对其进行傅里叶变换 [x,fs,bits]=wavread(zxy.wav);%读取音频文件 x=x(:,1);%取双声道中的第一声道 N=length(x);%计算信号序列长度 T=1/fs; n=0:N-1; Xf=fftshift(fft(x));%快速傅里叶变换并作中心对称变换 f=(n/N-1/2)*fs; %坐标变换 %%生成带有噪声的音频信号并对其进行傅里叶变换 fz1=4256;fz2=4627; %两个高频噪音 xz=0.01*sin(2*pi*fz1*n*T)+0.015*sin(2*pi*fz2*n*T);%噪声序列 x1=x+xz;%带有噪声的音频序列 Xf1=fftshift(fft(x1)); %%设计IIR低通滤波器 wp=2500*2/fs;ws=3000*2/fs;Rp=3;Rs=15;%通带截止频率2500Hz,阻带截止频率3000Hz,通带衰减3dB,阻带衰减15dB [Nm,Wc]=buttord(wp,ws,Rp,Rs);%计算满足指标的最小阶数以及3dB截止频率 [b,a]=butter(Nm,Wc); %计算滤波器的分子分母系数 %%IIR滤波器相关性能指标分析 H=freqz(b,a,f*2*pi/fs);%计算滤波器频率响应 mag=abs(H);pha=angle(H);%幅度响应和相位响应 mag1=20*log10(mag); %将幅频响应转化为dB的形式 %%用IIR滤波器对带有噪声的信号进行滤波 x2=filter(b,a,x1);%用IIR进行滤波 Xf2=fftshift(fft(x2)); %%设计FIR低通滤波器 wc=2800*2/fs; %3dB截止频率2800Hz fx=[0 wc wc 1]; m=[1 1 0 0]; b1=fir2(40,fx,m);%计算

文档评论(0)

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

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

1亿VIP精品文档

相关文档