1、1基于 Matlab的语音信号分析与处理摘要 语音信号处理是研究用数字信号处理技术和语音学知识对语音信号进行处理的新兴的学科,是目前发展最为迅速的信息科学研究领域的核心技术之一。通过语音传递信息是人类最重要、最有效、最常用和最方便的交换信息形式。 滤波器设计在数字信号处理中占有极其重要的地位,FIR 数字滤波器和 IIR 滤波器是滤波器设计的重要组成部分。MATLAB 功能强大、简单易学、编程效率高,深受广大科技工作者的欢迎。课题基于MATLAB 有噪音语音信号处理与设计与实现,本人综合运用数字信号处理的理论知识对加噪声清浊语音信号进行时域、频域分析和滤波。通过理论推导得出相应结论,用 MAT
2、LAB 平台对语音信号加入了不同的噪声,进一步用双线性变换法设计了一个的巴特沃思低通 IIR 滤波器和用窗函数法设计了 FIR 低通滤波器,然后对加噪的语音信号进行滤波处理。最后对比滤波前后的语音信号的时域和频域特性。关键词 清浊语音信号采集;傅里叶变换;滤波器设计;信号处理2目录引言 - 1 -1基本原理 - 1 -1.1 语音信号概述 .- 1 -1.2 数字滤波器原理 .- 1 -2总体设计思想 - 2 -2.1 语音信号的采集 .- 2 -2.2 语音信号处理工具的选择 .- 2 -2.3 数字滤波器的设计 .- 2 -3语音信号分析和滤波处理 - 4 -3.1 语音信号的采集 .-
3、4 -3.2 语音信号的频谱分析 .- 4 -3.3 语言信号处理 .- 6 -4滤波器的设计 4 .- 10 -4.1 巴特沃斯低通滤波器 - 10 -4.2 频率响应 S 域到 Z 域的变换: - 13 -4.3 设计数字带通滤波器 - 16 -4.4 窗函数法的 FIR 滤器波 - 20 -5结果及分析 .- 23 -6总结 .- 23 -参考文献 .- 24 -附录 原程序 .- 25 - 1 -引言语言是我们人类所特有的功能,它是传承和记载人类几千年文明史,没有语言就没有我们今天人类的文明。语音是语言最基本的表现形式,是相互传递信息最重要的手段,是人类最重要、最有效、最常用和最方便的
4、交换信息的形式。语音信号处理属于信息科学的一个重要分支,大规模集成技术的高度发展和计算机技术的飞速前进,推动了这一技术的发展;它是研究用数字信号处理技术对语音信号进行处理的一门新兴学科,同时又是综合性的多学科领域和涉及面很广的交叉学科,因此我们进行语言信号处理具有时代的意义。本设计先完成语音信号的采集,然后设计低通,高通,带通等滤波器对采集到的语音信号进行滤波处理,分析语音信号各频率段的特性。并对所采集的语音信号加入不同的干扰噪声,对加入噪声的信号进行频谱分析,针对受干扰语音信号的特点设计不同的滤波器,对加噪信号进行滤波,恢复原信号。把原始语音信号、加噪语音信号和滤波后的信号进行时域变换和频域
5、变换,画出它们的时域波形和频域波形图,从视觉角度比较分析滤波的效果。也可将这 3 类信号进行播放从听觉角度感受滤波的效果。1基本原理1.1 语音信号概述语言是人类创造的,是人类区别于其他地球生命的本质特征之一。人类用语言交流的过程可以看成是一个复杂的通信过程,为了获取便于分析和处理的语音信源,必须将在空气中传播的声波转变为包含语音信息并且记载着声波物理性质的模拟(或数字)电信号,即语音信号,因此语音信号就成为语音的表现形式或载体。语音学和数字信号处理的交叉结合便形成了语音信号处理。语音信号处理是建立在语音学和数字信号处理基础之上的,对语音信号模型进行分析、存储、传输、识别和合成等方面的一门综合
6、性学科。1.2 数字滤波器原理数字滤波器的概念:若滤波器的输入、输出都是离散时间信号,那么该滤波器的单位冲激响应 h(n)也必然是离散的,这种滤波器称为数字滤波器(DF) 。数字滤波器实质上是一种运算过程用来描述离散系统输入与输出关系的差分方程的计算或卷积计算。数字滤波器的实质是用一有限精度算法实现的离散时间线性时不变系统,以完成对信号进行滤波处理的过程。它是数字信号处理的一个重要分支,具有稳定性好、精度高、灵活性强、体积小、质量轻等诸多优点。数字滤波器的分类:数字滤波器根据不同的分类标准可以将滤波器分成不同的类别。(1)根据单位冲激响应 h(n)的时间特性分类- 2 -无限冲激响应(IIR)
7、数字滤波器有限冲激响应(FIR)数字滤波器(2)根据实现方法和形式分类递归型数字滤波器非递归型数字滤波器快速卷积型(3)根据频率特性分类低通数字滤波器、高通数字滤波器、带通数字波器、 带阻数字滤波器 12总体设计思想2.1 语音信号的采集Windows 自带了一个录音机程序(简称录音机) ,通过它可以驱动声卡采集、播放和简单处理语音信号。语音信号的采集可以用麦克风直接录制人的语音,也可以通过音频线或者 MIDI 线将收音机、电视机或磁带录机中的语音信号采集到计算机中。在录音机中可以进行简单的声音处理,如加大或降低音量,加速或减速,声音的反转或添加回音效果等。加速或减速的改变可以完成变音功能,反
8、转可以达到对声音文件保密的功能。本设计用是收音机接到电脑上用录音机录的,保存起来以备处理。 22.2 语音信号处理工具的选择语音信号的进一步处理分析工作选用了 matlab 平台。MATLAB 是一种科学计算软件,专门以矩阵的形式处理数据。MATLAB 将高性能的数值计算和可视化集成在一起,并提供了大量的内置函数,不断完善 MATLAB 产品以提高产品自身的竞争能力 Matlab 的数据分析和处理功能十分强大,运用它来进行语音信号的分析、处理和可视化相当便捷。在编程效率、程序可读性、可移植性和可扩充性上 matlab 远远优于其它的高级编程语言,而且编程易学、直观,代码非常符合人们的思维习惯。
9、另外 matlab 为用户提供了丰富的 windows 图形界面设计方法,使用户能够在利用其强大的数值计算功能的同时可设计出友好的图形界面,它受到了越来越多的用户的欢迎Matlab 几乎可以在各种机型和操作系统上运行,所以在可移植性和可扩充性上,matlab 远优越于其他的高级编程语言。Matlab 语言具有强大的数值计算能力和视图能力,其偏微分方程工具箱提供了有限元求解的一个强大而灵活的环境,并且有限元网格可做精细划分以满足要求。但是,和其他的高级语言相比,matlab 程序的执行速度较慢。在目前电脑处理速度不断提升的情况下,如果实时性要求不是非常高的情况下,使用 matlab 开发就不存在
10、此类问题了。- 3 -2.3 数字滤波器的设计本设计在 matlab 平台上,设计了 IIR 和 FIR 滤波器各种类型的滤波器。用以对语音原始信号及加噪的语音信号进行滤波,重点对加噪信号进行了滤波。对于 IIR 滤波器,它的极点可以在单位圆内的任何位置,实现 IIR 滤波器的阶次可以较低,所用的存储单元较少,效率高,又由于 IIR 数字滤波器能够保留一些模拟滤波器的优良特性,因此应用很广。设计 IIR 数字滤波器的常用方法是从模拟滤波器来设计数字 IIR 滤波器。模拟滤波器设计已经有了一套相当成熟的方法,它不但有完整的设计公式,而且还有较为完整的图表供查询,因此充分利用这些已有的资源将会给数
11、字滤波器的设计带来很大的方便。再将模拟滤波器转换为数字滤波器,其转换方法有冲激响应不变法和双线性 Z 变换法。一般,当着眼于滤波器的时域瞬态响应时,采用脉冲响应不变法较好,而其它情况下,对于 IIR 的设计,大多采用双线性变换法。 对于 FIR 滤波器,它有精确、严格的线性相位特性,并且可以做成既是因果的又是稳定的系统。所以 FIR 滤波器的应用越来越广泛。 3IIR DF FIR DF(1)相位一般是非线性的 (1)相位可以做到严格线性(2)不一定稳定 (2)一定是稳定的(3)不能用 FFT 作快速卷积 (3)信号通过系统可采用快速卷积(4)一定是递归结构 (4)主要是非递归结构,也可含递归
12、环节(5)对频率分量的选择性好(零极点可同时起作用)(5)选择性差(6)相同性能下阶次较低 (6)相同性能下阶次高(7)有噪声反馈,噪声大 (7)噪声小(8)运算误差大,有可能出现极限环振荡 (8)运算误差小,不会出现极限环振荡(9) 设计有封闭形式的公式,一次完成(9)没有封闭形式的设计公式,须靠经验与反复调试(10)对计算手段的要求较低 (10)一般需用计算机计算- 4 -(11)主要用于设计分段常数的标准低通、高通、带通、带阻和全通滤波器(11)还可设计正交变换器、微分器、线性预测器、回波抵消器、均衡器、线性调频器等各种网络,适用范围广表 2.1 IIR 滤波器与 FIR 滤波器的性能比
13、较从上面的简单比较我们可以看到 IIR 与 FIR 滤波器各有所长,所以在实际应用时应该从多方面考虑来加以选择。例如,从使用要求上来看,在对相位要求不敏感的场合,如语言通讯等,选用 IIR 较为合适,这样可以充分发挥其经济高效的特点,而对于图像信号处理,数据传输等以波形携带信息的系统,则对线性相位要求较高,如果有条件,采用 FIR滤波器较好,当然,在实际应用中应考虑经济上的要求以及计算工具的条件等多方面的因素。整体来看,IIR 滤波器达到同样效果阶数少,延迟小,但是有稳定性问题,非线性相位;FIR 滤波器没有稳定性问题,线性相位,但阶数多,延迟大。而不论是 IIR 滤波器还是 FIR 滤波器的
14、设计都包括三个步骤:(1) 按照实际任务的要求,确定滤波器的性能指标。(2) 用一个因果、稳定的离散线性时不变系统的系统函数逼近性能要求。根据系统的不同的要求可以考虑用 IIR 系统函数或 FIR 系统函数去逼近。(3) 利用有限精度算法实现系统函数,包括结构选择、字长选择等。3 语音信号分析和滤波处理3.1 语音信号的采集把语音信号并保存为.wav 文件,长度小于 30 秒,并对语言信号进行采样;录制的软件可以使用 Windows 自带的录音机,或者也可以使用其它专业的录音软件,录制时需要配备录音硬件(如麦克风) ,为了方便比较,需要在安静、无噪音、干扰小的环境下录。3.2 语音信号的频谱分
15、析 首先画出语音信号的时域波形,然后对话音信号进行频谱分析。在 MATLAB 中,可以采用函数 fft 对信号进行快速傅里叶变换,得到信号的频谱特性,从而加深对频谱特性的理解。 其程序如下: y,Fs,bits=wavread(d:声音片段 01.wav);%读出信号,采样率和采样位数 Sound(y); Y = fft(y,4096); figure(1); subplot(2,2,1);plot(y); - 5 -title( 原时域波形); ylabel(amplitude); xlabel(n); subplot(2,2,2); plot(abs(Y);%对频域取模 axis(0,40
16、96,0,3);%横纵坐标确定 title(原频谱特性);%标题 ylabel(amplitude);%Y 轴显示xlabel(frequency(hz);%X 轴显示 程序运行的结果如下图所示:图 3.1 语音信号的频谱分析- 6 -3.3 语言信号处理语音信号分析:用 MATLAB 绘制出语音信号的时域波形图和原始语音信号的频率响应图和原始语音信号的 FFT 频谱图。程序设计如下:fs=22050; %语音信号采样频率为 22050x,fs,bits=wavread(wzf.wav); sound(x,fs,bits); %播放语音信号y1=fft(x,1024); %对信号做 1024
17、点 FFT 变换f=fs*(0:511)/1024;figure(1)plot(x) %做原始语音信号的时域波形图title(原始语音信号时域图);xlabel(time n);ylabel(fuzhi n);figure(2)freqz(x) %绘制原始语音信号的频率响应图title(频率响应图)figure(3)plot(f,abs(y1(1:512);title(原始语音信号频谱)xlabel(Hz);ylabel(fudu); 如下图 3.2 所示:- 7 -图 3.2 语言信号分析含噪语音信号的合成在 MATLAB 软件平台下,给原始的语音信号叠加上噪声,噪声类型分为如下几种:(1)
18、单频噪色(正弦干扰) ;(2)高斯随机噪声。绘出加噪声后的语音信号时域和频谱图,在视觉上与原始语音信号图形对比,也可通过 Windows 播放软件从听觉上进行对比,分析并体会含噪语音信号频谱和时域波形的改变。程序代码如下:fs=22050; %语音信号采样频率为 22050x,fs,bits=wavread(ding.wav); %读取语音信号的数据,赋给变量 x%sound(x)- 8 -%t=0:1/22050:(size(x)-1)/22050;y1=fft(x,1024); %对信号做 1024 点 FFT 变换f=fs*(0:511)/1024;x1=rand(1,length(x)
19、; %产生一与 x 长度一致的随机信号 x2=x1+x;%t=0:(size(x)-1); %加入正弦噪音%Au=0.3;%d=Au*sin(6*pi*5000*t);%x2=x+d; sound(x2);figure(1)subplot(2,1,1)plot(x) %做原始语音信号的时域图形title(原语音信号时域图)subplot(2,1,2)plot(x2) %做原始语音信号的时域图形title(加高斯噪声后语音信号时域图)xlabel(time n);ylabel(fudu);y2=fft(x2,1024);figure(2)subplot(2,1,1)plot(abs(y1)tit
20、le(原始语音信号频谱);xlabel(Hz);ylabel(fudu);subplot(2,1,2)plot(abs(y2)title(加噪语音信号频谱);xlabel(Hz);ylabel(fudu);程序运行可以听到声音,得到的结果图 3.3 和图 3.4 所示:- 9 -图 3.3 高斯随机噪声图 3.4 正弦 sin 噪声的加噪语音信号- 10 -4 滤波器的设计 44.1 巴特沃斯低通滤波器对加入高斯随机噪声和正弦噪声的语音信号进行滤波。用双线性变换法设计了巴特沃斯数字低通 IIR 滤波器对两加噪语音信号进行滤波,并绘制了巴特沃斯低通滤波器的幅度图和两加噪语音信号滤波前后的时域图和
21、频谱图。程序设计如下:x,fs,bits=wavread(wzf.wav);%sound(x)%随机噪声合成x2=rand(1,length(x); %产生一与 x 长度一致的随机信号 y=x+x2;%加入正弦噪声%t=0:(size(x)-1);%Au=0.3;%d=Au*sin(2*pi*500*t);%y=x+d;wp=0.1*pi;ws=0.4*pi;Rp=1;Rs=15;Fs=22050;Ts=1/Fs;wp1=2/Ts*tan(wp/2); %将模拟指标转换成数字指标ws1=2/Ts*tan(ws/2); N,Wn=buttord(wp1,ws1,Rp,Rs,s); %选择滤波器的
22、最小阶数Z,P,K=buttap(N); %创建 butterworth 模拟滤波器Bap,Aap=zp2tf(Z,P,K);b,a=lp2lp(Bap,Aap,Wn); bz,az=bilinear(b,a,Fs); %用双线性变换法实现模拟滤波器到数字滤波器的转换H,W=freqz(bz,az); %绘制频率响应曲线figure(1)plot(W*Fs/(2*pi),abs(H)- 11 -gridf1=filter(bz,az,y);figure(2)subplot(2,1,1)plot(t,y) %画出滤波前的时域图title(滤波前的时域波形);subplot(2,1,2)plot(
23、t,f1); %画出滤波后的时域图title(滤波后的时域波形);sound(f1); %播放滤波后的信号F0=fft(f1,1024);f=fs*(0:511)/1024;figure(3)y2=fft(y,1024);subplot(2,1,1);plot(f,abs(y2(1:512); %画出滤波前的频谱图title(滤波前的频谱)xlabel(Hz);ylabel(fuzhi);subplot(2,1,2)F1=plot(f,abs(F0(1:512); %画出滤波后的频谱图title(滤波后的频谱)xlabel(Hz);ylabel(fuzhi);程序运行可以播放滤波前面的语音信号
24、,对比滤波前面的语音效果,得到的结果分别图 3.5 和图 3.6 所示:- 12 -图 3.5 高斯噪声滤波- 13 -图 3.6 正弦噪声滤波4.2 频率响应 S 域到 Z 域的变换:利用双线性变换实现频率响应 S 域到 Z 域的变换法设计了巴特沃斯低通数字 IIR 滤波器,对加入高斯随机噪声和正弦噪声的语音信号进行滤波,并绘制了两滤波器滤波前后的语音信号时域图和频谱图。程序设计如下:Ft=8000;Fp=1000;Fs=1200;wp=2*pi*Fp/Ft;- 14 -ws=2*pi*Fs/Ft;fp=2*Ft*tan(wp/2);fs=2*Fs*tan(wp/2);n11,wn11=bu
25、ttord(wp,ws,1,50,s); %求低通滤波器的阶数和截止频率b11,a11=butter(n11,wn11,s); %求 S 域的频率响应的参数 num11,den11=bilinear(b11,a11,0.5); %利用双线性变换实现频率响应 S 域到 Z 域的变换 x,fs,nbits=wavread (wzf.wav);n = length (x) ; %求出语音信号的长度t=0:(n-1);x2=rand(1,length(x); %产生一与 x 长度一致的随机信号 y=x+x2;%加入正弦噪声%t=0:(size(x)-1);%Au=0.03;%d=Au*sin(2*pi
26、*500*t);%y=x+d;figure(1)f2=filter(num11,den11,y)subplot(2,1,1)plot(t,y)title(滤波前的加高斯噪声时域波形);subplot(2,1,2)plot(t,f2); %画出滤波后的时域图title(滤波后的时域波形);sound(f1); %播放滤波后的信号F0=fft(f1,1024);f=fs*(0:511)/1024;figure(2)y2=fft(y,1024);subplot(2,1,1);plot(f,abs(y2(1:512); %画出滤波前的频谱图title(滤波前加高斯噪声的频谱)xlabel(Hz);-
27、15 -ylabel(fuzhi);subplot(2,1,2)F1=plot(f,abs(F0(1:512); %画出滤波后的频谱图title(滤波后的频谱)xlabel(Hz);ylabel(fuzhi);程序运行可以播放滤波前面的语音信号,对比滤波前面的语音效果,得到的结果分别图 3.7 和图 3.8 所示:图 3.7 高斯噪音滤波- 16 -图 3.8 正弦噪音滤波4.3 设计数字带通滤波器设计了巴特沃斯带通数字 IIR 滤波器对加了高斯随机噪声和正弦噪声的语音信号进行滤波,并绘制了两滤波器滤波后的语音信号时域图和频谱图。程序设计如下:Wp=0.3*pi,0.7*pi;Ws=0.2*p
28、i,0.8*pi;Ap=1;As=30;N,wn=buttord(Wp/pi,Ws/pi,Ap,As); %计算巴特沃斯滤波器阶次和截止频率b,a=butter(N,wn,bandpass); %频率变换法设计巴特沃斯- 17 -带通滤波器%db,mag,pha,grd,w=freqz_m(b,a); %数字滤波器响应%Plot(w/pi,mag);%Title(数字滤波器幅频响应|H(ejOmega)|)x,fs,nbits=wavread (wzf.wav);n = length (x) ; %求出语音信号的长度t=0:(size(x)-1);x2=rand(1,length(x); %产
29、生一与 x 长度一致的随机信号 y=x+x2;%加入正弦噪声%n = length (x) ; %求出语音信号的长度%t=0:(n-1);%Au=0.03;%d=Au*sin(2*pi*500*t);%y=x+d;f=filter(bz,az,y);figure(1)freqz(b,1,512)f2=filter(bz,az,y)figure(2)subplot(2,1,1)plot(t,y)title(滤波前的时域波形);subplot(2,1,2)plot(t,f2);title(滤波后的时域波形);sound(f2); %播放滤波后的语音信号F0=fft(f1,1024);f=fs*(0
30、:511)/1024;figure(3)y2=fft(y,1024);subplot(2,1,1);plot(f,abs(y2(1:512); %画出滤波前的频谱图title(滤波前的频谱)- 18 -xlabel(Hz);ylabel(fuzhi);subplot(2,1,2)F1=plot(f,abs(F0(1:512); %画出滤波后的频谱图title(滤波后的频谱)xlabel(Hz);ylabel(fuzhi); 程序运行可以听到声音,得到的结果分别图 3.9 和图 3.10 所示:- 19 -图 3.9 高斯噪声滤波- 20 -图 3.10 正弦噪声滤波4.4 窗函数法的 FIR
31、滤器波使用窗函数法,选用海明窗设计了数字 FIR 低通滤波器对加了高斯随机噪声和正弦噪声的语音信号进行滤波,并绘制了两滤波器滤波后的语音信号时域图和频谱图。程序设计如下:fs=22050;x,fs,bits=wavread(wzf.wav);%sound(x)t=0:(size(x)-1);x2=rand(1,length(x); %产生一与 x 长度一致的随机信号 y=x+x2;%加入正弦噪声t=0:(n-1);Au=0.03;d=Au*sin(2*pi*500*t);y=x+d;wp=0.25*pi;ws=0.3*pi;wdelta=ws-wp;N=ceil(6.6*pi/wdelta);
32、 %取整wn=(0.2+0.3)*pi/2;b=fir1(N,wn/pi,hamming(N+1); %选择窗函数,并归一化截止频率figure(1)freqz(b,1,512)f2=filter(bz,az,y)figure(2)subplot(2,1,1)plot(t,y)title(滤波前的时域波形);subplot(2,1,2)plot(t,f2);title(滤波后的时域波形);sound(f2); %播放滤波后的语音信号- 21 -F0=fft(f1,1024);f=fs*(0:511)/1024;figure(3)y2=fft(y,1024);subplot(2,1,1);plo
33、t(f,abs(y2(1:512); %画出滤波前的频谱图title(滤波前的频谱)xlabel(Hz);ylabel(fuzhi);subplot(2,1,2)F1=plot(f,abs(F0(1:512); %画出滤波后的频谱图title(滤波后的频谱)xlabel(Hz);ylabel(fuzhi);程序运行可以听到声音,得到的结果分别图 3.11 和图 3.12 所示:- 22 -图 3.11 高斯噪声滤波- 23 -图 3.12 正弦噪声滤波5 结果及分析图 5 图形用户界面语音信号处理是语音学与数字信号处理技术相结合的交叉学科,课题在这里不讨论语音学,而是将语音当做一种特殊的信号,
34、即一种“复杂向量”来看待。也就是说,课题更多的还是体现了数字信号处理技术。 从课题的中心来看,课题是希望将数字信号处理技术应用于某一实际领域,这里就是指对语音的处理。作为存储于计算机中的语音信号,其本身就是离散化了的向量,我们只需将这些离散的量提取出来,就可以对其进行处理了。致谢:非常感谢秦伟老师在这次基于 Matlab 的语音信号分析与处理课设报告中给予的指导和帮助,以及同学们的帮助。6总结本设计采用了高效快捷的开发工具MATLAB,实现了语音信号的采集,对语音信号加噪声及设计滤波器滤除噪声的一系列工作。从频率响应图中可以看出:巴特沃斯滤波器具有单调下降的幅频特性,通带内是平滑的。海明窗设计
35、的 FIR 滤波器的频率特性几乎在任何频带上都比巴特沃斯滤波器的频率特性好,过渡带也比较小,只是海明窗设计的滤波器下降斜度较小对语言的过渡失真进行了补偿。论文初步完成了设计任务,由于本人能力有限,还存在许多不足的地方,比如滤波器的设计种类还比较单一,没有做更多的滤波效果比较等。在以后的工作和学习中会更加努力来完善设计任务。- 24 -参考文献1.杨述斌,李永全. 数字信号处理实践教程.武汉:华中科技大学出版社,2007 年 1 月2.韩纪庆,张磊,郑铁然.语音信号处理.北京:清华大学出版社,2004 年 9 月3.陈怀琛.数字信号处理教程MATLAB 释义与实现.北京:电子工业出版社,2004
36、 年 12月4.黄文梅,熊桂林,杨勇. 信号分析与处理MATLAB 语言及应用.长沙:国防科技大学出版社,2000 年 2 月- 25 -附录 原程序global I; global X;global magX;global angX;H=*.wav; filename,pathname=uigetfile(H,请选择打开文件); file=strcat(pathname,filename);I=wavread(file); X=fft(I,4096); magX=abs(X); angX=angle(X); subplot(221);plot(I);title(原始信号波形); subplo
37、t(222);plot(X); title(原始信号频谱); subplot(223);plot(magX);title(原始信号幅值); subplot(224);plot(angX);title(原始信号相位);global I; global X; global magX; global angX; Y=wavread(speech); y=real(fft(Y,4096); magY=abs(y); angY=angle(y); Y=Y+I; y=X+y; magY=magX+magY; angY=angX+angY; subplot(221);plot(Y);title(加噪后信号波
38、形); subplot(222);plot(y); title(加噪后信号频谱);- 26 -subplot(223);plot(magY);title(加噪后信号幅值);subplot(224);plot(angY);title(加噪后信号相位);global Y; global Z;b=100;a=5;z=filter(a,b,Y);Z=fft(z,4096); magZ=abs(Z); angZ=angle(Z); subplot(221);plot(z);title(FIR 滤波后信号波形); subplot(222);plot(Z); title(FIR 滤波后信号频谱); subplot(223);plot(magZ);title(FIR 滤波后信号幅值); subplot(224);plot(angZ);title(FIR 滤波后信号相位);