| /*********************************************************************** | |
| Moses - statistical machine translation system | |
| Copyright (C) 2006-2012 University of Edinburgh | |
| This library is free software; you can redistribute it and/or | |
| modify it under the terms of the GNU Lesser General Public | |
| License as published by the Free Software Foundation; either | |
| version 2.1 of the License, or (at your option) any later version. | |
| This library is distributed in the hope that it will be useful, | |
| but WITHOUT ANY WARRANTY; without even the implied warranty of | |
| MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |
| Lesser General Public License for more details. | |
| You should have received a copy of the GNU Lesser General Public | |
| License along with this library; if not, write to the Free Software | |
| Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA | |
| ***********************************************************************/ | |
| namespace Moses | |
| { | |
| class Phrase; | |
| class TargetPhrase; | |
| class Word; | |
| class ChartParser; | |
| /** Implementation of RuleTableTrie. A RuleTableUTrie is designed to store | |
| * string-to-tree SCFG grammars only (i.e. rules can have distinct labels on | |
| * the target side, but only a generic non-terminal on the source side). | |
| * A key is the source RHS (one symbol per edge) of a rule and a mapped value | |
| * is the collection of grammar rules that share the same source RHS. | |
| * | |
| * (The 'U' in UTrie stands for 'unlabelled' -- the keys are unlabelled and | |
| * the target labels are stored on the node values, as opposed to the grammar | |
| * being a monolingual projection with target labels projected onto the source | |
| * side.) | |
| */ | |
| class RuleTableUTrie : public RuleTableTrie | |
| { | |
| public: | |
| RuleTableUTrie(const std::string &line) | |
| : RuleTableTrie(line) { | |
| } | |
| const UTrieNode &GetRootNode() const { | |
| return m_root; | |
| } | |
| ChartRuleLookupManager *CreateRuleLookupManager(const ChartParser &, | |
| const ChartCellCollectionBase &, std::size_t); | |
| private: | |
| TargetPhraseCollection::shared_ptr | |
| GetOrCreateTargetPhraseCollection(const Phrase &source, | |
| const TargetPhrase &target, | |
| const Word *sourceLHS); | |
| UTrieNode &GetOrCreateNode(const Phrase &source, const TargetPhrase &target, | |
| const Word *sourceLHS); | |
| void SortAndPrune(); | |
| UTrieNode m_root; | |
| }; | |
| } // namespace Moses | |