【端点检测】自相关函数最大值语音信号端点检测【含Matlab源码 4337期】

在这里插入图片描述

⛄一、获取代码方式

获取代码方式1:
完整代码已上传我的资源:【端点检测】基于matlab自相关函数最大值语音信号端点检测【含Matlab源码 4337期】
点击上面蓝色字体,直接付费下载,即可。

获取代码方式2:
付费专栏Matlab语音处理(初级版)

备注:
点击上面蓝色字体付费专栏Matlab语音处理(初级版),扫描上面二维码,付费29.9元订阅海神之光博客付费专栏Matlab语音处理(初级版),凭支付凭证,私信博主,可免费获得1份本博客上传CSDN资源代码(有效期为订阅日起,三天内有效);
点击CSDN资源下载链接:1份本博客上传CSDN资源代码

⛄二、语音端点检测简介

1 概述
语音信号是一种短时平稳信号,即时变的,十分复杂,携带很多有用的信息,这些信息包
括语义、个人特征等,其特征参数的准确性和唯一性将直接影响语音识别率的高低,并且这也是语音识别的基础。特征参数应该能够比较准确地表达语音信号的特征,具有一定的唯一性。
20世纪40年代, Potter等人提出了“Visible speech”的概念, 指出语谱图对语音信号有很强的描述能力,并且试着用语谱信息进行语音识别,这形成了最早的语音特征,直到现
在仍有很多人用语谱特征来进行语音识别。后来,人们发现利用语音信号的时域特征可以从语音波形中提取某些反映语音特性的参数,比如短时幅度、短时帧平均能量、短时帧过零率、短时自相关系数、平均幅度差函数等。这些参数不但能减小模板数目运算量及存储量,而且还可以滤除语音信号中无用的冗余信息。语音信号特征参数是分帧提取的,每帧特征参数一般构成一个矢量,所以语音信号特征是一个矢量序列。语音信号特征提取的基础是分帧,将语音信号切成一帧一帧,每帧大小大约是20~30ms。帧太大就不能得到语音信号随时间变化的特性,帧太小就不能提取出语音信号的特征,每帧语音信号中包含数个语音信号的基本周期。有时希望相邻帧之间的变化不是太大,帧之间就要有重叠,帧叠往往是帧长的1/2或1/3帧叠大,相应的计算量也大。随着语音识别技术的不断发展,时域特征参数的种种不足逐渐暴露出来,如这些特征参数缺乏较好的稳定性且区分能力不好。于是,频域参数开始作为语音信号的特征,如频谱共振峰等。
相比于分帧处理,端点检测在语音信号处理中也占有十分重要的地位,直接影响着系统
的性能。语音端点检测是指从一段语音信号中准确地找出语音信号的起始点和结束点,它的目的是为了使有效的语音信号和无用的噪声信号得以分离,因此在语音识别、语音增强、语音编码、回声抵消等系统中得到广泛应用。目前端点检测方法大体上可以分成两类,一类是基于阈值的方法,该方法根据语音信号和噪声信号的不同特征,提取每一段语音信号的特征,然后把这些特征值与设定的阈值进行比较,从而达到语音端点检测的目的该方法原理简单,运算方便,所以被人们广泛使用。另一类方法是基于模式识别的方法,需要估计语音信号和噪声信号的模型参数来进行检测。由于基于模式识别的方法自身复杂度高,运算量大,因此很难被人们应用到实时语音信号系统中去。

