HTK应用程序

源代码在线查看: wp_net.prl

软件大小: 2199 K
上传用户: yyjpu
关键词: HTK 应用程序
下载地址: 免注册下载 普通下载 VIP

相关代码

				#!/usr/local/bin/perl
				
				# This script will generate  word level networks for the word-pair test.
				# usage: wp_net.prl wp_gram_file nn nl
				#
				# TL 7/1998
				#
				
				$[ = 1;						# set array base to 1
				
				if ( $#ARGV != 4 ) {
					die "usage: wp_net.prl word-pair_grammar_file output_net_file nn nl\n";
				}
				
				$wp_file = $ARGV[1];
				if ( ! -f $wp_file ) {
					die "word-pair_grammar_file $wp_file not found.\n";
				}
				
				$net_file = $ARGV[2];
				$nn = $ARGV[3];
				$nl = $ARGV[4];
				
				open(NETFILE,">$net_file") or die "Can't open file $net_file\n";
				
				for ( $i=1; $i					open(WPFILE,"					while () {
					    chop;				# strip record separator
						/\*/ && next;		# skip comment line
					    @Fld = split(' ', $_, 9999);
					
						if ($#Fld == 0) {
							if ($ln > 990) {
							    $links = 1;
							}
							elsif (!$ln) {
							    printf NETFILE "N=%d L=%d\n", $nn, $nl;
							    $stwd = '!SENT_START';
							    printf NETFILE "I=%-4d W=%s\n", 0, $stwd;
							    $enwd = '!SENT_END';
							    $word = 'SENTENCE-END';
							    $num{$word} = 1;
							    $words{1} = $word;
							    printf NETFILE "I=%-4d W=%s\n", 1, $enwd;
							    $ln = 2;
							}
						}
						elsif ($links) {
							if (substr($Fld[1], 1, 1) eq '>') {
							    $word = substr($Fld[1], 2, length($Fld[1]) - 1);
							}
							else {
							    $like = -log($nfoll{$word});
							    if ($word eq 'SENTENCE-END') {
									printf NETFILE "J=%-5d S=%-4d E=%-4d l=%.4f\n", $la, 0, $num{$Fld[1]}, $like;
							    }
							    else {
									printf NETFILE "J=%-5d S=%-4d E=%-4d l=%.4f\n", $la, $num{$word}, $num{$Fld[1]}, $like;
							    }
							    $la++;
							}
						}
						elsif ($ln) {
							if (substr($Fld[1], 1, 1) eq '>') {
							    $word = substr($Fld[1], 2, length($Fld[1]) - 1);
							    $nfoll{$word} = 0;
							    if ($num{$word}) {
									$n = $num{$word};
							    }
							    else {
									$n = $ln;
									$num{$word} = $ln++;
									printf NETFILE "I=%-4d W=%s\n", $n, $word;
							    }
							}
							else {
							    $nfoll{$word}++;
							}
						}
					}
				}
				
				close(WPFILE);
				close(NETFILE);
							

相关资源