mosesdecoder/moses/FF/TargetWordInsertionFeature.h

59 lines
1.7 KiB
C
Raw Normal View History

#ifndef moses_TargetWordInsertionFeature_h
#define moses_TargetWordInsertionFeature_h
#include <string>
#include <boost/unordered_set.hpp>
2013-05-24 22:11:15 +04:00
#include "StatelessFeatureFunction.h"
2013-05-24 21:02:49 +04:00
#include "moses/FactorCollection.h"
#include "moses/AlignmentInfo.h"
namespace Moses
{
/** Sets the features for length of source phrase, target phrase, both.
*/
2013-05-29 21:16:15 +04:00
class TargetWordInsertionFeature : public StatelessFeatureFunction
{
private:
boost::unordered_set<std::string> m_vocab;
FactorType m_factorType;
bool m_unrestricted;
std::string m_filename;
public:
TargetWordInsertionFeature(const std::string &line);
2013-05-29 21:16:15 +04:00
bool IsUseable(const FactorMask &mask) const;
void Load();
virtual void Evaluate(const Phrase &source
2013-05-29 21:16:15 +04:00
, const TargetPhrase &targetPhrase
, ScoreComponentCollection &scoreBreakdown
, ScoreComponentCollection &estimatedFutureScore) const;
void Evaluate(const InputType &input
2013-09-27 12:35:24 +04:00
, const InputPath &inputPath
, const TargetPhrase &targetPhrase
, ScoreComponentCollection &scoreBreakdown
, ScoreComponentCollection *estimatedFutureScore = NULL) const
{}
void Evaluate(const Hypothesis& hypo,
2013-09-27 12:35:24 +04:00
ScoreComponentCollection* accumulator) const
{}
void EvaluateChart(const ChartHypothesis &hypo,
2013-09-27 12:35:24 +04:00
ScoreComponentCollection* accumulator) const
{}
void ComputeFeatures(const Phrase &source,
2013-05-29 21:16:15 +04:00
const TargetPhrase& targetPhrase,
ScoreComponentCollection* accumulator,
const AlignmentInfo &alignmentInfo) const;
void SetParameter(const std::string& key, const std::string& value);
};
}
#endif // moses_TargetWordInsertionFeature_h