2 端点检测
2.1双门限法
语音端点检测本质上是根据语音和噪声的相同参数所表现出的不同特征来进行区分。传
统的短时能量和过零率相结合的语音端点检测算法利用短时过零率来检测清音,用短时能量来检测浊音,两者相配合便实现了信号信噪比较大情况下的端点检测。算法以短时能量检测为主,短时过零率检测为辅。根据语音的统计特性,可以把语音段分为清音、浊音以及静音(包括背景噪声)三种。
在这里插入图片描述
图5-1双门限法端点检测的二级判决示意图
(1)短时能量
设第n帧语音信号x,(m)的短时能量用E,表示,则其计算公式如下:
在这里插入图片描述
E,是一个度量语音信号幅度值变化的函数,但它有一个缺陷,即它对高电平非常敏感
(因为它计算时用的是信号的平方)。
(2)短时过零率
短时过零率表示一帧语音中语音信号波形穿过横轴(零电平)的次数。对于连续语音信号,过零即意味着时域波形通过时间轴;而对于离散信号,如果相邻的取样值改变符号则称为过零。因此,过零率就是样本改变符号的次数。
定义语音信号x,(m)的短时过零率Z,为
在这里插入图片描述
式中, sgn[·] 是符号函数, 即
在这里插入图片描述
(3)双门限法
在双门限算法中,短时能量检测可以较好地区分出浊音和静音。对于清音,由于其能量
较小,在短时能量检测中会因为低于能量门限而被误判为静音;短时过零率则可以从语音中区分出静音和清音。将两种检测结合起来,就可以检测出语音段(清音和浊音)及静音段。在基于短时能量和过零率的双门限端点检测算法中首先为短时能量和过零率分别确定两个门限,一个为较低的门限,对信号的变化比较敏感,另一个是较高的门限。当低门限被超过时,很有可能是由于很小的噪声所引起的,未必是语音的开始,当高门限被超过并且在接下来的时间段内一直超过低门限时,则意味着语音信号的开始。
双门限法进行端点检测步骤如下:
1)计算信号的短时能量和短时平均过零率。
2)根据语音能量的轮廓选取一个较高的门限T,,语音信号的能量包络大部分都在此门限之上,这样可以进行一次初判。语音起止点位于该门限与短时能量包络交点N,和N,所对应的时间间隔之外。
3)根据背景噪声的能量确定一个较低的门限T,并从初判起点往左,从初判终点往右搜索,分别找到能零比曲线第一次与门限T,相交的两个点N和Ny,于是N,N,段就是用双门限方法所判定的语音段。
4)以短时平均过零率为准,从N,点往左和N,往右搜索,找到短时平均过零率低于某
阀值T,的两点N,和N,这便是语音段的起止点。
注意:门限值要通过多次实验来确定,门限都是由背景噪声特性确定的。语音起始段的
复杂度特征与结束时的有差异,起始时幅度变化比较大,结束时,幅度变化比较缓慢。在进行起止点判决前,通常都要采集若干帧背景噪声并计算其短时能量和短时平均过零率,作为选择M和M,的依据。

