Blame view

tools/openfst-1.6.7/include/fst/script/determinize.h 2 KB
8dcb6dfcb   Yannick Estève   first commit
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
55
56
57
58
59
  // See www.openfst.org for extensive documentation on this weighted
  // finite-state transducer library.
  
  #ifndef FST_SCRIPT_DETERMINIZE_H_
  #define FST_SCRIPT_DETERMINIZE_H_
  
  #include <tuple>
  
  #include <fst/determinize.h>
  #include <fst/script/fst-class.h>
  #include <fst/script/weight-class.h>
  
  namespace fst {
  namespace script {
  
  struct DeterminizeOptions {
    const float delta;
    const WeightClass &weight_threshold;
    const int64 state_threshold;
    const int64 subsequential_label;
    const DeterminizeType det_type;
    const bool increment_subsequential_label;
  
    DeterminizeOptions(float delta, const WeightClass &weight_threshold,
                       int64 state_threshold = kNoStateId,
                       int64 subsequential_label = 0,
                       DeterminizeType det_type = DETERMINIZE_FUNCTIONAL,
                       bool increment_subsequential_label = false)
        : delta(delta),
          weight_threshold(weight_threshold),
          state_threshold(state_threshold),
          subsequential_label(subsequential_label),
          det_type(det_type),
          increment_subsequential_label(increment_subsequential_label) {}
  };
  
  using DeterminizeArgs = std::tuple<const FstClass &, MutableFstClass *,
                                     const DeterminizeOptions &>;
  
  template <class Arc>
  void Determinize(DeterminizeArgs *args) {
    using Weight = typename Arc::Weight;
    const Fst<Arc> &ifst = *(std::get<0>(*args).GetFst<Arc>());
    MutableFst<Arc> *ofst = std::get<1>(*args)->GetMutableFst<Arc>();
    const auto &opts = std::get<2>(*args);
    const auto weight_threshold = *(opts.weight_threshold.GetWeight<Weight>());
    const fst::DeterminizeOptions<Arc> detargs(opts.delta, weight_threshold,
        opts.state_threshold, opts.subsequential_label, opts.det_type,
        opts.increment_subsequential_label);
    Determinize(ifst, ofst, detargs);
  }
  
  void Determinize(const FstClass &ifst, MutableFstClass *ofst,
                   const DeterminizeOptions &opts);
  
  }  // namespace script
  }  // namespace fst
  
  #endif  // FST_SCRIPT_DETERMINIZE_H_