提交 865d0758 编写于 作者: H huangyuxin

fix local/test.sh of librispeech asr1

上级 be359419
...@@ -42,6 +42,11 @@ echo "chunk mode ${chunk_mode}" ...@@ -42,6 +42,11 @@ echo "chunk mode ${chunk_mode}"
if [ ${stage} -le 0 ] && [ ${stop_stage} -ge 0 ]; then if [ ${stage} -le 0 ] && [ ${stop_stage} -ge 0 ]; then
# format the reference test file
python3 utils/format_rsl.py \
--origin_ref data/manifest.test-clean.raw \
--trans_ref data/manifest.test-clean.text
for type in attention; do for type in attention; do
echo "decoding ${type}" echo "decoding ${type}"
if [ ${chunk_mode} == true ];then if [ ${chunk_mode} == true ];then
...@@ -63,54 +68,90 @@ if [ ${stage} -le 0 ] && [ ${stop_stage} -ge 0 ]; then ...@@ -63,54 +68,90 @@ if [ ${stage} -le 0 ] && [ ${stop_stage} -ge 0 ]; then
echo "Failed in evaluation!" echo "Failed in evaluation!"
exit 1 exit 1
fi fi
python3 utils/format_rsl.py \
--origin_hyp ${ckpt_prefix}.${type}.rsl \
--trans_hyp ${ckpt_prefix}.${type}.rsl.text
python3 utils/compute-wer.py --char=1 --v=1 \
data/manifest.test-clean.text ${ckpt_prefix}.${type}.rsl.text > ${ckpt_prefix}.${type}.error
echo "decoding ${type} done."
done
for type in ctc_greedy_search; do
echo "decoding ${type}"
if [ ${chunk_mode} == true ];then
# stream decoding only support batchsize=1
batch_size=1
else
batch_size=64
fi
python3 -u ${BIN_DIR}/test.py \
--ngpu ${ngpu} \
--config ${config_path} \
--decode_cfg ${decode_config_path} \
--result_file ${ckpt_prefix}.${type}.rsl \
--checkpoint_path ${ckpt_prefix} \
--opts decode.decoding_method ${type} \
--opts decode.decode_batch_size ${batch_size}
if [ $? -ne 0 ]; then
echo "Failed in evaluation!"
exit 1
fi
python3 utils/format_rsl.py \
--origin_hyp ${ckpt_prefix}.${type}.rsl \
--trans_hyp ${ckpt_prefix}.${type}.rsl.text
python3 utils/compute-wer.py --char=1 --v=1 \
data/manifest.test-clean.text ${ckpt_prefix}.${type}.rsl.text > ${ckpt_prefix}.${type}.error
echo "decoding ${type} done." echo "decoding ${type} done."
done done
fi
for type in ctc_greedy_search; do
echo "decoding ${type}"
if [ ${chunk_mode} == true ];then for type in ctc_prefix_beam_search attention_rescoring; do
# stream decoding only support batchsize=1 echo "decoding ${type}"
batch_size=1 batch_size=1
else python3 -u ${BIN_DIR}/test.py \
batch_size=64 --ngpu ${ngpu} \
fi --config ${config_path} \
python3 -u ${BIN_DIR}/test.py \ --decode_cfg ${decode_config_path} \
--ngpu ${ngpu} \ --result_file ${ckpt_prefix}.${type}.rsl \
--config ${config_path} \ --checkpoint_path ${ckpt_prefix} \
--decode_cfg ${decode_config_path} \ --opts decode.decoding_method ${type} \
--result_file ${ckpt_prefix}.${type}.rsl \ --opts decode.decode_batch_size ${batch_size}
--checkpoint_path ${ckpt_prefix} \
--opts decode.decoding_method ${type} \ if [ $? -ne 0 ]; then
--opts decode.decode_batch_size ${batch_size} echo "Failed in evaluation!"
exit 1
if [ $? -ne 0 ]; then fi
echo "Failed in evaluation!" python3 utils/format_rsl.py \
exit 1 --origin_hyp ${ckpt_prefix}.${type}.rsl \
fi --trans_hyp ${ckpt_prefix}.${type}.rsl.text
echo "decoding ${type} done."
done python3 utils/compute-wer.py --char=1 --v=1 \
data/manifest.test-clean.text ${ckpt_prefix}.${type}.rsl.text > ${ckpt_prefix}.${type}.error
echo "decoding ${type} done."
done
for type in ctc_prefix_beam_search attention_rescoring; do fi
echo "decoding ${type}"
batch_size=1 if [ ${stage} -le 101 ] && [ ${stop_stage} -ge 101 ]; then
python3 -u ${BIN_DIR}/test.py \ python3 utils/format_rsl.py \
--ngpu ${ngpu} \ --origin_ref data/manifest.test-clean.raw \
--config ${config_path} \ --trans_ref_sclite data/manifest.test.text-clean.sclite
--decode_cfg ${decode_config_path} \
--result_file ${ckpt_prefix}.${type}.rsl \
--checkpoint_path ${ckpt_prefix} \ output_dir=${ckpt_prefix}
--opts decode.decoding_method ${type} \ for type in attention ctc_greedy_search ctc_prefix_beam_search attention_rescoring; do
--opts decode.decode_batch_size ${batch_size} python utils/format_rsl.py \
--origin_hyp ${output_dir}/${type}.rsl \
if [ $? -ne 0 ]; then --trans_hyp_sclite ${output_dir}/${type}.rsl.text.sclite
echo "Failed in evaluation!"
exit 1 mkdir -p ${output_dir}/${type}_sclite
fi sclite -i wsj -r data/manifest.test-clean.text.sclite -h ${output_dir}/${type}.rsl.text.sclite -e utf-8 -o all -O ${output_dir}/${type}_sclite -c NOASCII
echo "decoding ${type} done." done
done fi
echo "Finished" echo "Finished"
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册