2.2 自相关法
(1)短时自相关
自相关函数具有一些性质,如它是偶函数;假设序列具有周期性,则其自相关函数也是
同周期的周期函数等。对于浊音语音可以用自相关函数求出语音波形序列的基音周期。此
外,在进行语音信号的线性预测分析时,也要用到自相关函数。
语音信号x,(m)的短时自相关函数R.(k)的计算式如下:
R.(k)=*.(m)x.(m+k)(0≤k≤K)(5-4)
式中,K是最大的延迟点数。
为了避免语音端点检测过程中受到绝对能量带来的影响,把自相关函数进行归一化处
理,即用R.(0)进行归一化,得到
R.(k)=R,(k)/R.(0)(0≤k≤K)(5-5)
(2)自相关函数最大值法
图5-2和图5-3分别是噪声信号和含噪语音的自相关函数。从图可知,两种信号的自相关函数存在极大的差异,因此可利用这种差别来提取语音端点。根据噪声的情况,设置两个阀值T,当相关函数最大值大于T时,便判定是语音;当相关函数最大值大于或小于T时,则判定为语音信号的端点。
在这里插入图片描述
图5-3含噪语音的自相关函数
2.3 谱熵法
(1)谱熵特征
所谓熵就是表示信息的有序程度。在信息论中,熵描述了随机事件结局的不确定性,即
一个信息源发出的信号以信息熵来作为信息选择和不确定性的度量, 是由Shannon引用到信息理论中来的。1998年, Sh ne JL首次提出基于熵的语音端点检测方法, Sh ne在实验中发现语音的熵和噪声的熵存在较大的差异,谱熵这一特征具有一定的可选性,它体现了语音和噪声在整个信号段中的分布概率。
谱熵语音端点检测方法是通过检测谱的平坦程度,从而达到语音端点检测的目的,经实
验研究可知谱熵具有如下特征:
1)语音信号的谱熵不同于噪声信号的谱熵。
2)理论上,如果谱的分布保持不变,语音信号幅值的大小不会影响归一化。但实际上,语音谱熵随语音随机性而变化,与能量特征相比,谱熵的变化是很小的。
3)在某种程度上讲,谱熵对噪声具有一定的稳健性,相同的语音信号当信噪比降低
时,语音信号的谱熵值的形状大体保持不变,这说明谱熵是一个比较稳健性的特征参数。
4)语音谱熵只与语音信号的随机性有关,而与语音信号的幅度无关,理论上认为只要
语音信号的分布不发生变化,那么语音谱熵不会受到语音幅度的影响。另外,由于每个频率分量在求其概率密度函数的时候都经过了归一化处理,所以从这一方面也证明了语音信号的谱熵只会与语音分布有关,而不会与幅度大小有关。
(2)谱熵定义
设语音信号时域波形为x(i) , 加窗分帧处理后得到的第n帧语音信号为x, (m) , 其FFT表示为X.(k),其中下标n表示为第n帧,而k表示为第k条谱线。该语音帧在频域中的短时能量为
在这里插入图片描述
(3)基于谱熵的端点检测
由于谱熵语音端点检测方法是通过检测谱的平坦程度,来进行语音端点检测的,为了更
好地进行语音端点检测,本文采用语音信号的短时功率谱构造语音信息谱熵,从而更好地对语音段和噪声段进行区分。
其大概检测思路如下:

  1. 首先对语音信号进行分帧加窗、取FFT的点数。
    2)计算出每一帧的谱的能量。
    3)计算出每一帧中每个样本点的概率密度函数。
    4)计算出每一帧的谱熵值。
    5)设置判决门限。
    6)根据各帧的谱熵值进行端点检测。
    每一帧的谱熵值采用以下公式进行计算:
    在这里插入图片描述
    H(i)是第i帧的谱熵,H(i)计算是基于谱的能量变化而不是谱的能量,所以在不同水
    平噪声环境下谱熵参数具有一定的稳健性,但每一谱点的幅值易受噪声的污染进而影响端点检测的稳健性。
    2.4 比例法
    (1)能零比的端点检测
    在噪声情况下,信号的短时能量和短时过零率会发生一定变化,严重时会影响端点检测
    性能。图5-4是含噪情况下的短时能量和短时过零率显示图。从图中可知,在语音中的说
    话区间能量是向上凸起的,而过零率相反,在说话区间向下凹陷。这表明,说话区间能量的数值大,而过零率数值小;在噪声区间能量的数值小,而过零率数值大,所以把能量值除以过零率的值,则可以更突出说话区间,从而更容易检测出语音端点。
    在这里插入图片描述
    改进式(5-1)的能量表示为LE=lg(1+E/a)(5-10)
    式中,a为常数,适当的数值有助于区分噪声和清音。过零率的计算基本同式(5-2)和式(5-3)。不过,这里x,(m)需要先进行限幅处理,即
    在这里插入图片描述
    此时,能零比可表示为
    在这里插入图片描述
    此处, b为一较小的常数, 用于防止ZCR, 为零时溢出。
    (2)能熵比的端点检测
    谱熵值很类似于过零率值,在说话区间内的谱熵值小于噪声段的谱熵值,所以同能零
    比,能熵比的表示为
    在这里插入图片描述
    2.5对数频谱距离法
    设含噪语音信号为x(n),加窗分帧处理后得到第i帧语音信号为x,(m),帧长为N。任
    何一帧语音信号x(m) 做FFT后为
    在这里插入图片描述
    对频谱X,(k)取模值后再取对数,得
    在这里插入图片描述
    两个信号x(n)和xz(n)的对数频谱距离定义为
    在这里插入图片描述
    式中,N,表示只取正频率部分,即N=N/2+1。
    当采用对数谱距离进行端点检测时,对数谱距离的两个信号分别是语音信号和噪声信
    号。其中,噪声信号的平均频谱由下式获得:
    在这里插入图片描述
    这里, N IS表示前导的无语帧。
    基于对数谱距离的语音帧和噪声帧判别流程图如图5-5所示。通过判断一段语音信号
    中的语音帧和噪声帧,即可实现基于对数谱距离的端点检测。
    在这里插入图片描述
    图5-5 基于对数频谱距离的语音帧和噪声帧判别流程图

