diff options
Diffstat (limited to 'klm/search/vertex.cc')
| -rw-r--r-- | klm/search/vertex.cc | 42 | 
1 files changed, 42 insertions, 0 deletions
| diff --git a/klm/search/vertex.cc b/klm/search/vertex.cc new file mode 100644 index 00000000..11f4631f --- /dev/null +++ b/klm/search/vertex.cc @@ -0,0 +1,42 @@ +#include "search/vertex.hh" + +#include "search/context.hh" + +#include <algorithm> +#include <functional> + +#include <assert.h> + +namespace search { + +namespace { + +struct GreaterByBound : public std::binary_function<const VertexNode *, const VertexNode *, bool> { +  bool operator()(const VertexNode *first, const VertexNode *second) const { +    return first->Bound() > second->Bound(); +  } +}; + +} // namespace + +void VertexNode::SortAndSet(ContextBase &context, VertexNode **parent_ptr) { +  if (Complete()) { +    assert(end_.Valid()); +    assert(extend_.empty()); +    bound_ = end_.GetScore(); +    return; +  } +  if (extend_.size() == 1 && parent_ptr) { +    *parent_ptr = extend_[0]; +    extend_[0]->SortAndSet(context, parent_ptr); +    context.DeleteVertexNode(this); +    return; +  } +  for (std::vector<VertexNode*>::iterator i = extend_.begin(); i != extend_.end(); ++i) { +    (*i)->SortAndSet(context, &*i); +  } +  std::sort(extend_.begin(), extend_.end(), GreaterByBound()); +  bound_ = extend_.front()->Bound(); +} + +} // namespace search | 
