4 #include <unordered_map> 
    6 #include <boost/range/algorithm/min_element.hpp> 
    7 #include <boost/range/algorithm/sort.hpp> 
   20     template <
typename Aut>
 
   27       template <
typename Ctx = context_t_of<Aut>>
 
   34       using set_t = std::vector<state_t>;
 
   68                       return lhs[0] < rhs[0];
 
   79             state_to_class[s] = c;
 
   89               = s == aut->pre()  ? res->pre()
 
   90               : s == aut->post() ? res->post()
 
   92             origins[class_to_res_state[c]].insert(begin(set), end(set));
 
   99             state_t src = class_to_res_state[c];
 
  100             for (
auto t : aut->all_out(s))
 
  103                 state_t dst = class_to_res_state[state_to_class[d]];
 
  104                 res->add_transition(src, dst,
 
  105                                     aut->label_of(t), aut->weight_of(t));
 
  118   template <
typename Aut>
 
  121   template <
typename Aut>
 
class_to_set_t & class_to_set_
partition_automaton_t< Aut > quotient_t
The return type when calling quotient on Aut. 
fresh_automaton_t_of< automaton_t, Ctx > fresh_automaton_t
AutOut make_fresh_automaton(const AutIn &model)
Create an empty, mutable, automaton, based on another one. 
void sort_classes_()
Sort the classes. 
quotienter(class_to_set_t &class_to_set)
Apply a quotient onto an automaton: fuse equivalent states. 
typename origins_t_of_impl< Aut >::type origins_t_of
The type of the origins map for a partition automaton, or a transposed one. 
typename detail::state_t_of_impl< base_t< ValueSet >>::type state_t_of
auto quotient(const Aut &a, typename detail::quotienter< Aut >::class_to_set_t &cs) -> quotient_t< Aut >
std::vector< state_t > set_t
state_t_of< automaton_t > state_t
typename Aut::element_type::template fresh_automaton_t< Context > fresh_automaton_t_of
std::vector< set_t > class_to_set_t
std::unordered_map< state_t, class_t > state_to_class_t
size_t size(const ExpSet &rs, const typename ExpSet::value_t &r)
std::vector< state_t > class_to_state_t
quotient_t operator()(const automaton_t &aut)
Build the resulting automaton. 
typename detail::partition_automaton_t_impl< Aut >::type partition_automaton_t
The return type when calling quotient on Aut. 
partition_automaton_t< automaton_t > quotient_t
auto make_partition_automaton(const fresh_automaton_t_of< Aut > &res, const Aut &input, const typename detail::partition_automaton_impl< Aut >::origins_t origins) -> partition_automaton_t< Aut >
Build a partition_automaton. 
origins_t_of< quotient_t > origins_t
auto sort(const Aut &a) -> permutation_automaton< Aut >