⛄三、部分源代码

%自相关端点检测M1_009.wav,enframe.m放在当前路径
clear all;
[x,fs]=audioread(‘M1_009.wav’);
x=filter([1 -0.95],1,x);%对语音进行预加重,x[n]=y[n]-0.95y[n-1]
L=320; %窗长
FrameLen=320;
FrameInc=160;
%[f]=enframe(x,hamming(320,‘periodic’),FrameInc);%加汉明窗
[framenum,f]=enframe(x,FrameLen,FrameInc);
%[framenum,L]=size(f);%显示帧数
P=framenum;%总帧数
%求每帧的自相关函数的最大值,用数组MCOR存储,第i个元素为第i帧自相关序列的最大值
for ii=1:P
s=f(ii,:);% 取出第ii帧语音样值
r=xcorr(s);%该帧的自相关序列,长度为2*序列长度-1,最大值在正中间
MCOR(ii)=r(FrameLen);%取r的中间值,即最大值
end
%%%观察
frameTime=(((1:P)-1)FrameInc+FrameLen/2)/fs;%
%frameTime是数组,长度为帧长,第i个元素值是第i帧中间那个样值对应的时间
figure
subplot(2,1,1)
plot((0:length(x)-1)/fs,x);
xlabel(‘时间/s’);ylabel(‘幅度’);title(‘语音信号’);
subplot(2,1,2)
plot(frameTime,MCOR);%画出各帧的倒谱距离值,从而预估起点和终点的帧序号及alpha1,alpha2大小
xlabel(‘时间/s’);ylabel(‘幅度’);title(‘自相关最大值’);
%%%%取前导帧的自相关最大值的平均值
MR=mean(MCOR(1:5));% 取1-5帧做背景噪声的自相关最大值的平均值的2倍为门限值
MR=2
MR;
cx1=0;%检测出的起点帧号
cx2=0;%检测出的终点帧号
flag1=0;
flag2=0;
for i=1:P-3
if (MCOR(i)>MR)&&(MCOR(i+1)>MR)&&(MCOR(i+2)>MR)&&(MCOR(i+3)>MR)&&(flag1==0)
cx1=i;
flag1=1;
end
end

⛄四、运行结果

在这里插入图片描述
在这里插入图片描述

⛄五、matlab版本及参考文献

1 matlab版本
2014a

2 参考文献
[1]韩纪庆,张磊,郑铁然.语音信号处理(第3版)[M].清华大学出版社,2019.
[2]柳若边.深度学习:语音识别技术实践[M].清华大学出版社,2019.

