Blame view

egs/tedlium/s5_r3/local/rnnlm/average_rnnlm.sh 1.43 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
  #!/bin/bash
  #
  # Copyright 2018  François Hernandez (Ubiqus)
  #
  # This script takes a rnnlm_dir and averages its models.
  #
  # Takes the default rnnlm_dir of tedlium s5_r3 recipe,
  # and average the best model and the 10 previous and
  # following ones (if they exist).
  
  
  . ./cmd.sh
  . ./path.sh
  
  set -e -o pipefail -u
  
  rnnlm_dir=exp/rnnlm_lstm_tdnn_a
  begin=
  end=
  
  . utils/parse_options.sh # accept options
  
  # get the best iteration
  best_iter=$(rnnlm/get_best_model.py $rnnlm_dir)
  
  # get num_iters
  info=$(grep "num_iters" $rnnlm_dir/info.txt)
  num_iters=${info##*=}
  
  
  # test if begin and end exist
  if [ -z $begin ] && [ -z $end ]; then
      begin=$(($best_iter-10))
      end=$(($best_iter+10))
      if [ $begin -le 1 ]; then
          begin=1
      fi
      if [ ! $end -le $num_iters ]; then
          end=$num_iters
      fi
  fi
  
  # create list of models and embeddings files to merge
  models=""
  embeddings=""
  for num in $(seq -s' ' $begin $end); do
      [ -f $rnnlm_dir/$num.raw ] && \
          models=$models" $rnnlm_dir/$num.raw"
  	[ -f $rnnlm_dir/feat_embedding.$num.mat ] && \
          embeddings=$embeddings" $rnnlm_dir/feat_embedding.$num.mat"
  done
  
  # merge list of files
  mkdir -p ${rnnlm_dir}_averaged
  nnet3-average $models ${rnnlm_dir}_averaged/final.raw
  matrix-sum --average=true $embeddings ${rnnlm_dir}_averaged/feat_embedding.final.mat
  
  # copy other files to averaged rnnlm_dir
  cp -r $rnnlm_dir/{info.txt,word_feats.txt,config,special_symbol_opts.txt} ${rnnlm_dir}_averaged