hindi-sindhi-docker
/
mosesdecoder
/moses
/TranslationModel
/CYKPlusParser
/ChartRuleLookupManagerMemory.h
| /*********************************************************************** | |
| Moses - factored phrase-based language decoder | |
| Copyright (C) 2011 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 ChartParserCallback; | |
| class Range; | |
| //! Implementation of ChartRuleLookupManager for in-memory rule tables. | |
| class ChartRuleLookupManagerMemory : public ChartRuleLookupManagerCYKPlus | |
| { | |
| public: | |
| typedef std::vector<ChartCellCache> CompressedColumn; | |
| typedef std::vector<CompressedColumn> CompressedMatrix; | |
| ChartRuleLookupManagerMemory(const ChartParser &parser, | |
| const ChartCellCollectionBase &cellColl, | |
| const PhraseDictionaryMemory &ruleTable); | |
| ~ChartRuleLookupManagerMemory() {}; | |
| virtual void GetChartRuleCollection( | |
| const InputPath &inputPath, | |
| size_t lastPos, // last position to consider if using lookahead | |
| ChartParserCallback &outColl); | |
| private: | |
| void GetTerminalExtension( | |
| const PhraseDictionaryNodeMemory *node, | |
| size_t pos); | |
| void GetNonTerminalExtension( | |
| const PhraseDictionaryNodeMemory *node, | |
| size_t startPos); | |
| void AddAndExtend( | |
| const PhraseDictionaryNodeMemory *node, | |
| size_t endPos); | |
| void UpdateCompressedMatrix(size_t startPos, | |
| size_t endPos, | |
| size_t lastPos); | |
| const PhraseDictionaryMemory &m_ruleTable; | |
| // permissible soft nonterminal matches (target side) | |
| bool m_isSoftMatching; | |
| const std::vector<std::vector<Word> >& m_softMatchingMap; | |
| // temporary storage of completed rules (one collection per end position; all rules collected consecutively start from the same position) | |
| std::vector<CompletedRuleCollection> m_completedRules; | |
| size_t m_lastPos; | |
| size_t m_unaryPos; | |
| StackVec m_stackVec; | |
| std::vector<float> m_stackScores; | |
| std::vector<const Word*> m_sourceWords; | |
| ChartParserCallback* m_outColl; | |
| std::vector<CompressedMatrix> m_compressedMatrixVec; | |
| }; | |
| } // namespace Moses | |