7 #include <vcsn/dyn/fwd.hh>
20 template <Automaton Aut,
typename Algo = auto_tag>
21 fresh_automaton_t_of<Aut>
24 require(is_tropical<weightset_t_of<Aut>>(),
25 "lightest-automaton: ", *aut->weightset(),
26 " is not a tropical weightset");
34 for (
auto t = pred[aut->post()];
35 t != aut->null_transition();
36 t = pred[aut->src_of(t)])
52 template <Automaton Aut,
typename Num,
typename String>
55 const std::string& algo)
57 const auto& a = aut->
as<Aut>();
std::vector< path_t_of< Aut > > k_lightest_path(const Aut &aut, state_t_of< Aut > src, state_t_of< Aut > dst, unsigned k)
void require(Bool b, Args &&...args)
If b is not verified, raise an error with args as message.
detail::copier< AutIn, AutOut > make_copier(const AutIn &in, AutOut &out, bool safe=true)
Build an automaton copier.
automaton lightest_automaton(const automaton &aut, unsigned k, const std::string &algo)
Bridge.
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.
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 ...
auto & as()
Extract wrapped typed automaton.
std::vector< transition_t_of< Aut > > lightest_path(const Aut &aut, state_t_of< Aut > source, state_t_of< Aut > dest, a_star_tag)