3 备注
简介此部分摘自互联网,仅供参考,若侵权,联系删除

  • 11
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
CSDN海神之光上传的全部代码均可运行,亲测可用,尽我所能,为你服务; 1、代码压缩包内容 主函数:main.m; Fig:GUI操作界面; 运行结果效果图; 2、代码运行版本 Matlab 2019b;若运行有误,根据提示修改;若不会,可私信博主; 3、运行操作步骤 步骤一:将所有文件放到 Matlab的当前文件夹中; 步骤二:双击打开main.m文件;(若有其他m文件,无需运行) 步骤三:点击运行,等程序运行完得到结果; 4、语音处理系列仿真咨询 如需其他服务,可私信博主或扫描博主博客文章底部QQ名片; 4.1 CSDN博客或资源的完整代码提供 4.2 刊或参考文献复现 4.3 Matlab程序定制 4.4 科研合作 语音处理系列程序定制或科研合作方向:语音隐藏、语音压缩、语音识别、语音去噪、语音评价、语音加密、语音合成、语音分析、语音分离、语音处理、语音编码、音乐检索、特征提取、声源定位、情感识别、语音采集播放变速等; CSDN海神之光上传的全部代码均可运行,亲测可用,尽我所能,为你服务; 1、代码压缩包内容 主函数:svddwt.m; 调用函数:其他m文件; 语音信号,其格式为MP4; 运行结果效果图; 2、代码运行版本 Matlab 2019b;若运行有误,根据提示修改;若不会,可私信博主; 3、运行操作步骤 步骤一:将所有文件放到 Matlab的当前文件夹中; 步骤二:双击打开svddwt.m文件;(若有其他m文件,无需运行) 步骤三:点击运行,等程序运行完得到结果; 4、智能优化算法背包问题系列仿真咨询 如需其他服务,可私信博主或扫描博主博客文章底部QQ名片; 4.1 CSDN博客或资源的完整代码提供 4.2 刊或参考文献复现 4.3 Matlab程序定制 4.4 科研合作 语音处理系列程序定制或科研合作方向:语音隐藏、语音压缩、语音识别、语音去噪、语音评价、语音加密、语音合成、语音分析、语音分离、语音处理、语音编码、音乐检索、特征提取、声源定位、情感识别、语音采集播放变速等;
CSDN海神之光上传的全部代码均可运行,亲测可用,尽我所能,为你服务; 1、代码压缩包内容 主函数:main.m; Fig:GUI操作界面; 运行结果效果图; 2、代码运行版本 Matlab 2019b;若运行有误,根据提示修改;若不会,可私信博主; 3、运行操作步骤 步骤一:将所有文件放到 Matlab的当前文件夹中; 步骤二:双击打开main.m文件;(若有其他m文件,无需运行) 步骤三:点击运行,等程序运行完得到结果; 4、语音处理系列仿真咨询 如需其他服务,可私信博主或扫描博主博客文章底部QQ名片; 4.1 CSDN博客或资源的完整代码提供 4.2 刊或参考文献复现 4.3 Matlab程序定制 4.4 科研合作 语音处理系列程序定制或科研合作方向:语音隐藏、语音压缩、语音识别、语音去噪、语音评价、语音加密、语音合成、语音分析、语音分离、语音处理、语音编码、音乐检索、特征提取、声源定位、情感识别、语音采集播放变速等; CSDN海神之光上传的全部代码均可运行,亲测可用,尽我所能,为你服务; 1、代码压缩包内容 主函数:svddwt.m; 调用函数:其他m文件; 语音信号,其格式为MP4; 运行结果效果图; 2、代码运行版本 Matlab 2019b;若运行有误,根据提示修改;若不会,可私信博主; 3、运行操作步骤 步骤一:将所有文件放到 Matlab的当前文件夹中; 步骤二:双击打开svddwt.m文件;(若有其他m文件,无需运行) 步骤三:点击运行,等程序运行完得到结果; 4、智能优化算法背包问题系列仿真咨询 如需其他服务,可私信博主或扫描博主博客文章底部QQ名片; 4.1 CSDN博客或资源的完整代码提供 4.2 刊或参考文献复现 4.3 Matlab程序定制 4.4 科研合作 语音处理系列程序定制或科研合作方向:语音隐藏、语音压缩、语音识别、语音去噪、语音评价、语音加密、语音合成、语音分析、语音分离、语音处理、语音编码、音乐检索、特征提取、声源定位、情感识别、语音采集播放变速等;

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Matlab领域

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值