show_wer.sh 1.41 KB
Newer Older
Nikhilesh Bhatnagar's avatar
Nikhilesh Bhatnagar committed
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
#!/bin/bash

split="dev_other"
ref_data=""
get_best_wer=true
dec_name="decode"
graph_name="graph"

. ./cmd.sh
. ./path.sh
. parse_options.sh

exp_root=$1

set -eu

echo "==== WER w.r.t. pseudo transcript"
for x in $exp_root/*/${dec_name}_${split}*; do grep WER $x/wer_* 2>/dev/null | utils/best_wer.sh; done


if [ ! -z $ref_data ]; then
  echo "==== WER w.r.t. real transcript (select based on pseudo WER)"
  ref_txt=$ref_data/$split/text
  for x in $exp_root/*/${dec_name}_${split}*; do
    lang=$(dirname $x)/$graph_name

    lmwt=$(
      grep WER $x/wer_* 2>/dev/null | utils/best_wer.sh |
      sed 's/.*wer_\(.*\)$/\1/g' | sed 's/_/./g'
    )
    tra=$x/scoring/$lmwt.tra
    cat $tra | utils/int2sym.pl -f 2- $lang/words.txt | sed 's:<UNK>::g' | sed 's:<SIL>::g' | \
      compute-wer --text --mode=present \
      ark:$ref_txt  ark,p:- 2> /dev/null | grep WER | xargs -I{} echo {} $tra
  done
fi

if [ ! -z $ref_data ] && $get_best_wer; then
  echo "==== WER w.r.t. real transcript (select based on true WER)"
  ref_txt=$ref_data/$split/text
  for x in $exp_root/*/${dec_name}_${split}*; do
    lang=$(dirname $x)/$graph_name

    for tra in $x/scoring/*.tra; do
      cat $tra | utils/int2sym.pl -f 2- $lang/words.txt | sed 's:<UNK>::g' | sed 's:<SIL>::g' | \
        compute-wer --text --mode=present \
        ark:$ref_txt  ark,p:- 2> /dev/null | grep WER | xargs -I{} echo {} $tra
    done | sort -k2n | head -n1
  done
fi

exit 0;