-
Notifications
You must be signed in to change notification settings - Fork 32
/
Copy pathextract_lfcc.m
executable file
·50 lines (49 loc) · 2.3 KB
/
extract_lfcc.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
function [stat,delta,double_delta]=extract_lfcc(speech,Fs,Window_Length,NFFT,No_Filter)
% Function for computing LFCC features
% Usage: [stat,delta,double_delta]=extract_lfcc(file_path,Fs,Window_Length,No_Filter)
%
% Input: file_path=Path of the speech file
% Fs=Sampling frequency in Hz
% Window_Length=Window length in ms
% NFFT=No of FFT bins
% No_Filter=No of filter
%
%Output: stat=Static LFCC (Size: NxNo_Filter where N is the number of frames)
% delta=Delta LFCC (Size: NxNo_Filter where N is the number of frames)
% double_delta=Double Delta LFCC (Size: NxNo_Filter where N is the number of frames)
%
% Written by Md Sahidullah at School of Computing, University of
% Eastern Finland (email: [email protected])
%
% Implementation details are available in the following paper:
% M. Sahidullah, T. Kinnunen, C. Hanil�i, �A comparison of features
% for synthetic speech detection�, Proc. Interspeech 2015,
% pp. 2087--2091, Dresden, Germany, September 2015.
%rng('default');
%speech=speech+randn(size(speech))*eps; %dithering
%-------------------------- PRE-EMPHASIS ----------------------------------
speech = filter( [1 -0.97], 1, speech);
%---------------------------FRAMING & WINDOWING----------------------------
frame_length_inSample=(Fs/1000)*Window_Length;
framedspeech=buffer(speech,frame_length_inSample,frame_length_inSample/2,'nodelay')';
w=hamming(frame_length_inSample);
y_framed=framedspeech.*repmat(w',size(framedspeech,1),1);
%--------------------------------------------------------------------------
f=(Fs/2)*linspace(0,1,NFFT/2+1);
filbandwidthsf=linspace(min(f),max(f),No_Filter+2);
fr_all=(abs(fft(y_framed',NFFT))).^2;
fa_all=fr_all(1:(NFFT/2)+1,:)';
filterbank=zeros((NFFT/2)+1,No_Filter);
for i=1:No_Filter
filterbank(:,i)=trimf(f,[filbandwidthsf(i),filbandwidthsf(i+1),...
filbandwidthsf(i+2)]);
end
filbanksum=fa_all*filterbank(1:end,:);
% disp(size(filbanksum))
%-------------------------Calculate Static Cepstral------------------------
t=dct(log10(filbanksum'+eps));
t=(t(1:No_Filter,:));
stat=t';
delta=deltas(stat',3)';
double_delta=deltas(delta',3)';
%--------------------------------------------------------------------------