#!/usr/bin/perl -w use strict; my $ADD_FCLASS_JUMP = 1; my $ADD_MODEL2_BINARY = 0; my $ADD_FC_RELPOS = 1; my ($f_classes) = @ARGV; die "Usage: $0 f-classes.file" unless $f_classes && -f $f_classes; print <<EOT; MarkovJump 0 RelativeSentencePosition 0 EOT # ! 8 # " 11 # 's 18 my %dcats = (); $dcats{'BOS'} = 1; $dcats{'EOS'} = 1; open FC, "<$f_classes" or die; while(<FC>) { chomp; my ($x, $cat) = split /\s+/; $dcats{$cat} = 1; } my @cats = sort keys %dcats; my $added = 0; for (my $i=0; $i < scalar @cats; $i++) { my $c1 = $cats[$i]; for (my $j=0; $j < scalar @cats; $j++) { my $c2 = $cats[$j]; print "SP:${c1}_${c2} 0\n"; $added++; } } for (my $ss=1; $ss < 100; $ss++) { if ($ADD_FCLASS_JUMP) { for (my $i=0; $i < scalar @cats; $i++) { my $cat = $cats[$i]; for (my $j = -$ss; $j <= $ss; $j++) { print "Jump_FL:${ss}_FC:${cat}_J:$j 0\n"; $added++; } } } if ($ADD_MODEL2_BINARY) { # M2_FL:8_SI:3_TI:2=1 for (my $i = 0; $i < $ss; $i++) { for (my $j = 0; $j < 100; $j++) { print "M2FL:${ss}:TI:${j}_SI:${i} 0\n"; $added++; } } } } if ($ADD_FC_RELPOS) { #RelPos_FC:11 for (my $i=0; $i < scalar @cats; $i++) { my $cat = $cats[$i]; print "RelPos_FC:$cat 0\n"; $added++; } } print STDERR "Added $added weights\n";