#!/bin/bash

# Copyright 2018 Jarvan Wang Apache 2.0.

# Copyright 2016 Xiaohui Zhang Apache 2.0.

 
 

# This srcipt operates on lattice directories, such as exp/tri4a_lats

# the output is a new lat dir which has lattices from all the input lattice dirs

 
 

# Begin configuration section.

cmd=run.pl

extra_files=

num_jobs=4

# End configuration section.

echo "$0 $@" # Print the command line for logging

 
 

if [ -f path.sh ]; then . ./path.sh; fi

. parse_options.sh || exit 1;

 
 

if [[ $# -lt 3 ]]; then

echo "Usage: $0 [options] <data> <dest-lat-dir> <src-lat-dir1> <src-lat-dir2> ..."

echo "e.g.: $0 --num-jobs 32 data/train exp/tri3_lat_combined exp/tri3_lat_1 exp_tri3_lat_2"

echo "Options:"

echo " --extra-files <file1 file2...> # specify addtional files in 'src-lat-dir1' to copy"

echo " --num-jobs <nj> # number of jobs used to split the data directory."

echo " Note, files that don't appear in the first source dir will not be added even if they appear in later ones."

echo " Other than lattices, only files from the first src lat dir are copied."

exit 1;

fi

 
 

data=$1;

shift;

dest=$1;

shift;

first_src=$1;

 
 

mkdir -p $dest;

rm $dest/{lat.*.gz,num_jobs} 2>/dev/null

 
 

cp $first_src/phones.txt $dest 2>/dev/null

 
 

export LC_ALL=C

 
 

for dir in $*; do

if [ ! -f $dir/lat.1.gz ]; then

echo "$0: check if lattices (lat.*.gz) are present in $dir."

exit 1;

fi

done

 
 

for dir in $*; do

for f in tree; do

diff $first_src/$f $dir/$f 1>/dev/null 2>&1

if [ $? -ne 0 ]; then

echo "$0: Cannot combine lattice directories with different $f files."

fi

done

done

 
 

for f in final.mdl tree cmvn_opts num_jobs $extra_files; do

if [ ! -f $first_src/$f ]; then

echo "combine_lat_dir.sh: no such file $first_src/$f"

exit 1;

fi

cp $first_src/$f $dest/

done

 
 

src_id=0

temp_dir=$dest/temp

[ -d $temp_dir ] && rm -r $temp_dir;

mkdir -p $temp_dir

echo "$0: dumping lattices in each source directory as single archive and index."

for dir in $*; do

src_id=$((src_id + 1))

cur_num_jobs=$(cat $dir/num_jobs) || exit 1;

lats=$(for n in $(seq $cur_num_jobs); do echo -n "$dir/lat.$n.gz "; done)

$cmd $dir/log/copy_lattices.log \

lattice-copy "ark:gunzip -c $lats|" \

ark,scp:$temp_dir/lat.$src_id.ark,$temp_dir/lat.$src_id.scp || exit 1;

done

sort -m $temp_dir/lat.*.scp > $temp_dir/lat.scp || exit 1;

 
 

echo "$0: splitting data to get reference utt2spk for individual lat.JOB.gz files."

utils/split_data.sh $data $num_jobs || exit 1;

 
 

echo "$0: splitting the lattices to appropriate chunks according to the reference utt2spk files."

utils/filter_scps.pl JOB=1:$num_jobs \

$data/split$num_jobs/JOB/utt2spk $temp_dir/lat.scp $temp_dir/lat.JOB.scp

 
 

for i in `seq 1 $num_jobs`; do

lattice-copy scp:$temp_dir/lat.${i}.scp "ark:|gzip -c >$dest/lat.$i.gz" || exit 1;

done

 
 

echo $num_jobs > $dest/num_jobs || exit 1

 
 

echo "$0: checking the lattice files generated have at least 90% of the utterances."

for i in `seq 1 $num_jobs`; do

num_lines=`cat $temp_dir/lat.$i.scp | wc -l` || exit 1;

num_lines_tot=`cat $data/split$num_jobs/$i/utt2spk | wc -l` || exit 1;

python -c "import sys;

percent = 100.0 * float($num_lines) / $num_lines_tot

if percent < 90 :

print ('$dest/lat.$i.gz {0}% utterances missing.'.format(percent))" || exit 1;

done

rm -r $temp_dir 2>/dev/null

 
 

echo "Combined lattices and stored in $dest"

exit 0

combine_lat_dirs.sh的更多相关文章

  1. 数据库备份并分离日志表(按月)sh 脚本

    #!/bin/sh year=`date +%Y` month=`date +%m` day=`date +%d` hour=`date +%H` dir="/data/dbbackup/f ...

  2. Linux下如何查找.sh后缀的文件

    find / -name *.sh或locate *.shfind 与locate的区别:locate 配合数据库查看文件位置 find 实际搜寻硬盘查询文件名称

  3. sh 测试网段在线主机

    yum install nmap nmap -sP  192.168.21.1/24 查看网段在线主机 grep -vwf file1 file2 文件内容比较 #!/bin/bash # day=` ...

  4. Maven打包生成可运行bat/sh脚本文件

    利用Maven的appassembler-maven-plugin插件,就可以实现自动打包可运行的脚本,还可以跨平台.   <plugin>      <groupId>org ...

  5. 记一个简单的保护if 的sh脚本

    真是坑爹,就下面的sh,竟然也写了很久! if [ `pwd` != '/usr/xx/bin/tomcat' ] then echo "rstall is not allowed in c ...

  6. 主机巡检脚本:OSWatcher.sh

    主机巡检脚本:OSWatcher.sh 2016-09-26更新,目前该脚本只支持Linux操作系统,后续有需求可以继续完善. 注意: 经测试,普通用户执行脚本可以顺利执行前9项检查: 第10项,普通 ...

  7. Oracle巡检脚本:ORAWatcher.sh

    Oracle巡检脚本:ORAWatcher.sh #!/usr/bin/ksh echo "" echo "ORAWatcher Version:1.0.1" ...

  8. 解决:/bin/sh: 1: /home/**/custom_app.sh: Permission denied错误

    出现如下错误,一般是执行权限不够. /bin/sh: : /home/custom_app.sh: Permission denied 解决方法是:cd 到此文件目录,对提示的文件赋予可执行权限或读写 ...

  9. SH Script Grammar

    http://linux.about.com/library/cmd/blcmdl1_sh.htm http://pubs.opengroup.org/onlinepubs/9699919799/ut ...

随机推荐

  1. Java基础系列--07_String、StringBuffer和StringBuilder

    String类  (1)字符串:字符串是常量:它们的值在创建之后不能更改,存储在堆中.          如果字符串多次赋值,其实是每次重新赋值的时候程序都先在内存中寻找已开辟的空间是否存在该值;如果 ...

  2. 解决FileZilla访问手机ftp服务只能删除浏览文件不能下载文件的问题

    用了Linux系统之后,很多资源都不方便获取, 因为很多资料都是放在百某某盘上面. 无意中看到我手机有FTP服务,想到我电脑装有FileZilla,可以访问手机了 然后就连接上了. 但是浏览的时候发现 ...

  3. 【spring源码分析】IOC容器初始化(六)

    前言:经过前几篇文章的讲解,我们已经得到了BeanDefinition,接下来将分析Bean的加载. 获取Bean的入口:AbstractApplicationContext#getBean publ ...

  4. Educational Codeforces Round 60 (Rated for Div. 2) - D. Magic Gems(动态规划+矩阵快速幂)

    Problem   Educational Codeforces Round 60 (Rated for Div. 2) - D. Magic Gems Time Limit: 3000 mSec P ...

  5. day20 hashlib、hmac、subprocess、configparser模块

    hashlib模块:加密 import hashlib# 基本使用cipher = hashlib.md5('需要加密的数据的二进制形式'.encode('utf-8'))print(cipher.h ...

  6. (转)sizeof()和_countof()区别

    先看程序: #include <iostream> using namespace std; int main(int argc, char* argv[]) { char *a = &q ...

  7. python上下文管理

    一.python上下文介绍: python中的上下文,指的就是代码所执行的环境状态,或者运行的场景 python上下文管理器规定了某个对象的使用范围,当进入或者离开了使用范围,会有相应的操作,多用于资 ...

  8. jeecg入门操作—树型表单开发

    树表类型表单 表单创建,基础配置如下: 1.设置表单类型为:单表; 2.是否树选择:是; 3.设置特殊字段:[树形表单父id][树开表单列] 结果测试

  9. Web 项目系列之浏览器机制(一)

    目录: ——初步认识浏览器 ——浏览器的渲染机制   ——浏览器的缓存机制 正文: 初步认识浏览器 想来任何一位读者,对浏览器都不会陌生.除开IT相关人员常用的Chrome(谷歌,Google).Fi ...

  10. jexus独立版设置支持https

    先用命令找到libssl.so find / -name libssl.so.* 执行完命令之后找到libssl.so.x.x.x如(libssl.so.1.0.0) 再到jexus/runtime/ ...