| /*********************************************************************** | |
| Moses - statistical machine translation system | |
| Copyright (C) 2006-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 search | |
| { | |
| class Vertex; | |
| } | |
| namespace Moses | |
| { | |
| class Word; | |
| /** Contains a range, word (non-terms?) and a vector of hypotheses. | |
| * @todo This is probably incompatible with lattice decoding when the word that spans | |
| * a position (or positions) can vary. | |
| * @todo is this to hold sorted hypotheses that are in the queue for creating the next hypos? | |
| */ | |
| class ChartCellLabel | |
| { | |
| public: | |
| union Stack { | |
| const HypoList *cube; // cube pruning | |
| search::Vertex *incr; // incremental search after filling. | |
| void *incr_generator; // incremental search during filling. | |
| }; | |
| ChartCellLabel(const Range &coverage, const Word &label, | |
| Stack stack=Stack()) | |
| : m_coverage(coverage) | |
| , m_label(label) | |
| , m_stack(stack) | |
| , m_bestScore(0) { | |
| } | |
| const Range &GetCoverage() const { | |
| return m_coverage; | |
| } | |
| const Word &GetLabel() const { | |
| return m_label; | |
| } | |
| Stack GetStack() const { | |
| return m_stack; | |
| } | |
| Stack &MutableStack() { | |
| return m_stack; | |
| } | |
| //caching of best score on stack | |
| float GetBestScore(const ChartParserCallback *outColl) const { | |
| if (m_bestScore == 0) { | |
| m_bestScore = outColl->GetBestScore(this); | |
| } | |
| return m_bestScore; | |
| } | |
| private: | |
| const Range &m_coverage; | |
| const Word &m_label; | |
| //const InputPath &m_inputPath; | |
| Stack m_stack; | |
| mutable float m_bestScore; | |
| }; | |
| } | |