-
Notifications
You must be signed in to change notification settings - Fork 27
/
Copy pathgenRawData_func.m
49 lines (39 loc) · 1.39 KB
/
genRawData_func.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
function [] = genRawData_func(start_id,end_id,part_id)
SAVEPATH='/home/hyli/Data/InternData/trainDB_lps/RawData_Part';
SAVEPATH=[SAVEPATH,num2str(part_id),'.mat'];
noisebase='/home/hyli/Data/InternData/noiseDB/noise_';
cleanbase='/home/hyli/Data/InternData/train_clean/sentence_';
sent_id=start_id;
snr=-5:5:20;
data=[];label=[];nat=[];
clean_spec=[];noisy_spec=[]; sentence_id=[0];
while sent_id<=end_id
in=1;
[clean,~]=audioread([cleanbase,num2str(sent_id),'.wav']);
clean = clean.*32768;
while in<=35
[noise,~]=audioread([noisebase,num2str(in),'.wav']);
noise = noise.*32768;
rand_snr=snr(randi(6,[1,1]));
[mix,~]=addnoise(clean,noise,rand_snr);
s=clean;
n=mix-s;
S=2.*log(abs(STFT(s))'+1e-8);
N=2.*log(abs(STFT(n))'+1e-8);
M=2.*log(abs(STFT(mix))'+1e-8);
label=[label;[S,N]]; % clean lps and noise lps
[m,~]=size(M);
nat_tmp=repmat(mean(M(1:8,:)),[m,1]);
data=[data;M];
nat=[nat;nat_tmp];
in=in+1;
sentence_id=[sentence_id;sentence_id(end)+m];
end
fprintf('sentence id %d finished\n', sent_id);
sent_id=sent_id+1;
end
data=single(data);
label=single(label);
nat=single(nat);
save(SAVEPATH,'data','label','nat','sentence_id','-v7.3');
end