2016-02-26 18:50:41 +03:00
|
|
|
/*
|
|
|
|
* Hypothesis.cpp
|
|
|
|
*
|
|
|
|
* Created on: 24 Oct 2015
|
|
|
|
* Author: hieu
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <boost/foreach.hpp>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <deque>
|
2016-08-10 23:40:05 +03:00
|
|
|
#include "HypothesisBase.h"
|
2016-02-26 18:50:41 +03:00
|
|
|
#include "System.h"
|
|
|
|
#include "Scores.h"
|
|
|
|
#include "ManagerBase.h"
|
|
|
|
#include "MemPool.h"
|
|
|
|
#include "FF/StatefulFeatureFunction.h"
|
|
|
|
|
|
|
|
using namespace std;
|
|
|
|
|
|
|
|
namespace Moses2
|
|
|
|
{
|
|
|
|
|
|
|
|
//size_t g_numHypos = 0;
|
|
|
|
|
|
|
|
HypothesisBase::HypothesisBase(MemPool &pool, const System &system)
|
|
|
|
{
|
2016-03-31 23:00:16 +03:00
|
|
|
m_scores = new (pool.Allocate<Scores>()) Scores(system, pool,
|
|
|
|
system.featureFunctions.GetNumScores());
|
|
|
|
|
|
|
|
// FF states
|
|
|
|
const std::vector<const StatefulFeatureFunction*> &sfffs =
|
|
|
|
system.featureFunctions.GetStatefulFeatureFunctions();
|
|
|
|
size_t numStatefulFFs = sfffs.size();
|
|
|
|
m_ffStates = (FFState **) pool.Allocate(sizeof(FFState*) * numStatefulFFs);
|
|
|
|
|
|
|
|
BOOST_FOREACH(const StatefulFeatureFunction *sfff, sfffs){
|
2016-08-03 23:34:47 +03:00
|
|
|
size_t statefulInd = sfff->GetStatefulInd();
|
|
|
|
FFState *state = sfff->BlankState(pool, system);
|
2016-03-31 23:00:16 +03:00
|
|
|
m_ffStates[statefulInd] = state;
|
|
|
|
}
|
2016-02-26 18:50:41 +03:00
|
|
|
}
|
|
|
|
|
2016-02-29 15:32:53 +03:00
|
|
|
size_t HypothesisBase::hash() const
|
|
|
|
{
|
2016-03-31 23:00:16 +03:00
|
|
|
return hash(0);
|
2016-02-29 15:32:53 +03:00
|
|
|
}
|
|
|
|
|
2016-02-26 18:50:41 +03:00
|
|
|
size_t HypothesisBase::hash(size_t seed) const
|
|
|
|
{
|
2016-03-31 23:00:16 +03:00
|
|
|
size_t numStatefulFFs =
|
|
|
|
GetManager().system.featureFunctions.GetStatefulFeatureFunctions().size();
|
2016-02-26 18:50:41 +03:00
|
|
|
|
|
|
|
// states
|
|
|
|
for (size_t i = 0; i < numStatefulFFs; ++i) {
|
2016-03-31 23:00:16 +03:00
|
|
|
const FFState *state = m_ffStates[i];
|
|
|
|
size_t hash = state->hash();
|
|
|
|
boost::hash_combine(seed, hash);
|
2016-02-26 18:50:41 +03:00
|
|
|
}
|
|
|
|
return seed;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
bool HypothesisBase::operator==(const HypothesisBase &other) const
|
|
|
|
{
|
2016-03-31 23:00:16 +03:00
|
|
|
size_t numStatefulFFs =
|
|
|
|
GetManager().system.featureFunctions.GetStatefulFeatureFunctions().size();
|
2016-02-26 18:50:41 +03:00
|
|
|
|
|
|
|
// states
|
|
|
|
for (size_t i = 0; i < numStatefulFFs; ++i) {
|
2016-03-31 23:00:16 +03:00
|
|
|
const FFState &thisState = *m_ffStates[i];
|
|
|
|
const FFState &otherState = *other.m_ffStates[i];
|
|
|
|
if (thisState != otherState) {
|
|
|
|
return false;
|
|
|
|
}
|
2016-02-26 18:50:41 +03:00
|
|
|
}
|
|
|
|
return true;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|