Welcome to mirror list, hosted at ThFree Co, Russian Federation.

edge.hh « search - github.com/moses-smt/mosesdecoder.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: cee96b474e955ac06730f96df39b5430d9b2b982 (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
49
50
51
52
53
54
#ifndef SEARCH_EDGE__
#define SEARCH_EDGE__

#include "lm/state.hh"
#include "search/header.hh"
#include "search/types.hh"
#include "search/vertex.hh"
#include "util/pool.hh"

#include <functional>

#include <stdint.h>

namespace search {

// Copyable, but the copy will be shallow.
class PartialEdge : public Header {
  public:
    // Allow default construction for STL.
    PartialEdge() {}

    PartialEdge(util::Pool &pool, Arity arity)
      : Header(pool.Allocate(Size(arity, arity + 1)), arity) {}

    PartialEdge(util::Pool &pool, Arity arity, Arity chart_states)
      : Header(pool.Allocate(Size(arity, chart_states)), arity) {}

    // Non-terminals
    const PartialVertex *NT() const {
      return reinterpret_cast<const PartialVertex*>(After());
    }
    PartialVertex *NT() {
      return reinterpret_cast<PartialVertex*>(After());
    }

    const lm::ngram::ChartState &CompletedState() const {
      return *Between();
    }
    const lm::ngram::ChartState *Between() const {
      return reinterpret_cast<const lm::ngram::ChartState*>(After() + GetArity() * sizeof(PartialVertex));
    }
    lm::ngram::ChartState *Between() {
      return reinterpret_cast<lm::ngram::ChartState*>(After() + GetArity() * sizeof(PartialVertex));
    }

  private:
    static std::size_t Size(Arity arity, Arity chart_states) {
      return kHeaderSize + arity * sizeof(PartialVertex) + chart_states * sizeof(lm::ngram::ChartState);
    }
};


} // namespace search
#endif // SEARCH_EDGE__