HDMan命令

HDMan命令的主要功能是从多个输入生成发音字典。它支持在脚本中编辑命令行功能,就是可以按照定制好的方式生成发音字典。

         每个编辑命令在脚本中都是单独的一行,如果HDMan命令没有任何的脚本编辑命令指定,该命令就将输入简单的排序并输出。每个输入字典文件都对应一个编辑命令脚本文件,如输入字典文件为example.dict,那么在指定的目录下可以存放编辑命令脚本文件example.ded,当然,如果没有这个脚本文件,最多也就警告,不会出错的。另外有一个特殊的脚本文件global.ded,这个脚本是针对合成之后的字典文件。

         如果多个输入文件指定同一个单词的不同发音,此时默认的行为是第一个有效,后面的都会被忽略 。

 

1,  脚本文件命令

 

         脚本文件有如下编辑命令:

1.        AS A B 。添加静音模型A和B。

2.        RS system 去掉重音标记。

3.        MP X A B 。 在等待合成的发音序列中,如果出现A B,重新命名为X

4.        RW X A B 在单词中出现A或者B,将其替换为X

5.        RP X A B ,在发音序列中,如果出现A或者B,替换为X

6.        UP。转换所有的发音序列为大写。

7.        UW。转换所有的单词为大写。

8.        SP X A B ,将发音X分成新的发音序列A B

当然,除了上面的命令之外,其他还有。

 

2,  命令用法

HDMan [options]newDict strDict1 strDict2 …

从strDict1 strDict2中读取发音字典,并重新生成新的发音字典newDict。

常用选项如下:

1,  -m 。前面说了这个命令如果碰到一个单词在多个输入文件中定义发音,则会忽略第一个之后的所有发音,但添加这个选项之后,就会将所有发音全部输出。

2,  -w file。加载单词列表文件,file中存储了很多个单词,这个选项会控制输出的大小,如输入的发音文件有1000个单词,但列表文件中仅仅有10个,此时输出的发音文件中包含10个单词的发音。

3,  -e dir。这个选项指定一个目录,这个目录是编辑命令脚本存储的路径。

4,  -n file,这会输出一个单音列表,就是在单词列表中的单词的单音,而不是所有发音输入的单音。

5,  -l file。日志

 

其它还有一些选项,主要是控制从多个发单文件(当然也可以是一个文件)中生成一个新的发音文件,可以按照我们指定的要求来生成,

3,  使用例子

HDMan -A -D -T 1 -m -w ./wlist -e ./input_files -n ./monophones-i -l logs/ HDMan_log ./ dict ./lexicon/lexicon

上面的例子中-A –D –T是标准的选项,大部分HTK命令行工具都有这个选项。另外还有-C –V和-S也是标准选项。C表示配置文件,S表示使用指定的脚本文件名,A表示当前的命令行参数会被打印。D表示输出显示配置信息。T表示Trace,一般的每个命令都有一些Trace配置参数,如上面的命令中使用-T 1表示Trace的信息是基本的程序执行进度报告。

后面的./dict为输出文件,而./lexicon/lexicon表示输入的发音文件。

你可能感兴趣的:(HDMan命令)