summaryrefslogtreecommitdiff
path: root/klm/search/vertex.cc
blob: cc53c0dd50845391971425bce01be469e1fce22a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
#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_);
    assert(extend_.empty());
    bound_ = end_->Bound();
    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 {
VertexNode kBlankVertexNode;
} // namespace

PartialVertex kBlankPartialVertex(kBlankVertexNode);

} // namespace search