mosesdecoder/moses/FF/InputFeature.h

70 lines
1.6 KiB
C
Raw Normal View History

#pragma once
#include "InputFeature.h"
#include "StatelessFeatureFunction.h"
namespace Moses
{
class InputFeature : public StatelessFeatureFunction
{
2013-06-05 01:09:21 +04:00
protected:
static InputFeature *s_instance;
2013-06-05 01:09:21 +04:00
size_t m_numInputScores;
size_t m_numRealWordCount;
bool m_legacy;
public:
static const InputFeature& Instance() {
return *s_instance;
}
static InputFeature& InstanceNonConst() {
return *s_instance;
}
InputFeature(const std::string &line);
void Load();
void SetParameter(const std::string& key, const std::string& value);
2013-06-05 16:42:56 +04:00
bool IsUseable(const FactorMask &mask) const {
return true;
}
size_t GetNumInputScores() const {
return m_numInputScores;
}
size_t GetNumRealWordsInInput() const {
return m_numRealWordCount;
}
2013-06-05 01:09:21 +04:00
void EvaluateInIsolation(const Phrase &source
2013-09-27 12:35:24 +04:00
, const TargetPhrase &targetPhrase
, ScoreComponentCollection &scoreBreakdown
, ScoreComponentCollection &estimatedFutureScore) const
{}
void EvaluateWithSourceContext(const InputType &input
2013-09-27 12:35:24 +04:00
, const InputPath &inputPath
, const TargetPhrase &targetPhrase
, const StackVec *stackVec
, ScoreComponentCollection &scoreBreakdown
, ScoreComponentCollection *estimatedFutureScore = NULL) const;
void EvaluateWhenApplied(const Hypothesis& hypo,
2013-09-27 12:35:24 +04:00
ScoreComponentCollection* accumulator) const
{}
void EvaluateWhenApplied(const ChartHypothesis &hypo,
2013-09-27 12:35:24 +04:00
ScoreComponentCollection* accumulator) const
{}
};
}