Matlab|语音处理|端点侦测

基于过零率和短时能量的端点侦测


[x,fs,nbits]=wavread('sunday.wav');
x = x / max(abs(x));%幅度归一化到[-1,1]
%参数设置
FrameLen = 256;     %帧长
inc = 90;           %未重叠部分,这里涉及到信号分帧的问题,在后边再解释。
amp1 = 10;          %短时能量阈值
amp2 = 2;           %即设定能量的两个阈值。
zcr1 = 10;          %过零率阈值
zcr2 = 5;                 %过零率的两个阈值,感觉第一个没有用到。
 
minsilence = 6;   %用无声的长度来判断语音是否结束
minlen  = 15;    %判断是语音的最小长度
status  = 0;      %记录语音段的状态
count   = 0;     %语音序列的长度
silence = 0;      %无声的长度
 
%计算过零率
tmp1  = enframe(x(1:end-1), FrameLen,inc);
tmp2  = enframe(x(2:end)  , FrameLen,inc);
signs = (tmp1.*tmp2)<0;
diffs = (tmp1 - tmp2)>0.02;
zcr   = sum(signs.*diffs,2);%虽然没搞懂上边的原理,但是可以推测存的是各桢的过零率。上边计算过零率的放到后边分析,这里只要了解通过这几句得到了信号各帧的过零率值,放到zcr矩阵中。
 
%计算短时能量
 %amp = sum((abs(enframe(filter([1 -0.9375], 1, x), FrameLen, inc))).^2, 2);%不知道这里的filter是干啥的&#
  • 3
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值