#include "viterbi.h" #include #include #include "hg.h" using namespace std; string ViterbiETree(const Hypergraph& hg) { vector tmp; const prob_t p = Viterbi, ETreeTraversal, prob_t, EdgeProb>(hg, &tmp); return TD::GetString(tmp); } string ViterbiFTree(const Hypergraph& hg) { vector tmp; const prob_t p = Viterbi, FTreeTraversal, prob_t, EdgeProb>(hg, &tmp); return TD::GetString(tmp); } prob_t ViterbiESentence(const Hypergraph& hg, vector* result) { return Viterbi, ESentenceTraversal, prob_t, EdgeProb>(hg, result); } prob_t ViterbiFSentence(const Hypergraph& hg, vector* result) { return Viterbi, FSentenceTraversal, prob_t, EdgeProb>(hg, result); } int ViterbiELength(const Hypergraph& hg) { int len = -1; Viterbi(hg, &len); return len; } int ViterbiPathLength(const Hypergraph& hg) { int len = -1; Viterbi(hg, &len); return len; } // create a strings of the form (S (X the man) (X said (X he (X would (X go))))) struct JoshuaVisTraversal { JoshuaVisTraversal() : left("("), space(" "), right(")") {} const std::string left; const std::string space; const std::string right; void operator()(const Hypergraph::Edge& edge, const std::vector*>& ants, std::vector* result) const { std::vector tmp; edge.rule_->ESubstitute(ants, &tmp); const std::string cat = TD::Convert(edge.rule_->GetLHS() * -1); if (cat == "Goal") result->swap(tmp); else { ostringstream os; os << left << cat << '{' << edge.i_ << '-' << edge.j_ << '}' << space << TD::GetString(tmp) << right; TD::ConvertSentence(os.str(), result); } } }; string JoshuaVisualizationString(const Hypergraph& hg) { vector tmp; const prob_t p = Viterbi, JoshuaVisTraversal, prob_t, EdgeProb>(hg, &tmp); return TD::GetString(tmp); }