mosesdecoder/moses/Incremental.h

122 lines
3.8 KiB
C
Raw Normal View History

// -*- c++ -*-
#pragma once
#include "lm/word_index.hh"
#include "search/applied.hh"
#include "search/nbest.hh"
2012-11-12 23:56:18 +04:00
#include "moses/ChartCellCollection.h"
#include "moses/ChartParser.h"
#include "BaseManager.h"
#include <vector>
#include <string>
2013-05-29 21:16:15 +04:00
namespace Moses
{
class ScoreComponentCollection;
class InputType;
2013-05-27 18:54:50 +04:00
class LanguageModel;
2013-05-29 21:16:15 +04:00
namespace Incremental
{
class Manager : public BaseManager
2013-05-29 21:16:15 +04:00
{
public:
Manager(ttasksptr const& ttask);
2013-05-29 21:16:15 +04:00
~Manager();
2013-05-29 21:16:15 +04:00
template <class Model> void LMCallback(const Model &model, const std::vector<lm::WordIndex> &words);
2014-12-05 20:59:53 +03:00
void Decode();
const std::vector<search::Applied> &GetNBest() const;
2012-10-12 16:53:08 +04:00
2013-05-29 21:16:15 +04:00
// Call to get the same value as ProcessSentence returned.
const std::vector<search::Applied> &Completed() const {
return *completed_nbest_;
}
// output
void OutputBest(OutputCollector *collector) const;
void OutputNBest(OutputCollector *collector) const;
void OutputDetailedTranslationReport(OutputCollector *collector) const;
void OutputNBestList(OutputCollector *collector, const std::vector<search::Applied> &nbest, long translationId) const;
2015-01-14 14:07:42 +03:00
void OutputLatticeSamples(OutputCollector *collector) const {
}
void OutputAlignment(OutputCollector *collector) const {
}
void OutputDetailedTreeFragmentsTranslationReport(OutputCollector *collector) const;
2015-01-14 14:07:42 +03:00
void OutputWordGraph(OutputCollector *collector) const {
}
void OutputSearchGraph(OutputCollector *collector) const {
}
void OutputSearchGraphSLF() const {
}
void OutputSearchGraphHypergraph() const {
}
2013-05-29 21:16:15 +04:00
private:
template <class Model, class Best> search::History PopulateBest(const Model &model, const std::vector<lm::WordIndex> &words, Best &out);
2012-10-12 16:53:08 +04:00
2013-05-29 21:16:15 +04:00
ChartCellCollectionBase cells_;
ChartParser parser_;
2013-05-29 21:16:15 +04:00
// Only one of single_best_ or n_best_ will be used, but it was easier to do this than a template.
search::SingleBest single_best_;
// ProcessSentence returns a reference to a vector. ProcessSentence
// doesn't have one, so this is populated and returned.
std::vector<search::Applied> backing_for_single_;
search::NBest n_best_;
const std::vector<search::Applied> *completed_nbest_;
// outputs
void OutputDetailedTranslationReport(
2015-01-14 14:07:42 +03:00
OutputCollector *collector,
const search::Applied *applied,
const Sentence &sentence,
long translationId) const;
void OutputTranslationOptions(std::ostream &out,
ApplicationContext &applicationContext,
const search::Applied *applied,
const Sentence &sentence,
long translationId) const;
void OutputTranslationOption(std::ostream &out,
ApplicationContext &applicationContext,
const search::Applied *applied,
const Sentence &sentence,
long translationId) const;
void ReconstructApplicationContext(const search::Applied *applied,
const Sentence &sentence,
ApplicationContext &context) const;
void OutputTreeFragmentsTranslationOptions(std::ostream &out,
ApplicationContext &applicationContext,
const search::Applied *applied,
const Sentence &sentence,
long translationId) const;
2015-01-14 14:07:42 +03:00
void OutputBestHypo(OutputCollector *collector, search::Applied applied, long translationId) const;
void OutputBestNone(OutputCollector *collector, long translationId) const;
void OutputUnknowns(OutputCollector *collector) const {
}
void CalcDecoderStatistics() const {
}
2015-01-04 13:02:44 +03:00
};
// Just get the phrase.
void ToPhrase(const search::Applied final, Phrase &out);
2013-05-29 21:16:15 +04:00
// Get the phrase and the features.
2013-05-11 17:13:26 +04:00
void PhraseAndFeatures(const search::Applied final, Phrase &phrase, ScoreComponentCollection &features);
2013-05-27 18:54:50 +04:00
} // namespace Incremental
} // namespace Moses