File: test-main-align.sh

package info (click to toggle)
pocketsphinx 5.0.4-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 51,236 kB
  • sloc: ansic: 54,519; python: 2,438; sh: 566; cpp: 410; perl: 342; yacc: 93; lex: 50; makefile: 30
file content (50 lines) | stat: -rwxr-xr-x 1,802 bytes parent folder | download
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
#!/bin/bash

: ${CMAKE_BINARY_DIR:=$(pwd)}
. ${CMAKE_BINARY_DIR}/test/testfuncs.sh

bn=`basename $0 .sh`

echo "Test: $bn"
for wav in $data/librivox/*.wav; do \
    utt=$(basename $wav .wav)
    run_program pocketsphinx \
                -loglevel INFO \
                -hmm $model/en-us/en-us \
                -dict $model/en-us/cmudict-en-us.dict \
                align $wav $(cat $data/librivox/$utt.txt) \
                > $utt.json 2>>$bn.log
    run_program pocketsphinx \
                -loglevel INFO \
                -phone_align yes \
                -hmm $model/en-us/en-us \
                -dict $model/en-us/cmudict-en-us.dict \
                align $wav $(cat $data/librivox/$utt.txt) \
                > $utt.phone.json 2>>$bn.phone.log
    run_program pocketsphinx \
                -loglevel INFO \
                -state_align yes \
                -hmm $model/en-us/en-us \
                -dict $model/en-us/cmudict-en-us.dict \
                align $wav $(cat $data/librivox/$utt.txt) \
                > $utt.state.json 2>>$bn.state.log

    # Test whether it actually completed
    if [ $? = 0 ]; then
        pass "run $utt"
    else
        fail "run $utt"
    fi
    # Check the decoding results
    compare_table "match $utt" $data/librivox/$utt.json $utt.json 1.0
    compare_table "match $utt.phone" $data/librivox/$utt.phone.json $utt.phone.json 1.0
    compare_table "match $utt.state" $data/librivox/$utt.state.json $utt.state.json 1.0
done

run_program pocketsphinx \
            -loglevel INFO \
            -hmm $model/en-us/en-us \
            -lm $model/en-us/en-us.lm.bin \
            -dict $model/en-us/cmudict-en-us.dict align $data/null.wav ' ' \
            2>>$bn.log >null-align.json
compare_table "match" $data/null-align.json null-align.json 1.0