-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathconvert_mfcc_to_fbank.py
52 lines (40 loc) · 1.47 KB
/
convert_mfcc_to_fbank.py
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
import os
import sys
import random
import argparse
import numpy as np
import kaldi_io
sys.path.insert(0, 'steps')
import libs.common as common_lib
def get_args():
parser = argparse.ArgumentParser(description="Apply idct")
parser.add_argument("inp_feats_scp", help='inp_feats_scp on top of which mask will be applied')
parser.add_argument("out_feats_ark", help='out_feats_ark where masked features are saved')
args = parser.parse_args()
return args
def convert_mfcc_to_fbank(feats):
num_mel = np.shape(feats)[-1]
idct_mat = common_lib.compute_idct_matrix(
num_mel, num_mel, 22.0)
idct_mat2 = np.transpose(idct_mat)
fbank = feats.dot(idct_mat2)
return fbank
def convert_fbank_to_mfcc(feats):
num_mel = np.shape(feats)[-1]
dct_mat = common_lib.compute_dct_matrix(
num_mel, num_mel, 22.0)
mfcc = feats.dot(dct_mat)
return mfcc
def main():
args = get_args()
inp_feats_scp = args.inp_feats_scp
out_feats_ark = args.out_feats_ark
ark_scp_output='ark:| copy-feats --compress=true ark:- ark,scp:{p}.ark,{p}.scp'.format(
p=out_feats_ark)
with kaldi_io.open_or_fd(ark_scp_output,'wb') as f:
for utt, feats in kaldi_io.read_mat_scp(inp_feats_scp):
mfcc = convert_mfcc_to_fbank(feats)
np.save('ark_check4/{u}.npy'.format(u=utt), mfcc)
kaldi_io.write_mat(f, mfcc, key=utt)
if __name__ == "__main__":
main()