Welcome to mirror list, hosted at ThFree Co, Russian Federation.

ControlRecombination.cpp « FF « moses - github.com/moses-smt/mosesdecoder.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 10c2898b123f8ace2803ff4a0f0452dd043aa324 (plain)
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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
#include "ControlRecombination.h"
#include "moses/Hypothesis.h"
#include "moses/Manager.h"
#include "moses/ChartHypothesis.h"
#include "moses/ChartManager.h"
#include "moses/StaticData.h"
#include "moses/InputFileStream.h"
#include "moses/Util.h"
#include "util/exception.hh"

using namespace std;

namespace Moses
{
ControlRecombinationState::ControlRecombinationState(const Hypothesis &hypo, const ControlRecombination &ff)
  :m_ff(ff)
{
  if (ff.GetType() == SameOutput) {
    //UTIL_THROW(util::Exception, "Implemented not yet completed for phrase-based model. Need to take into account the coverage");
    hypo.GetOutputPhrase(m_outputPhrase);
  } else {
    m_hypo = &hypo;
  }
}

ControlRecombinationState::ControlRecombinationState(const ChartHypothesis &hypo, const ControlRecombination &ff)
  :m_ff(ff)
{
  if (ff.GetType() == SameOutput) {
    hypo.GetOutputPhrase(m_outputPhrase);
  } else {
    m_hypo = &hypo;
  }
}

size_t ControlRecombinationState::hash() const
{
  size_t ret;
  if (m_ff.GetType() == SameOutput) {
    ret = hash_value(m_outputPhrase);
  } else {
    // compare hypo address. Won't be equal unless they're actually the same hypo
    ret = (size_t) m_hypo;
  }
  return ret;
}

bool ControlRecombinationState::operator==(const FFState& other) const
{
  const ControlRecombinationState &otherFF = static_cast<const ControlRecombinationState&>(other);

  if (m_ff.GetType() == SameOutput) {
    return m_outputPhrase == otherFF.m_outputPhrase;
  } else {
    // compare hypo address. Won't be equal unless they're actually the same hypo
    if (m_hypo == otherFF.m_hypo)
      return true;
    return (m_hypo == otherFF.m_hypo);
  }
}

std::vector<float> ControlRecombination::DefaultWeights() const
{
  UTIL_THROW_IF2(m_numScoreComponents,
                 "ControlRecombination should not have any scores");
  vector<float> ret(0);
  return ret;
}

FFState* ControlRecombination::EvaluateWhenApplied(
  const Hypothesis& hypo,
  const FFState* prev_state,
  ScoreComponentCollection* accumulator) const
{
  return new ControlRecombinationState(hypo, *this);
}

FFState* ControlRecombination::EvaluateWhenApplied(
  const ChartHypothesis &hypo,
  int /* featureID - used to index the state in the previous hypotheses */,
  ScoreComponentCollection* accumulator) const
{
  return new ControlRecombinationState(hypo, *this);
}

void ControlRecombination::SetParameter(const std::string& key, const std::string& value)
{
  if (key == "type") {
    m_type = (ControlRecombinationType) Scan<int>(value);
  } else {
    StatefulFeatureFunction::SetParameter(key, value);
  }
}

}