-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfeature_harmonic.m
64 lines (57 loc) · 1.36 KB
/
feature_harmonic.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
function [HR, f0] = feature_harmonic(window, Fs, M, m0)
%
% function [HR, f0, Gamma] = feature_harmonic(window, Fs, M, m0)
% This function computes the harmonic ratio and fundamental frequency of a
% window
%
% ARGUMENTS
% - window: the samples of the window
% - Fs: the sampling frequency
% - M: the maximum T0 (optional)
% - m0: the minimum T0 (optional)
%
% RETURNS:
% - HR: harmonic ratio
% - f0: fundamental frequency
if nargin<3
M=round(0.016*Fs);
end
% compute autocorrelation:
R=xcorr(window);
g=R(length(window));
R=R(length(window)+1:end);
i=2;
if nargin<4
% estimate m0 (as the first zero crossing of R)
m0=length(R)+1;
while i<=length(R)
if R(i)<0 & R(i-1)>=0
m0=i;
break;
end
i=i+1;
end
end
if M>length(R) M = length(R); end
% compute normalized autocorrelation:
Gamma = zeros(M, 1);
CSum = cumsum(window.^2);
Gamma(m0:M) = R(m0:M) ./ (sqrt((g*CSum(end-m0:-1:end-M)))+eps);
Z = feature_zcr(Gamma);
if Z > 0.15
HR = 0;
f0 = 0;
else
% compute T0 and harmonic ratio:
if isempty(Gamma)
HR=1;
blag=0;
Gamma=zeros(M,1);
else
[HR, blag] = max(Gamma);
end
% get fundamental frequency:
f0 = Fs / blag;
if f0>5000 f0 = 0; end
if HR<0.1 f0 = 0; end;
end