File size: 2,487 Bytes
158b61b
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
#ifndef moses_CorrectionPattern_h
#define moses_CorrectionPattern_h

#include <string>
#include <boost/unordered_set.hpp>

#include "StatelessFeatureFunction.h"
#include "moses/FactorCollection.h"
#include "moses/AlignmentInfo.h"

namespace Moses
{

typedef std::vector<std::string> Tokens;

/** Sets the features for length of source phrase, target phrase, both.
 */
class CorrectionPattern : public StatelessFeatureFunction
{
private:
  std::vector<FactorType> m_factors;
  bool m_general;
  size_t m_context;
  std::vector<FactorType> m_contextFactors;

public:
  CorrectionPattern(const std::string &line);

  bool IsUseable(const FactorMask &mask) const;

  void EvaluateInIsolation(const Phrase &source
                           , const TargetPhrase &targetPhrase
                           , ScoreComponentCollection &scoreBreakdown
                           , ScoreComponentCollection &estimatedFutureScore) const
  {}

  virtual void EvaluateWithSourceContext(const InputType &input
                                         , const InputPath &inputPath
                                         , const TargetPhrase &targetPhrase
                                         , const StackVec *stackVec
                                         , ScoreComponentCollection &scoreBreakdown
                                         , ScoreComponentCollection *estimatedFutureScore = NULL) const;

  void EvaluateTranslationOptionListWithSourceContext(const InputType &input
      , const TranslationOptionList &translationOptionList) const
  {}

  void EvaluateWhenApplied(const Hypothesis& hypo,
                           ScoreComponentCollection* accumulator) const
  {}
  void EvaluateWhenApplied(const ChartHypothesis &hypo,
                           ScoreComponentCollection* accumulator) const
  {}

  void ComputeFeatures(const InputType &input,
                       const InputPath &inputPath,
                       const TargetPhrase& targetPhrase,
                       ScoreComponentCollection* accumulator) const;

  void SetParameter(const std::string& key, const std::string& value);

  std::vector<std::string> CreatePattern(const Tokens &s1,
                                         const Tokens &s2,
                                         const InputType &input,
                                         const InputPath &inputPath) const;

  std::string CreateSinglePattern(const Tokens &s1, const Tokens &s2) const;

};

}

#endif // moses_CorrectionPattern_h