mosesdecoder/contrib/moses2/SCFG/Hypothesis.h

69 lines
1.5 KiB
C++

#pragma once
#include <vector>
#include "InputPath.h"
#include "../HypothesisBase.h"
#include "../MemPool.h"
#include "../Vector.h"
namespace Moses2
{
class InputPathBase;
class StatefulFeatureFunction;
namespace SCFG
{
class TargetPhraseImpl;
class Manager;
class SymbolBind;
class InputPath;
class Hypothesis: public HypothesisBase
{
public:
static Hypothesis *Create(MemPool &pool, Manager &mgr);
void Init(SCFG::Manager &mgr,
const SCFG::InputPath &path,
const SCFG::SymbolBind &symbolBind,
const SCFG::TargetPhraseImpl &tp,
const Vector<size_t> &prevHyposIndices);
virtual SCORE GetFutureScore() const;
virtual void EvaluateWhenApplied();
const SCFG::TargetPhraseImpl &GetTargetPhrase() const
{ return *m_targetPhrase; }
const SCFG::InputPath &GetInputPath() const
{ return *m_path; }
const Vector<const Hypothesis*> &GetPrevHypos() const
{ return m_prevHypos; }
//! get a particular previous hypos
const Hypothesis* GetPrevHypo(size_t ind) const
{ return m_prevHypos[ind]; }
void OutputToStream(std::ostream &out) const;
void OutputTransOpt(std::ostream &out) const;
std::string Debug(const System &system) const;
protected:
const SCFG::TargetPhraseImpl *m_targetPhrase;
const SCFG::InputPath *m_path;
const SCFG::SymbolBind *m_symbolBind;
Vector<const Hypothesis*> m_prevHypos; // always sorted by source position?
Hypothesis(MemPool &pool,
const System &system);
void EvaluateWhenApplied(const StatefulFeatureFunction &sfff);
};
}
}