2010-01-27 17:10:50 +03:00
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <vector>
|
|
|
|
#include <string>
|
|
|
|
|
|
|
|
#include "FFState.h"
|
|
|
|
#include "Hypothesis.h"
|
2010-02-11 20:08:24 +03:00
|
|
|
#include "LexicalReordering.h"
|
2010-01-27 17:10:50 +03:00
|
|
|
#include "WordsRange.h"
|
2010-01-27 20:10:35 +03:00
|
|
|
#include "WordsBitmap.h"
|
2010-01-27 17:10:50 +03:00
|
|
|
#include "ReorderingStack.h"
|
2010-02-11 20:08:24 +03:00
|
|
|
#include "TranslationOption.h"
|
2010-01-27 17:10:50 +03:00
|
|
|
|
|
|
|
|
|
|
|
namespace Moses
|
|
|
|
{
|
2010-02-11 20:08:24 +03:00
|
|
|
class LexicalReorderingState;
|
2011-11-09 01:22:34 +04:00
|
|
|
class LexicalReordering;
|
2010-02-11 20:08:24 +03:00
|
|
|
|
2012-06-27 03:45:02 +04:00
|
|
|
/** Factory class for lexical reordering states
|
|
|
|
* @todo There's a lot of classes for lexicalized reordering. Perhaps put them in a separate dir
|
|
|
|
*/
|
2011-02-24 16:14:42 +03:00
|
|
|
class LexicalReorderingConfiguration
|
|
|
|
{
|
|
|
|
public:
|
2011-11-09 01:22:34 +04:00
|
|
|
friend class LexicalReordering;
|
2011-02-24 16:14:42 +03:00
|
|
|
enum ModelType {Monotonic, MSD, MSLR, LeftRight, None};
|
|
|
|
enum Direction {Forward, Backward, Bidirectional};
|
|
|
|
enum Condition {F, E, FE};
|
|
|
|
|
2011-11-09 01:22:34 +04:00
|
|
|
LexicalReorderingConfiguration(const std::string &modelType);
|
2011-02-24 16:14:42 +03:00
|
|
|
|
|
|
|
LexicalReorderingState *CreateLexicalReorderingState(const InputType &input) const;
|
|
|
|
|
|
|
|
size_t GetNumScoreComponents() const;
|
2011-08-19 20:09:36 +04:00
|
|
|
void SetAdditionalScoreComponents(size_t number);
|
2011-02-24 16:14:42 +03:00
|
|
|
size_t GetNumberOfTypes() const;
|
|
|
|
|
|
|
|
ScoreProducer *GetScoreProducer() const {
|
|
|
|
return m_scoreProducer;
|
|
|
|
}
|
|
|
|
|
2011-11-09 01:22:34 +04:00
|
|
|
|
2011-02-24 16:14:42 +03:00
|
|
|
ModelType GetModelType() const {
|
|
|
|
return m_modelType;
|
|
|
|
}
|
|
|
|
|
|
|
|
Direction GetDirection() const {
|
|
|
|
return m_direction;
|
|
|
|
}
|
|
|
|
|
|
|
|
Condition GetCondition() const {
|
|
|
|
return m_condition;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool IsPhraseBased() const {
|
|
|
|
return m_phraseBased;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool CollapseScores() const {
|
|
|
|
return m_collapseScores;
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
2011-11-09 01:22:34 +04:00
|
|
|
void SetScoreProducer(ScoreProducer* scoreProducer) {
|
|
|
|
m_scoreProducer = scoreProducer;
|
|
|
|
}
|
|
|
|
|
|
|
|
const std::string& GetModelString() const {
|
|
|
|
return m_modelString;
|
|
|
|
}
|
|
|
|
|
|
|
|
std::string m_modelString;
|
2011-02-24 16:14:42 +03:00
|
|
|
ScoreProducer *m_scoreProducer;
|
|
|
|
ModelType m_modelType;
|
|
|
|
bool m_phraseBased;
|
|
|
|
bool m_collapseScores;
|
|
|
|
Direction m_direction;
|
|
|
|
Condition m_condition;
|
2011-08-19 20:09:36 +04:00
|
|
|
size_t m_additionalScoreComponents;
|
2010-02-11 20:08:24 +03:00
|
|
|
};
|
|
|
|
|
2011-02-24 16:14:42 +03:00
|
|
|
//! Abstract class for lexical reordering model states
|
|
|
|
class LexicalReorderingState : public FFState
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
virtual int Compare(const FFState& o) const = 0;
|
|
|
|
virtual LexicalReorderingState* Expand(const TranslationOption& hypo, Scores& scores) const = 0;
|
|
|
|
|
|
|
|
static LexicalReorderingState* CreateLexicalReorderingState(const std::vector<std::string>& config,
|
|
|
|
LexicalReorderingConfiguration::Direction dir, const InputType &input);
|
|
|
|
|
|
|
|
protected:
|
|
|
|
typedef int ReorderingType;
|
|
|
|
|
2011-11-09 01:22:34 +04:00
|
|
|
|
2011-02-24 16:14:42 +03:00
|
|
|
const LexicalReorderingConfiguration &m_configuration;
|
|
|
|
// The following is the true direction of the object, which can be Backward or Forward even if the Configuration has Bidirectional.
|
|
|
|
LexicalReorderingConfiguration::Direction m_direction;
|
|
|
|
size_t m_offset;
|
|
|
|
const Scores *m_prevScore;
|
|
|
|
|
|
|
|
inline LexicalReorderingState(const LexicalReorderingState *prev, const TranslationOption &topt) :
|
|
|
|
m_configuration(prev->m_configuration), m_direction(prev->m_direction), m_offset(prev->m_offset),
|
|
|
|
m_prevScore(topt.GetCachedScores(m_configuration.GetScoreProducer())) {}
|
|
|
|
|
|
|
|
inline LexicalReorderingState(const LexicalReorderingConfiguration &config, LexicalReorderingConfiguration::Direction dir, size_t offset)
|
|
|
|
: m_configuration(config), m_direction(dir), m_offset(offset), m_prevScore(NULL) {}
|
|
|
|
|
|
|
|
// copy the right scores in the right places, taking into account forward/backward, offset, collapse
|
|
|
|
void CopyScores(Scores& scores, const TranslationOption& topt, ReorderingType reoType) const;
|
|
|
|
void ClearScores(Scores& scores) const;
|
|
|
|
int ComparePrevScores(const Scores *other) const;
|
|
|
|
|
|
|
|
//constants for the different type of reorderings (corresponding to indexes in the table file)
|
|
|
|
static const ReorderingType M = 0; // monotonic
|
|
|
|
static const ReorderingType NM = 1; // non-monotonic
|
|
|
|
static const ReorderingType S = 1; // swap
|
|
|
|
static const ReorderingType D = 2; // discontinuous
|
|
|
|
static const ReorderingType DL = 2; // discontinuous, left
|
|
|
|
static const ReorderingType DR = 3; // discontinuous, right
|
|
|
|
static const ReorderingType R = 0; // right
|
|
|
|
static const ReorderingType L = 1; // left
|
2010-02-11 20:08:24 +03:00
|
|
|
};
|
|
|
|
|
2012-06-27 03:45:02 +04:00
|
|
|
//! @todo what is this?
|
2011-02-24 16:14:42 +03:00
|
|
|
class BidirectionalReorderingState : public LexicalReorderingState
|
|
|
|
{
|
|
|
|
private:
|
|
|
|
const LexicalReorderingState *m_backward;
|
|
|
|
const LexicalReorderingState *m_forward;
|
|
|
|
public:
|
|
|
|
BidirectionalReorderingState(const LexicalReorderingConfiguration &config, const LexicalReorderingState *bw, const LexicalReorderingState *fw, size_t offset) :
|
|
|
|
LexicalReorderingState(config, LexicalReorderingConfiguration::Bidirectional, offset), m_backward(bw), m_forward(fw) {}
|
|
|
|
|
|
|
|
~BidirectionalReorderingState() {
|
|
|
|
delete m_backward;
|
|
|
|
delete m_forward;
|
|
|
|
}
|
|
|
|
|
|
|
|
virtual int Compare(const FFState& o) const;
|
|
|
|
virtual LexicalReorderingState* Expand(const TranslationOption& topt, Scores& scores) const;
|
2010-01-27 17:10:50 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
//! State for the standard Moses implementation of lexical reordering models
|
|
|
|
//! (see Koehn et al, Edinburgh System Description for the 2005 NIST MT Evaluation)
|
2011-02-24 16:14:42 +03:00
|
|
|
class PhraseBasedReorderingState : public LexicalReorderingState
|
|
|
|
{
|
|
|
|
private:
|
|
|
|
WordsRange m_prevRange;
|
|
|
|
bool m_first;
|
|
|
|
public:
|
2012-09-07 20:33:44 +04:00
|
|
|
static bool m_useFirstBackwardScore;
|
2011-02-24 16:14:42 +03:00
|
|
|
PhraseBasedReorderingState(const LexicalReorderingConfiguration &config, LexicalReorderingConfiguration::Direction dir, size_t offset);
|
|
|
|
PhraseBasedReorderingState(const PhraseBasedReorderingState *prev, const TranslationOption &topt);
|
|
|
|
|
|
|
|
virtual int Compare(const FFState& o) const;
|
|
|
|
virtual LexicalReorderingState* Expand(const TranslationOption& topt, Scores& scores) const;
|
|
|
|
|
|
|
|
ReorderingType GetOrientationTypeMSD(WordsRange currRange) const;
|
|
|
|
ReorderingType GetOrientationTypeMSLR(WordsRange currRange) const;
|
|
|
|
ReorderingType GetOrientationTypeMonotonic(WordsRange currRange) const;
|
|
|
|
ReorderingType GetOrientationTypeLeftRight(WordsRange currRange) const;
|
2010-01-27 17:10:50 +03:00
|
|
|
};
|
|
|
|
|
2011-02-24 16:14:42 +03:00
|
|
|
//! State for a hierarchical reordering model
|
|
|
|
//! (see Galley and Manning, A Simple and Effective Hierarchical Phrase Reordering Model, EMNLP 2008)
|
|
|
|
//!backward state (conditioned on the previous phrase)
|
|
|
|
class HierarchicalReorderingBackwardState : public LexicalReorderingState
|
|
|
|
{
|
|
|
|
private:
|
|
|
|
ReorderingStack m_reoStack;
|
|
|
|
public:
|
|
|
|
HierarchicalReorderingBackwardState(const LexicalReorderingConfiguration &config, size_t offset);
|
|
|
|
HierarchicalReorderingBackwardState(const HierarchicalReorderingBackwardState *prev,
|
|
|
|
const TranslationOption &topt, ReorderingStack reoStack);
|
|
|
|
|
|
|
|
virtual int Compare(const FFState& o) const;
|
|
|
|
virtual LexicalReorderingState* Expand(const TranslationOption& hypo, Scores& scores) const;
|
|
|
|
|
|
|
|
private:
|
|
|
|
ReorderingType GetOrientationTypeMSD(int reoDistance) const;
|
|
|
|
ReorderingType GetOrientationTypeMSLR(int reoDistance) const;
|
|
|
|
ReorderingType GetOrientationTypeMonotonic(int reoDistance) const;
|
|
|
|
ReorderingType GetOrientationTypeLeftRight(int reoDistance) const;
|
2010-01-27 17:10:50 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2011-02-24 16:14:42 +03:00
|
|
|
//!forward state (conditioned on the next phrase)
|
|
|
|
class HierarchicalReorderingForwardState : public LexicalReorderingState
|
|
|
|
{
|
|
|
|
private:
|
|
|
|
bool m_first;
|
|
|
|
WordsRange m_prevRange;
|
|
|
|
WordsBitmap m_coverage;
|
|
|
|
|
|
|
|
public:
|
|
|
|
HierarchicalReorderingForwardState(const LexicalReorderingConfiguration &config, size_t sentenceLength, size_t offset);
|
|
|
|
HierarchicalReorderingForwardState(const HierarchicalReorderingForwardState *prev, const TranslationOption &topt);
|
|
|
|
|
|
|
|
virtual int Compare(const FFState& o) const;
|
|
|
|
virtual LexicalReorderingState* Expand(const TranslationOption& hypo, Scores& scores) const;
|
|
|
|
|
|
|
|
private:
|
|
|
|
ReorderingType GetOrientationTypeMSD(WordsRange currRange, WordsBitmap coverage) const;
|
|
|
|
ReorderingType GetOrientationTypeMSLR(WordsRange currRange, WordsBitmap coverage) const;
|
|
|
|
ReorderingType GetOrientationTypeMonotonic(WordsRange currRange, WordsBitmap coverage) const;
|
|
|
|
ReorderingType GetOrientationTypeLeftRight(WordsRange currRange, WordsBitmap coverage) const;
|
2010-01-27 20:10:35 +03:00
|
|
|
};
|
|
|
|
|
2010-01-27 17:10:50 +03:00
|
|
|
}
|