Vcsn  2.4
Be Rational
lightest-automaton.hh
Go to the documentation of this file.
1 #pragma once
2 
3 #include <vcsn/algos/copy.hh>
4 #include <vcsn/algos/tags.hh>
6 #include <vcsn/dyn/automaton.hh>
7 #include <vcsn/dyn/fwd.hh>
8 #include <vcsn/misc/set.hh>
9 
10 namespace vcsn
11 {
20  template <Automaton Aut, typename Algo = auto_tag>
21  fresh_automaton_t_of<Aut>
22  lightest_automaton(const Aut& aut, unsigned k, Algo algo = {})
23  {
24  require(is_tropical<weightset_t_of<Aut>>(),
25  "lightest-automaton: ", *aut->weightset(),
26  " is not a tropical weightset");
27  auto res = make_fresh_automaton(aut);
28  // The copy is not 'safe' (uses add_transition instead of new_transition),
29  // as there can be the same transition multiple times.
30  auto copy = make_copier(aut, res, false);
31  if (k == 1)
32  {
33  auto pred = lightest_path(aut, algo);
34  for (auto t = pred[aut->post()];
35  t != aut->null_transition();
36  t = pred[aut->src_of(t)])
37  copy(t);
38  }
39  else if (1 < k)
40  {
41  for (auto path : k_lightest_path(aut, aut->pre(), aut->post(), k))
42  copy(path);
43  }
44  return res;
45  }
46 
47  namespace dyn
48  {
49  namespace detail
50  {
52  template <Automaton Aut, typename Num, typename String>
53  automaton
54  lightest_automaton(const automaton& aut, unsigned k,
55  const std::string& algo)
56  {
57  const auto& a = aut->as<Aut>();
59  }
60  }
61  }
62 }
std::vector< path_t_of< Aut > > k_lightest_path(const Aut &aut, state_t_of< Aut > src, state_t_of< Aut > dst, unsigned k)
return res
Definition: multiply.hh:398
void require(Bool b, Args &&...args)
If b is not verified, raise an error with args as message.
Definition: raise.hh:91
detail::copier< AutIn, AutOut > make_copier(const AutIn &in, AutOut &out, bool safe=true)
Build an automaton copier.
Definition: copy.hh:256
automaton lightest_automaton(const automaton &aut, unsigned k, const std::string &algo)
Bridge.
Definition: a-star.hh:8
fresh_automaton_t_of< Aut > lightest_automaton(const Aut &aut, unsigned k, Algo algo={})
Lightest Automaton.
AutOut make_fresh_automaton(const AutIn &model)
Create an empty, mutable, automaton, based on another one.
Definition: copy.hh:91
A dyn automaton.
Definition: automaton.hh:17
auto copy(const AutIn &input, KeepState keep_state, KeepTrans keep_trans) -> decltype(keep_state(input->null_state()), keep_trans(input->null_transition()), make_fresh_automaton< AutIn, AutOut >(input))
A copy of input keeping only its states that are accepted by keep_state, and transitions accepted by ...
Definition: copy.hh:322
auto & as()
Extract wrapped typed automaton.
Definition: automaton.hh:37
std::vector< transition_t_of< Aut > > lightest_path(const Aut &aut, state_t_of< Aut > source, state_t_of< Aut > dest, a_star_tag)
Definition: a-star.hh:151