#ifndef SEARCH_EDGE_GENERATOR__ #define SEARCH_EDGE_GENERATOR__ #include "search/edge.hh" #include "search/note.hh" #include "search/types.hh" #include namespace lm { namespace ngram { class ChartState; } // namespace ngram } // namespace lm namespace search { template class Context; class EdgeGenerator { public: EdgeGenerator() {} PartialEdge AllocateEdge(Arity arity) { return partial_edge_pool_.Allocate(arity); } void AddEdge(PartialEdge edge) { generate_.push(edge); } bool Empty() const { return generate_.empty(); } // Pop. If there's a complete hypothesis, return it. Otherwise return an invalid PartialEdge. template PartialEdge Pop(Context &context); template void Search(Context &context, Output &output) { unsigned to_pop = context.PopLimit(); while (to_pop > 0 && !generate_.empty()) { PartialEdge got(Pop(context)); if (got.Valid()) { output.NewHypothesis(got); --to_pop; } } output.FinishedSearch(); } private: PartialEdgePool partial_edge_pool_; typedef std::priority_queue Generate; Generate generate_; }; } // namespace search #endif // SEARCH_EDGE_GENERATOR__