mosesdecoder/contrib/other-builds/moses2/SCFG/ActiveChart.cpp
Hieu Hoang f7c23b7d90 debug
2016-06-24 19:15:47 +01:00

100 lines
1.9 KiB
C++

#include <boost/foreach.hpp>
#include <boost/functional/hash_fwd.hpp>
#include "ActiveChart.h"
#include "InputPath.h"
#include "Word.h"
#include "../Vector.h"
using namespace std;
namespace Moses2
{
namespace SCFG
{
SymbolBindElement::SymbolBindElement()
{
}
SymbolBindElement::SymbolBindElement(
const Range *range,
const SCFG::Word *word,
const Moses2::Hypotheses *hypos)
:range(range)
,word(word)
,hypos(hypos)
{
assert( (word->isNonTerminal && hypos) || (!word->isNonTerminal && hypos == NULL));
}
size_t hash_value(const SymbolBindElement &obj)
{
size_t ret = (size_t) obj.range;
boost::hash_combine(ret, obj.word);
return ret;
}
////////////////////////////////////////////////////////////////////////////
SymbolBind::SymbolBind(MemPool &pool)
:coll(pool)
,numNT(0)
{
}
void SymbolBind::Add(const Range &range, const SCFG::Word &word, const Moses2::Hypotheses *hypos)
{
SymbolBindElement ele(&range, &word, hypos);
coll.push_back(ele);
if (word.isNonTerminal) {
++numNT;
}
}
std::vector<const SymbolBindElement*> SymbolBind::GetNTElements() const
{
std::vector<const SymbolBindElement*> ret;
for (size_t i = 0; i < coll.size(); ++i) {
const SymbolBindElement &ele = coll[i];
//cerr << "ele=" << ele.word->isNonTerminal << " " << ele.hypos << endl;
if (ele.word->isNonTerminal) {
ret.push_back(&ele);
}
}
return ret;
}
std::string SymbolBind::Debug(const System &system) const
{
stringstream out;
BOOST_FOREACH(const SymbolBindElement &ele, coll) {
out << "("<< *ele.range;
out << ele.word->Debug(system);
out << ") ";
}
return out.str();
}
////////////////////////////////////////////////////////////////////////////
ActiveChartEntry::ActiveChartEntry(MemPool &pool)
:m_symbolBind(pool)
{
}
////////////////////////////////////////////////////////////////////////////
ActiveChart::ActiveChart(MemPool &pool)
:entries(pool)
{
}
ActiveChart::~ActiveChart()
{
}
}
}