summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--decoder/hg_intersect.cc2
-rw-r--r--decoder/tree2string_translator.cc6
2 files changed, 5 insertions, 3 deletions
diff --git a/decoder/hg_intersect.cc b/decoder/hg_intersect.cc
index 31a9a1ce..02f5a401 100644
--- a/decoder/hg_intersect.cc
+++ b/decoder/hg_intersect.cc
@@ -92,7 +92,7 @@ bool Intersect(const Lattice& target, Hypergraph* hg) {
return FastLinearIntersect(target, hg);
vector<bool> rem(hg->edges_.size(), false);
- const RuleFilter filter(target, 15); // TODO make configurable
+ const RuleFilter filter(target, 9999); // TODO make configurable
for (unsigned i = 0; i < rem.size(); ++i)
rem[i] = filter(*hg->edges_[i].rule_);
hg->PruneEdges(rem, true);
diff --git a/decoder/tree2string_translator.cc b/decoder/tree2string_translator.cc
index c353f7ca..fafb0d97 100644
--- a/decoder/tree2string_translator.cc
+++ b/decoder/tree2string_translator.cc
@@ -128,12 +128,14 @@ namespace std {
void AddDummyGoalNode(Hypergraph* hg) {
static const int kGOAL = -TD::Convert("Goal");
- static TRulePtr kGOAL_RULE(new TRule("[Goal] ||| [X] ||| [1]"));
unsigned old_goal_node_idx = hg->nodes_.size() - 1;
+ int old_goal_cat = hg->nodes_[old_goal_node_idx].cat_;
+ TRulePtr goal_rule(new TRule("[Goal] ||| [X] ||| [1]"));
+ goal_rule->f_[0] = old_goal_cat;
HG::Node* goal_node = hg->AddNode(kGOAL);
goal_node->node_hash = 1;
TailNodeVector tail(1, old_goal_node_idx);
- HG::Edge* new_edge = hg->AddEdge(kGOAL_RULE, tail);
+ HG::Edge* new_edge = hg->AddEdge(goal_rule, tail);
hg->ConnectEdgeToHeadNode(new_edge, goal_node);
}