summaryrefslogtreecommitdiff
path: root/decoder/ff_klm.cc
diff options
context:
space:
mode:
authorChris Dyer <cdyer@cs.cmu.edu>2011-03-02 19:11:23 -0500
committerChris Dyer <cdyer@cs.cmu.edu>2011-03-02 19:11:23 -0500
commit0169e4df3e96540ee30f00408e42e087ce07afc4 (patch)
tree4eafea66e5a7d43ae3cff6ab5c395403baa81014 /decoder/ff_klm.cc
parent4e232d33e56d8f1980f72105c48eb47392544c0c (diff)
final version of SOS EOS handling, i think
Diffstat (limited to 'decoder/ff_klm.cc')
-rw-r--r--decoder/ff_klm.cc16
1 files changed, 11 insertions, 5 deletions
diff --git a/decoder/ff_klm.cc b/decoder/ff_klm.cc
index a12d4a2d..7c37ddb7 100644
--- a/decoder/ff_klm.cc
+++ b/decoder/ff_klm.cc
@@ -175,18 +175,24 @@ class KLanguageModelImpl {
return sum;
}
- //FIXME: this assumes no target words on final unary -> goal rule. is that ok?
+ // this assumes no target words on final unary -> goal rule. is that ok?
// for <s> (n-1 left words) and (n-1 right words) </s>
double FinalTraversalCost(const void* state) {
- if (add_sos_eos_) {
+ if (add_sos_eos_) { // rules do not produce <s> </s>, so do it here
SetRemnantLMState(ngram_->BeginSentenceState(), dummy_state_);
SetHasFullContext(1, dummy_state_);
SetUnscoredSize(0, dummy_state_);
dummy_ants_[1] = state;
return LookupWords(*dummy_rule_, dummy_ants_, NULL, NULL);
- } else {
- // TODO, figure out whether spans are correct
- return 0;
+ } else { // rules DO produce <s> ... </s>
+ double p = 0;
+ if (!GetFlag(state, HAS_EOS_ON_RIGHT)) { p -= 100; }
+ if (UnscoredSize(state) > 0) { // are there unscored words
+ if (kSOS_ != IthUnscoredWord(0, state)) {
+ p -= 100 * UnscoredSize(state);
+ }
+ }
+ return p;
}
}