annotate experiments/scripts/cnbh-syllables/feature_generation/gen_hcopy_aimcopy_script.sh @ 56:5d4f1e1524bb

- Add support for reading and writing vectors from signal banks. Useful for Python.
author tomwalters
date Wed, 04 Aug 2010 20:56:29 +0000
parents 90eebc3c02ca
children 41640b18c99c
rev   line source
tomwalters@54 1 #!/bin/bash
tomwalters@54 2 # Copyright 2009-2010 Thomas Walters <tom@acousticscale.org>
tomwalters@54 3 #
tomwalters@54 4 # Generate a list of source and destination filenames from the syllables spoke
tomwalters@54 5 # pattern. This list can be used as a script for HTK's HCopy and AIM-C's
tomwalters@54 6 # AIMCopy binaries for generating features.
tomwalters@54 7 #
tomwalters@54 8 # The first argument is the path to the root directory for the features to be
tomwalters@54 9 # generated in. The second argument is the path to the sounds database.
tomwalters@54 10 #
tomwalters@54 11 # Generated files:
tomwalters@54 12 # feature_generation_script - The AIMCopy / HCopy script
tomwalters@54 13
tomwalters@54 14 FEATURES_DIR=$1
tomwalters@54 15 SOUND_SOURCE=$2
tomwalters@54 16
tomwalters@54 17 FULL_LIST=feature_generation_script
tomwalters@54 18
tomwalters@54 19 # Temporary file names
tomwalters@54 20 SYLLIST=syllable_list
tomwalters@54 21 TALKERS=talker_list
tomwalters@54 22
tomwalters@54 23 # The vowels and consonants that make up the CNBH database
tomwalters@54 24 VOWELS="a e i o u"
tomwalters@54 25 CONSONANTS="b d f g h k l m n p r s t v w x y z"
tomwalters@54 26
tomwalters@54 27 if [ ! -e $FEATURES_DIR/.features_script_success ]; then
tomwalters@54 28 mkdir -p $FEATURES_DIR
tomwalters@54 29
tomwalters@54 30 # Make the sets of VC, CV, and vowel only labels, plus silence and use them to
tomwalters@54 31 # generate the grammar, dictionary and list of syllables
tomwalters@54 32 if [ -a $FEATURES_DIR/$SYLLIST.tmp.tmp ]
tomwalters@54 33 then
tomwalters@54 34 rm $FEATURES_DIR/$SYLLIST.tmp.tmp
tomwalters@54 35 fi
tomwalters@54 36
tomwalters@54 37 for v in $VOWELS; do
tomwalters@54 38 for c in $CONSONANTS; do
tomwalters@54 39 echo $v$c >> $FEATURES_DIR/$SYLLIST.tmp.tmp
tomwalters@54 40 echo $c$v >> $FEATURES_DIR/$SYLLIST.tmp.tmp
tomwalters@54 41 done
tomwalters@54 42 done
tomwalters@54 43
tomwalters@54 44 # Sort the syllable list and delete the
tomwalters@54 45 # temporary, unsorted version
tomwalters@54 46 sort $FEATURES_DIR/$SYLLIST.tmp.tmp > $FEATURES_DIR/$SYLLIST.tmp
tomwalters@54 47 rm $FEATURES_DIR/$SYLLIST.tmp.tmp
tomwalters@54 48
tomwalters@54 49 cat <<"EOF" > $FEATURES_DIR/${TALKERS}.tmp
tomwalters@54 50 170.9p112.2s
tomwalters@54 51 171.0p112.8s
tomwalters@54 52 171.3p111.7s
tomwalters@54 53 171.5p113.1s
tomwalters@54 54 171.9p111.5s
tomwalters@54 55 172.1p113.0s
tomwalters@54 56 172.4p111.9s
tomwalters@54 57 172.5p112.5s
tomwalters@54 58 171.7p112.3s
tomwalters@54 59 137.0p104.3s
tomwalters@54 60 141.3p135.4s
tomwalters@54 61 145.5p106.3s
tomwalters@54 62 148.8p128.8s
tomwalters@54 63 151.6p83.9s
tomwalters@54 64 153.0p108.1s
tomwalters@54 65 155.5p123.5s
tomwalters@54 66 156.7p90.6s
tomwalters@54 67 159.5p109.6s
tomwalters@54 68 161.1p119.4s
tomwalters@54 69 161.1p96.8s
tomwalters@54 70 163.4p157.6s
tomwalters@54 71 164.7p110.8s
tomwalters@54 72 164.9p102.1s
tomwalters@54 73 165.6p144.0s
tomwalters@54 74 165.7p116.2s
tomwalters@54 75 167.4p133.5s
tomwalters@54 76 167.8p106.5s
tomwalters@54 77 168.6p111.6s
tomwalters@54 78 168.9p125.4s
tomwalters@54 79 169.0p114.0s
tomwalters@54 80 170.0p109.7s
tomwalters@54 81 170.1p119.5s
tomwalters@54 82 171.0p115.5s
tomwalters@54 83 172.4p109.3s
tomwalters@54 84 173.3p105.6s
tomwalters@54 85 173.5p115.0s
tomwalters@54 86 174.5p100.6s
tomwalters@54 87 174.5p110.6s
tomwalters@54 88 174.9p113.0s
tomwalters@54 89 175.7p118.5s
tomwalters@54 90 176.1p94.5s
tomwalters@54 91 178.0p108.5s
tomwalters@54 92 178.1p87.6s
tomwalters@54 93 178.8p123.6s
tomwalters@54 94 179.0p113.9s
tomwalters@54 95 180.4p80.1s
tomwalters@54 96 183.0p105.7s
tomwalters@54 97 183.0p130.4s
tomwalters@54 98 184.8p115.1s
tomwalters@54 99 188.1p139.2s
tomwalters@54 100 189.6p102.1s
tomwalters@54 101 192.7p116.7s
tomwalters@54 102 194.5p150.4s
tomwalters@54 103 198.1p97.9s
tomwalters@54 104 202.7p118.6s
tomwalters@54 105 208.6p93.2s
tomwalters@54 106 215.2p121.0s
tomwalters@54 107 EOF
tomwalters@54 108
tomwalters@54 109 echo "Generating script..."
tomwalters@54 110 exec 3> $FEATURES_DIR/$FULL_LIST
tomwalters@54 111 for syllable in $(cat $FEATURES_DIR/${SYLLIST}.tmp); do
tomwalters@54 112 for speaker in $(cat $FEATURES_DIR/${TALKERS}.tmp); do
tomwalters@54 113 SOURCE_FILENAME=$SOUND_SOURCE/$syllable/${syllable}${speaker}.wav
tomwalters@54 114 DEST_FILENAME=$FEATURES_DIR/$syllable/${syllable}${speaker}.htk
tomwalters@54 115 echo "$SOURCE_FILENAME ${DEST_FILENAME}" >&3
tomwalters@54 116 done
tomwalters@54 117 done
tomwalters@54 118 exec 3>&-
tomwalters@54 119
tomwalters@54 120 # Make the necessary directories for the computed features
tomwalters@54 121 echo "Making directory structure..."
tomwalters@54 122 for syllable in $(cat $FEATURES_DIR/${SYLLIST}.tmp); do
tomwalters@54 123 mkdir -p $FEATURES_DIR/$syllable
tomwalters@54 124 done
tomwalters@54 125
tomwalters@54 126 rm $FEATURES_DIR/$SYLLIST.tmp
tomwalters@54 127 rm $FEATURES_DIR/${TALKERS}.tmp
tomwalters@54 128 touch $FEATURES_DIR/.features_script_success
tomwalters@54 129 fi