陆续补充..
基频F0
基音的振动频率叫基频(pitch,一般是一个复杂声波中最低的频率(其他频率叫谐波)),它决定语音音调的高低;陪音的频率叫谐波频率,它们决定语音的音色区别。因此,两个具有相同的基频的语音可以因为谐波频率不同而具有不同的音色;相反,两个相同音色的语音可以因为基频的不同而具有不同的音高。
[x, fs] = wavread('1.wav');
nw = 256;
signal = x(16001:(16000+nw),1);#取一帧信号
#相关函数计算
r = my_direct_convolution(signal,signal(end:-1:1)); #利用卷积计算相关函数
r = r/(signal'*signal);%相关函数归一化
rhalf = r(nw:end); # 取延迟量为正值的部分
#提取基音,假设介于50-600Hz之间
lmin = round((50/fs)*nw);
lmax = round((600/fs)*nw);
[tmax,tloc] = max(rhalf(lmin:lmax)); # 在Pmin~Pmax范围内寻找最大值
pos = lmin+tloc-1; # 给出对应最大值的延迟量
pitch = pos/nw*fs # 估计得基频