summaryrefslogtreecommitdiff
path: root/decoder/bottom_up_parser-rs.h
diff options
context:
space:
mode:
authorChris Dyer <redpony@gmail.com>2014-11-30 21:30:09 -0500
committerChris Dyer <redpony@gmail.com>2014-11-30 21:30:09 -0500
commitc915af2347a676b1f3b11dc4c0865c4bdb7ca609 (patch)
tree72dc3086c28e6b5e86e678ff005dc4393abdaa02 /decoder/bottom_up_parser-rs.h
parent2d684c9e3f5478d1aec7374824f94a5d6a761d07 (diff)
implementation of Rico Sennrich's CKY+ variant; it currently doesn't support span limits so it is not enabled, but it seems to be functional.
Diffstat (limited to 'decoder/bottom_up_parser-rs.h')
-rw-r--r--decoder/bottom_up_parser-rs.h29
1 files changed, 29 insertions, 0 deletions
diff --git a/decoder/bottom_up_parser-rs.h b/decoder/bottom_up_parser-rs.h
new file mode 100644
index 00000000..2e271e99
--- /dev/null
+++ b/decoder/bottom_up_parser-rs.h
@@ -0,0 +1,29 @@
+#ifndef RSBOTTOM_UP_PARSER_H_
+#define RSBOTTOM_UP_PARSER_H_
+
+#include <vector>
+#include <string>
+
+#include "lattice.h"
+#include "grammar.h"
+
+class Hypergraph;
+
+// implementation of Sennrich (2014) parser
+// http://aclweb.org/anthology/W/W14/W14-4011.pdf
+class RSExhaustiveBottomUpParser {
+ public:
+ RSExhaustiveBottomUpParser(const std::string& goal_sym,
+ const std::vector<GrammarPtr>& grammars);
+
+ // returns true if goal reached spanning the full input
+ // forest contains the full (i.e., unpruned) parse forest
+ bool Parse(const Lattice& input,
+ Hypergraph* forest) const;
+
+ private:
+ const std::string goal_sym_;
+ const std::vector<GrammarPtr> grammars_;
+};
+
+#endif