视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
实验二 语音信号的时域分析
2025-09-25 17:47:59 责编:小OO
文档
实验二 语音信号的时域分析

1 实验目的

通过Matlab编程实现语音信号的时域波形图,并观察清音、浊音信号的时域特点。掌握语音信号的时域分析技术,如短时平均能量、短时平均幅度、短时平均过零率分析、短时平均自相关、短时平均幅度差。

2 实验原理

语音信号的时域分析就是分析和提取语音信号的时域参数。时域分析通常用于最基本的参数分析及应用,此方法表示语音信号比较直观,物理意义明确,实现起来比较简单,运算量少。

3 实验过程

1)观察浊音信号波形图

 2)观察清音信号波形图

 3)计算语音信号的短时能量、短时平均幅度并画图

 4)计算信号的短时平均过零率并画图

    

 5)计算语音信号的短时自相关函数并画图

    

 6)计算语音信号的短时平均幅度差函数并画图

[x,fs,bits]=wavread('c:\\WINDOWS\\Media\\chimes.wav');

x=x(:,1);

x=x';

len=length(x);

N=256;

M=128;

Fn=fix((len-N)/M+1);

y=[];

for i=1:Fn

    down=1+(i-1)*M;

    up=down+N-1;

    temp=x(down:up);

    y=[y;temp];

end

K=100;

E=[];

for i=1:Fn

    temp=sum(y(i,:).^2,2);

    E=[E,temp];

end

plot(E)

[x,fs,bits]=wavread('c:\\WINDOWS\\Media\\chimes.wav');

x=x(:,1);

x=x';

len=length(x);

N=256;

M=128;

Fn=fix((len-N)/M+1);

y=[];

for i=1:Fn

    down=1+(i-1)*M;

    up=down+N-1;

    temp=x(down:up);

    y=[y;temp];

end

K=100;

for i=1:Fn

    for j=0:K

    F(i,j+1)=sum(abs(y(i,1:N-j)-y(i,j+1:N)),2);

end

end

[x,fs,bits]=wavread('c:\\WINDOWS\\Media\\chimes.wav');

x=x(:,1);

x=x';

len=length(x);

N=256;

M=128;

Fn=fix((len-N)/M+1);

y=[];

for i=1:Fn

    down=1+(i-1)*M;

    up=down+N-1;

    temp=x(down:up);

    y=[y;temp];

end

K=100;

M=[];

for i=1:Fn

    temp=sum(abs(y(i,:)),2)

    M=[M,temp];

end

plot(M)

[x,fs,bits]=wavread('c:\\WINDOWS\\Media\\chimes.wav');

x=x(:,1);

x=x';

len=length(x);

N=256;

M=128;

Fn=fix((len-N)/M+1);

y=[];

for i=1:Fn

    down=1+(i-1)*M;

    up=down+N-1;

    temp=x(down:up);

    y=[y;temp];

end

K=100;

for i=1:Fn

    for j=0:K

    R(i,j+1)=sum(y(i,1:N-j).*y(i,j+1:N),2);

end

end

[x,fs,bits]=wavread('c:\\WINDOWS\\Media\\chimes.wav');

x=x(:,1);

x=x';

len=length(x);

N=256;

M=128;

Fn=fix((len-N)/M+1);

y=[];

for i=1:Fn

    down=1+(i-1)*M;

    up=down+N-1;

    temp=x(down:up);

    y=[y;temp];

end

K=100;

z=[];

for i=1:Fn

    temp=sum(abs(sign(y(i,2:N))-sign(y(i,1:N-1))),2);

    z=[z,temp];

end下载本文

显示全文
专题