mirror of
https://github.com/moses-smt/mosesdecoder.git
synced 2024-12-26 21:42:19 +03:00
21f141ce0d
Conflicts: moses/InputPath.cpp moses/Word.cpp
98 lines
3.1 KiB
C++
98 lines
3.1 KiB
C++
#include "InputPath.h"
|
|
#include "ScoreComponentCollection.h"
|
|
#include "TargetPhraseCollection.h"
|
|
#include "StaticData.h"
|
|
#include "TypeDef.h"
|
|
#include "AlignmentInfo.h"
|
|
#include "util/exception.hh"
|
|
#include "TranslationModel/PhraseDictionary.h"
|
|
using namespace std;
|
|
|
|
namespace Moses
|
|
{
|
|
InputPath::
|
|
InputPath(const Phrase &phrase, const NonTerminalSet &sourceNonTerms,
|
|
const WordsRange &range, const InputPath *prevNode,
|
|
const ScorePair *inputScore)
|
|
:m_prevPath(prevNode)
|
|
,m_phrase(phrase)
|
|
,m_range(range)
|
|
,m_inputScore(inputScore)
|
|
,m_nextNode(1)
|
|
,m_sourceNonTerms(sourceNonTerms)
|
|
,m_sourceNonTermArray(FactorCollection::Instance().GetNumNonTerminals(), false)
|
|
{
|
|
for (NonTerminalSet::const_iterator iter = sourceNonTerms.begin(); iter != sourceNonTerms.end(); ++iter) {
|
|
size_t idx = (*iter)[0]->GetId();
|
|
m_sourceNonTermArray[idx] = true;
|
|
}
|
|
|
|
//cerr << "phrase=" << phrase << " m_inputScore=" << *m_inputScore << endl;
|
|
|
|
}
|
|
|
|
InputPath::~InputPath()
|
|
{
|
|
// Since there is no way for the Phrase Dictionaries to tell in
|
|
// which (sentence) context phrases were looked up, we tell them
|
|
// now that the phrase isn't needed any more by this inputPath
|
|
typedef std::pair<const TargetPhraseCollection*, const void* > entry;
|
|
std::map<const PhraseDictionary*, entry>::const_iterator iter;
|
|
for (iter = m_targetPhrases.begin(); iter != m_targetPhrases.end(); ++iter)
|
|
iter->first->Release(iter->second.first);
|
|
|
|
delete m_inputScore;
|
|
}
|
|
|
|
const TargetPhraseCollection *InputPath::GetTargetPhrases(const PhraseDictionary &phraseDictionary) const
|
|
{
|
|
std::map<const PhraseDictionary*, std::pair<const TargetPhraseCollection*, const void*> >::const_iterator iter;
|
|
iter = m_targetPhrases.find(&phraseDictionary);
|
|
if (iter == m_targetPhrases.end()) {
|
|
return NULL;
|
|
}
|
|
return iter->second.first;
|
|
}
|
|
|
|
const void *InputPath::GetPtNode(const PhraseDictionary &phraseDictionary) const
|
|
{
|
|
std::map<const PhraseDictionary*, std::pair<const TargetPhraseCollection*, const void*> >::const_iterator iter;
|
|
iter = m_targetPhrases.find(&phraseDictionary);
|
|
if (iter == m_targetPhrases.end()) {
|
|
return NULL;
|
|
}
|
|
return iter->second.second;
|
|
}
|
|
|
|
void InputPath::SetTargetPhrases(const PhraseDictionary &phraseDictionary
|
|
, const TargetPhraseCollection *targetPhrases
|
|
, const void *ptNode)
|
|
{
|
|
std::pair<const TargetPhraseCollection*, const void*> value(targetPhrases, ptNode);
|
|
m_targetPhrases[&phraseDictionary] = value;
|
|
}
|
|
|
|
const Word &InputPath::GetLastWord() const
|
|
{
|
|
size_t len = m_phrase.GetSize();
|
|
UTIL_THROW_IF2(len == 0, "Input path phrase cannot be empty");
|
|
const Word &ret = m_phrase.GetWord(len - 1);
|
|
return ret;
|
|
}
|
|
|
|
std::ostream& operator<<(std::ostream& out, const InputPath& obj)
|
|
{
|
|
out << &obj << " " << obj.GetWordsRange() << " " << obj.GetPrevPath() << " " << obj.GetPhrase();
|
|
|
|
out << "pt: ";
|
|
std::map<const PhraseDictionary*, std::pair<const TargetPhraseCollection*, const void*> >::const_iterator iter;
|
|
for (iter = obj.m_targetPhrases.begin(); iter != obj.m_targetPhrases.end(); ++iter) {
|
|
const PhraseDictionary *pt = iter->first;
|
|
out << pt << " ";
|
|
}
|
|
|
|
return out;
|
|
}
|
|
|
|
}
|