summaryrefslogtreecommitdiff
path: root/decoder
diff options
context:
space:
mode:
authorChris Dyer <redpony@gmail.com>2014-05-17 17:53:53 -0400
committerChris Dyer <redpony@gmail.com>2014-05-17 17:53:53 -0400
commit0026ae2bf5417401af9cf3c1dd357def5ae23e0a (patch)
tree9896ef74a811f69ff3489e6203955e6e8fb67c8e /decoder
parentc2d83e45cb079b1724772034663c4414cba06160 (diff)
check for duplicates when creating pass through rules
Diffstat (limited to 'decoder')
-rw-r--r--decoder/tree2string_translator.cc11
1 files changed, 9 insertions, 2 deletions
diff --git a/decoder/tree2string_translator.cc b/decoder/tree2string_translator.cc
index 101ed21c..8d624820 100644
--- a/decoder/tree2string_translator.cc
+++ b/decoder/tree2string_translator.cc
@@ -167,9 +167,8 @@ struct Tree2StringTranslatorImpl {
root.resize(root.size() + 1);
root.back().reset(new Tree2StringGrammarNode);
++remove_grammars;
+ unordered_set<vector<unsigned>,boost::hash<vector<unsigned>>> unique_rule_check;
for (auto& prod : tree.nodes) {
- ostringstream os;
- vector<int> rhse, rhsf;
int ntc = 0;
int lhs = -(prod.lhs & cdec::ALL_MASK);
int &ntfid = pntfid[lhs];
@@ -178,8 +177,16 @@ struct Tree2StringTranslatorImpl {
fos << "PassThrough:" << TD::Convert(-lhs);
ntfid = FD::Convert(fos.str());
}
+
+ // check for duplicate rule in tree
+ vector<unsigned> key = prod.rhs;
+ key.push_back(prod.lhs);
+ if (!unique_rule_check.insert(key).second) continue;
+
bool has_lex = false;
bool has_nt = false;
+ vector<int> rhse, rhsf;
+ ostringstream os;
os << '(' << TD::Convert(-lhs);
for (auto& sym : prod.rhs) {
os << ' ';