| | #pragma once |
| |
|
| | #include <iostream> |
| | #include <string> |
| | #include <map> |
| | #include <vector> |
| | #include <boost/shared_ptr.hpp> |
| | #include <boost/make_shared.hpp> |
| | #include "util/generator.hh" |
| | #include "util/exception.hh" |
| |
|
| | namespace MosesTuning |
| | { |
| |
|
| | class InternalTree; |
| | typedef boost::shared_ptr<InternalTree> TreePointer; |
| | typedef int NTLabel; |
| |
|
| | class InternalTree |
| | { |
| | std::string m_value; |
| | std::vector<TreePointer> m_children; |
| | bool m_isTerminal; |
| | public: |
| | InternalTree(const std::string & line, const bool terminal = false); |
| | InternalTree(const InternalTree & tree): |
| | m_value(tree.m_value), |
| | m_isTerminal(tree.m_isTerminal) { |
| | const std::vector<TreePointer> & children = tree.m_children; |
| | for (std::vector<TreePointer>::const_iterator it = children.begin(); it != children.end(); it++) { |
| | m_children.push_back(boost::make_shared<InternalTree>(**it)); |
| | } |
| | } |
| | size_t AddSubTree(const std::string & line, size_t start); |
| |
|
| | std::string GetString(bool start = true) const; |
| | void Combine(const std::vector<TreePointer> &previous); |
| | const std::string & GetLabel() const { |
| | return m_value; |
| | } |
| |
|
| | size_t GetLength() const { |
| | return m_children.size(); |
| | } |
| | std::vector<TreePointer> & GetChildren() { |
| | return m_children; |
| | } |
| |
|
| | bool IsTerminal() const { |
| | return m_isTerminal; |
| | } |
| |
|
| | bool IsLeafNT() const { |
| | return (!m_isTerminal && m_children.size() == 0); |
| | } |
| | }; |
| |
|
| | |
| | $generator(leafNT) |
| | { |
| | std::vector<TreePointer>::iterator it; |
| | InternalTree* tree; |
| | leafNT(InternalTree* root = 0): tree(root) {} |
| | $emit(std::vector<TreePointer>::iterator) |
| | for (it = tree->GetChildren().begin(); it !=tree->GetChildren().end(); ++it) { |
| | if (!(*it)->IsTerminal() && (*it)->GetLength() == 0) { |
| | $yield(it); |
| | } else if ((*it)->GetLength() > 0) { |
| | if ((*it).get()) { |
| | $restart(tree = (*it).get()); |
| | } |
| | } |
| | } |
| | $stop; |
| | }; |
| |
|
| | } |