mirror of
https://github.com/moses-smt/mosesdecoder.git
synced 2024-12-27 22:14:57 +03:00
162 lines
5.8 KiB
C++
162 lines
5.8 KiB
C++
// $Id$
|
|
|
|
/***********************************************************************
|
|
Moses - factored phrase-based language decoder
|
|
Copyright (C) 2006 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
|
|
***********************************************************************/
|
|
|
|
#ifndef moses_TranslationOptionCollection_h
|
|
#define moses_TranslationOptionCollection_h
|
|
|
|
#include <list>
|
|
#include <boost/unordered_map.hpp>
|
|
#include "TypeDef.h"
|
|
#include "TranslationOption.h"
|
|
#include "TranslationOptionList.h"
|
|
#include "SquareMatrix.h"
|
|
#include "WordsBitmap.h"
|
|
#include "PartialTranslOptColl.h"
|
|
#include "DecodeStep.h"
|
|
|
|
namespace Moses
|
|
{
|
|
|
|
class LanguageModel;
|
|
class FactorCollection;
|
|
class PhraseDictionaryMemory;
|
|
class GenerationDictionary;
|
|
class InputType;
|
|
class LMList;
|
|
class FactorMask;
|
|
class Word;
|
|
class DecodeGraph;
|
|
|
|
/** Contains all phrase translations applicable to current input type (a sentence or confusion network).
|
|
* A key insight into efficient decoding is that various input
|
|
* conditions (trelliss, factored input, normal text, xml markup)
|
|
* all lead to the same decoding algorithm: hypotheses are expanded
|
|
* by applying phrase translations, which can be precomputed.
|
|
*
|
|
* The precomputation of a collection of instances of such TranslationOption
|
|
* depends on the input condition, but they all are presented to
|
|
* decoding algorithm in the same form, using this class.
|
|
*
|
|
* This is a abstract class, and cannot be instantiated directly. Instantiate 1 of the inherited
|
|
* classes instead, for a particular input type
|
|
**/
|
|
class TranslationOptionCollection
|
|
{
|
|
friend std::ostream& operator<<(std::ostream& out, const TranslationOptionCollection& coll);
|
|
TranslationOptionCollection(const TranslationOptionCollection&); /*< no copy constructor */
|
|
protected:
|
|
const TranslationSystem* m_system;
|
|
std::vector< std::vector< TranslationOptionList > > m_collection; /*< contains translation options */
|
|
InputType const &m_source; /*< reference to the input */
|
|
SquareMatrix m_futureScore; /*< matrix of future costs for contiguous parts (span) of the input */
|
|
const size_t m_maxNoTransOptPerCoverage; /*< maximum number of translation options per input span */
|
|
const float m_translationOptionThreshold; /*< threshold for translation options with regard to best option for input span */
|
|
std::vector<Phrase*> m_unksrcs;
|
|
boost::unordered_map<TranslationOption,ScoreComponentCollection> m_precalculatedScores;
|
|
|
|
|
|
TranslationOptionCollection(const TranslationSystem* system, InputType const& src, size_t maxNoTransOptPerCoverage,
|
|
float translationOptionThreshold);
|
|
|
|
void CalcFutureScore();
|
|
|
|
//! Force a creation of a translation option where there are none for a particular source position.
|
|
void ProcessUnknownWord();
|
|
//! special handling of ONE unknown words.
|
|
virtual void ProcessOneUnknownWord(const Word &sourceWord, size_t sourcePos, size_t length = 1, const Scores *inputScores = NULL);
|
|
|
|
void IncorporateDLMScores();
|
|
|
|
//! pruning: only keep the top n (m_maxNoTransOptPerCoverage) elements */
|
|
void Prune();
|
|
|
|
//! sort all trans opt in each list for cube pruning */
|
|
void Sort();
|
|
|
|
//! list of trans opt for a particular span
|
|
TranslationOptionList &GetTranslationOptionList(size_t startPos, size_t endPos);
|
|
const TranslationOptionList &GetTranslationOptionList(size_t startPos, size_t endPos) const;
|
|
void Add(TranslationOption *translationOption);
|
|
|
|
//! implemented by inherited class, called by this class
|
|
virtual void ProcessUnknownWord(size_t sourcePos)=0;
|
|
|
|
|
|
|
|
void CacheLexReordering();
|
|
|
|
//! Pre-calculate most stateless feature values
|
|
void PreCalculateScores();
|
|
|
|
public:
|
|
virtual ~TranslationOptionCollection();
|
|
|
|
//! input sentence/confusion network
|
|
const InputType& GetSource() const {
|
|
return m_source;
|
|
}
|
|
|
|
//!List of unknowns (OOVs)
|
|
const std::vector<Phrase*>& GetUnknownSources() const;
|
|
|
|
//! get length/size of source input
|
|
size_t GetSize() const {
|
|
return m_source.GetSize();
|
|
};
|
|
|
|
//! Create all possible translations from the phrase tables
|
|
virtual void CreateTranslationOptions();
|
|
//! Create translation options that exactly cover a specific input span.
|
|
virtual void CreateTranslationOptionsForRange(const DecodeGraph &decodeStepList
|
|
, size_t startPosition
|
|
, size_t endPosition
|
|
, bool adhereTableLimit
|
|
, size_t graphInd);
|
|
|
|
//!Check if this range has XML options
|
|
virtual bool HasXmlOptionsOverlappingRange(size_t startPosition, size_t endPosition) const;
|
|
|
|
//! Create xml-based translation options for the specific input span
|
|
virtual void CreateXmlOptionsForRange(size_t startPosition, size_t endPosition);
|
|
|
|
|
|
//! returns future cost matrix for sentence
|
|
inline virtual const SquareMatrix &GetFutureScore() const {
|
|
return m_futureScore;
|
|
}
|
|
|
|
//! list of trans opt for a particular span
|
|
const TranslationOptionList &GetTranslationOptionList(const WordsRange &coverage) const {
|
|
return GetTranslationOptionList(coverage.GetStartPos(), coverage.GetEndPos());
|
|
}
|
|
|
|
//! Access these pre-calculated values
|
|
void InsertPreCalculatedScores(const TranslationOption& translationOption,
|
|
ScoreComponentCollection* scoreBreakdown) const;
|
|
|
|
TO_STRING();
|
|
};
|
|
|
|
}
|
|
|
|
#endif
|
|
|