Blame view

egs/chime5/s5b/local/reverberate_lat_dir.sh 2.66 KB
8dcb6dfcb   Yannick Estève   first commit
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
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
  #!/bin/bash
  
  # Copyright 2018  Vimal Manohar
  # Apache 2.0
  
  num_data_reps=1
  cmd=run.pl
  nj=20
  include_clean=false
  
  . utils/parse_options.sh
  . ./path.sh
  
  if [ $# -ne 4 ]; then
    echo "Usage: $0 <train-data-dir> <noisy-latdir> <clean-latdir> <output-latdir>"
    exit 1
  fi
  
  train_data_dir=$1
  noisy_latdir=$2
  clean_latdir=$3
  dir=$4
  
  clean_nj=$(cat $clean_latdir/num_jobs)
  
  $cmd JOB=1:$clean_nj $dir/copy_clean_lattices.JOB.log \
    lattice-copy "ark:gunzip -c $clean_latdir/lat.JOB.gz |" \
    ark,scp:$dir/lats_clean.JOB.ark,$dir/lats_clean.JOB.scp || exit 1
    
  for n in $(seq $clean_nj); do
    cat $dir/lats_clean.$n.scp 
  done > $dir/lats_clean.scp
  
  for i in $(seq $num_data_reps); do
    cat $dir/lats_clean.scp | awk -vi=$i '{print "rev"i"_"$0}'
  done > $dir/lats_rvb.scp
  
  noisy_nj=$(cat $noisy_latdir/num_jobs)
  $cmd JOB=1:$noisy_nj $dir/copy_noisy_lattices.JOB>log \
    lattice-copy "ark:gunzip -c $noisy_latdir/lat.JOB.gz |" \
    ark,scp:$dir/lats_noisy.JOB.ark,$dir/lats_noisy.JOB.scp || exit 1
  
  optional_clean=
  if $include_clean; then
    optional_clean=$dir/lats_clean.scp
  fi
  
  for n in $(seq $noisy_nj); do
    cat $dir/lats_noisy.$n.scp
  done | cat - $dir/lats_rvb.scp ${optional_clean} | sort -k1,1 > $dir/lats.scp
  
  utils/split_data.sh $train_data_dir $nj
  $cmd JOB=1:$nj $dir/copy_lattices.JOB.log \
    lattice-copy "scp:utils/filter_scp.pl $train_data_dir/split$nj/JOB/utt2spk $dir/lats.scp |" \
    "ark:|gzip -c >$dir/lat.JOB.gz" || exit 1
  
  echo $nj > $dir/num_jobs
  
  if [ -f $clean_latdir/ali.1.gz ]; then
    $cmd JOB=1:$clean_nj $dir/copy_clean_alignments.JOB.log \
      copy-int-vector "ark:gunzip -c $clean_latdir/ali.JOB.gz |" \
      ark,scp:$dir/ali_clean.JOB.ark,$dir/ali_clean.JOB.scp
      
    for n in $(seq $clean_nj); do
      cat $dir/ali_clean.$n.scp 
    done > $dir/ali_clean.scp
  
    for i in $(seq $num_data_reps); do
      cat $dir/ali_clean.scp | awk -vi=$i '{print "rev"i"_"$0}'
    done > $dir/ali_rvb.scp
    
    optional_clean=
    if $include_clean; then
      optional_clean=$dir/ali_clean.scp
    fi
  
    $cmd JOB=1:$noisy_nj $dir/copy_noisy_alignments.JOB.log \
      copy-int-vector "ark:gunzip -c $noisy_latdir/ali.JOB.gz |" \
      ark,scp:$dir/ali_noisy.JOB.ark,$dir/ali_noisy.JOB.scp
  
    for n in $(seq $noisy_nj); do
      cat $dir/ali_noisy.$n.scp
    done | cat - $dir/ali_rvb.scp $optional_clean | sort -k1,1 > $dir/ali.scp
  
    utils/split_data.sh $train_data_dir $nj || exit 1
    $cmd JOB=1:$nj $dir/copy_rvb_alignments.JOB.log \
      copy-int-vector "scp:utils/filter_scp.pl $train_data_dir/split$nj/JOB/utt2spk $dir/ali.scp |" \
      "ark:|gzip -c >$dir/ali.JOB.gz" || exit 1
  fi
  
  cp $clean_latdir/{final.*,tree,*.mat,*opts,*.txt} $dir || true
  
  rm $dir/lats_{clean,noisy}.*.{ark,scp} $dir/ali_{clean,noisy}.*.{ark,scp} || true # save space