4 #include <unordered_set> 
   14   template <
typename Aut>
 
   18     using automaton_t = Aut;
 
   20                   "is_deterministic: requires free labelset");
 
   23     std::unordered_set<label_t> seen;
 
   24     for (
auto t : aut->all_out(s))
 
   25       if (!seen.insert(aut->label_of(t)).second)
 
   31   template <
typename Aut>
 
   36                   "num_deterministic_states: requires free labelset");
 
   39     for (
auto s: aut->states())
 
   45   template <
typename Aut>
 
   54   template <
typename Aut>
 
   59                   "is_deterministic: requires free labelset");
 
   61     if (1 < aut->initial_transitions().size())
 
   64     for (
auto s: aut->states())
 
   71   template <
typename Aut>
 
   83       template <
typename Aut>
 
   91       template <
typename Aut>
 
typename detail::label_t_of_impl< base_t< ValueSet >>::type label_t_of
size_t num_deterministic_states(const Aut &aut)
Number of non-deterministic states. 
bool is_codeterministic(const automaton &aut)
Bridge. 
typename detail::state_t_of_impl< base_t< ValueSet >>::type state_t_of
bool is_deterministic(const automaton &aut)
Bridge. 
Aut transpose(const transpose_automaton< Aut > &aut)
std::shared_ptr< detail::automaton_base > automaton
typename detail::labelset_t_of_impl< base_t< ValueSet >>::type labelset_t_of
bool is_codeterministic(const Aut &aut)
Whether the transpositive automaton is deterministic. 
bool is_deterministic(const Aut &aut, state_t_of< Aut > s)
Whether state s is deterministic in aut. 
size_t num_codeterministic_states(const Aut &aut)
Number of non-deterministic states of transpositive automaton.