speedup ngram build

pull/1729/head
Hui Zhang 3 years ago
parent 60f2b5e5e5
commit 54376f5d8f

@ -1,10 +1,15 @@
#!/usr/bin/env bash #!/usr/bin/env bash
set -eo pipefail
data=$1 data=$1
feat_scp=$2 scp=$2
split_feat_name=$3 split_name=$3
numsplit=$4 numsplit=$4
# save in $data/split{n}
# $scp to split
#
if [[ ! $numsplit -gt 0 ]]; then if [[ ! $numsplit -gt 0 ]]; then
echo "Invalid num-split argument"; echo "Invalid num-split argument";
@ -12,8 +17,8 @@ if [[ ! $numsplit -gt 0 ]]; then
fi fi
directories=$(for n in `seq $numsplit`; do echo $data/split${numsplit}/$n; done) directories=$(for n in `seq $numsplit`; do echo $data/split${numsplit}/$n; done)
feat_split_scp=$(for n in `seq $numsplit`; do echo $data/split${numsplit}/$n/${split_feat_name}; done) scp_splits=$(for n in `seq $numsplit`; do echo $data/split${numsplit}/$n/${split_name}; done)
echo $feat_split_scp
# if this mkdir fails due to argument-list being too long, iterate. # if this mkdir fails due to argument-list being too long, iterate.
if ! mkdir -p $directories >&/dev/null; then if ! mkdir -p $directories >&/dev/null; then
for n in `seq $numsplit`; do for n in `seq $numsplit`; do
@ -21,4 +26,5 @@ if ! mkdir -p $directories >&/dev/null; then
done done
fi fi
utils/split_scp.pl $feat_scp $feat_split_scp echo "utils/split_scp.pl $scp $scp_splits"
utils/split_scp.pl $scp $scp_splits

@ -3,6 +3,7 @@
# To be run from one directory above this script. # To be run from one directory above this script.
. ./path.sh . ./path.sh
nj=40
text=data/local/lm/text text=data/local/lm/text
lexicon=data/local/dict/lexicon.txt lexicon=data/local/dict/lexicon.txt
@ -31,9 +32,15 @@ cleantext=$dir/text.no_oov
# oov to <SPOKEN_NOISE> # oov to <SPOKEN_NOISE>
# lexicon line: word char0 ... charn # lexicon line: word char0 ... charn
# text line: utt word0 ... wordn -> line: <SPOKEN_NOISE> word0 ... wordn # text line: utt word0 ... wordn -> line: <SPOKEN_NOISE> word0 ... wordn
cat $text | awk -v lex=$lexicon 'BEGIN{while((getline<lex) >0){ seen[$1]=1; } } text_dir=$(dirname $text)
split_name=$(basename $text)
./local/split_data.sh $text_dir $text $split_name $nj
utils/run.pl JOB=1:$nj $text_dir/split${nj}/JOB/${split_name}.no_oov.log \
cat ${text_dir}/split${nj}/JOB/${split_name} \| awk -v lex=$lexicon 'BEGIN{while((getline<lex) >0){ seen[$1]=1; } }
{for(n=1; n<=NF;n++) { if (seen[$n]) { printf("%s ", $n); } else {printf("<SPOKEN_NOISE> ");} } printf("\n");}' \ {for(n=1; n<=NF;n++) { if (seen[$n]) { printf("%s ", $n); } else {printf("<SPOKEN_NOISE> ");} } printf("\n");}' \
> $cleantext || exit 1; \> ${text_dir}/split${nj}/JOB/${split_name}.no_oov || exit 1;
cat ${text_dir}/split${nj}/*/${split_name}.no_oov > $cleantext
# compute word counts, sort in descending order # compute word counts, sort in descending order
# line: count word # line: count word

@ -0,0 +1,30 @@
#!/usr/bin/env bash
set -eo pipefail
data=$1
scp=$2
split_name=$3
numsplit=$4
# save in $data/split{n}
# $scp to split
#
if [[ ! $numsplit -gt 0 ]]; then
echo "Invalid num-split argument";
exit 1;
fi
directories=$(for n in `seq $numsplit`; do echo $data/split${numsplit}/$n; done)
scp_splits=$(for n in `seq $numsplit`; do echo $data/split${numsplit}/$n/${split_name}; done)
# if this mkdir fails due to argument-list being too long, iterate.
if ! mkdir -p $directories >&/dev/null; then
for n in `seq $numsplit`; do
mkdir -p $data/split${numsplit}/$n
done
fi
echo "utils/split_scp.pl $scp $scp_splits"
utils/split_scp.pl $scp $scp_splits
Loading…
Cancel
Save