This page contains documentation for everything in the namespace todd_coxeter. This includes everything from Common congruence helpers and ToddCoxeter helper functions.
| Functions | |
| template<typename Thing> | |
| void | add_generating_pair (Thing &thing, typename Thing::native_word_type const &u, typename Thing::native_word_type const &v) | 
| Helper for adding a generating pair of words. | |
| template<typename Thing> | |
| void | add_generating_pair_no_checks (Thing &thing, typename Thing::native_word_type const &u, typename Thing::native_word_type const &v) | 
| Helper for adding a generating pair of words. | |
| template<typename Word> | |
| auto | class_by_index (ToddCoxeter< Word > &tc, index_type n) | 
| Returns a range object containing every word in the congruence class with given index. | |
| template<typename Word> | |
| auto | class_by_index_no_checks (ToddCoxeter< Word > &tc, index_type n) | 
| Returns a range object containing every word in the congruence class with given index. | |
| template<typename Word> | |
| auto | class_of (ToddCoxeter< Word > &tc, char const *w) | 
| Returns a range object containing every word in the congruence class of a given word. | |
| template<typename Word, typename Iterator1, typename Iterator2> | |
| auto | class_of (ToddCoxeter< Word > &tc, Iterator1 first, Iterator2 last) | 
| Returns a range object containing every word in the congruence class of a word given by iterators. | |
| template<typename Word, typename Int> | |
| auto | class_of (ToddCoxeter< Word > &tc, std::initializer_list< Int > const &w) | 
| Returns a range object containing every word in the congruence class of a given word. | |
| template<typename Word> | |
| auto | class_of (ToddCoxeter< Word > &tc, Word const &w) | 
| Returns a range object containing every word in the congruence class of a given word. | |
| template<typename Word> | |
| auto | class_of_no_checks (ToddCoxeter< Word > &tc, char const *w) | 
| Returns a range object containing every word in the congruence class of a given word. | |
| template<typename Word, typename Iterator1, typename Iterator2> | |
| auto | class_of_no_checks (ToddCoxeter< Word > &tc, Iterator1 first, Iterator2 last) | 
| Returns a range object containing every word in the congruence class of a word given by iterators. | |
| template<typename Word, typename Int> | |
| auto | class_of_no_checks (ToddCoxeter< Word > &tc, std::initializer_list< Int > const &w) | 
| Returns a range object containing every word in the congruence class of a given word. | |
| template<typename Word> | |
| auto | class_of_no_checks (ToddCoxeter< Word > &tc, Word const &w) | 
| Returns a range object containing every word in the congruence class of a given word. | |
| template<typename Thing> | |
| bool | contains (Thing &thing, typename Thing::native_word_type const &u, typename Thing::native_word_type const &v) | 
| Check containment of a pair of words. | |
| template<typename Thing> | |
| bool | contains_no_checks (Thing &thing, typename Thing::native_word_type const &u, typename Thing::native_word_type const &v) | 
| Check containment of a pair of words. | |
| template<typename Word> | |
| index_type | current_index_of (ToddCoxeter< Word > &tc, char const *w) | 
| Returns the current index of the class containing a word. | |
| template<typename Word, typename Int> | |
| index_type | current_index_of (ToddCoxeter< Word > &tc, std::initializer_list< Int > const &w) | 
| Returns the current index of the class containing a word. | |
| template<typename Word> | |
| index_type | current_index_of (ToddCoxeter< Word > const &tc, Word const &w) | 
| Returns the current index of the class containing a word. | |
| template<typename Word> | |
| index_type | current_index_of_no_checks (ToddCoxeter< Word > &tc, char const *w) | 
| Returns the current index of the class containing a word. | |
| template<typename Word, typename Int> | |
| index_type | current_index_of_no_checks (ToddCoxeter< Word > &tc, std::initializer_list< Int > const &w) | 
| Returns the current index of the class containing a word. | |
| template<typename Word> | |
| index_type | current_index_of_no_checks (ToddCoxeter< Word > const &tc, Word const &w) | 
| Returns the current index of the class containing a word. | |
| template<typename Word> | |
| Word | current_word_of (ToddCoxeter< Word > &tc, index_type i) | 
| Returns a word representing a class with given index. | |
| template<typename Word> | |
| Word | current_word_of_no_checks (ToddCoxeter< Word > &tc, index_type i) | 
| Returns a word representing a class with given index. | |
| template<typename Thing> | |
| tril | currently_contains (Thing const &thing, typename Thing::native_word_type const &u, typename Thing::native_word_type const &v) | 
| Check containment of a pair of words. | |
| template<typename Thing> | |
| tril | currently_contains_no_checks (Thing const &thing, typename Thing::native_word_type const &u, typename Thing::native_word_type const &v) | 
| Check containment of a pair of words. | |
| template<typename Word> | |
| index_type | index_of (ToddCoxeter< Word > &tc, char const *w) | 
| Returns the index of the class containing a word. | |
| template<typename Word, typename Int> | |
| index_type | index_of (ToddCoxeter< Word > &tc, std::initializer_list< Int > const &w) | 
| Returns the index of the class containing a word. | |
| template<typename Word> | |
| index_type | index_of (ToddCoxeter< Word > &tc, Word const &w) | 
| Returns the index of the class containing a word. | |
| template<typename Word> | |
| index_type | index_of_no_checks (ToddCoxeter< Word > &tc, char const *w) | 
| Returns the index of the class containing a word. | |
| template<typename Word, typename Int> | |
| index_type | index_of_no_checks (ToddCoxeter< Word > &tc, std::initializer_list< Int > const &w) | 
| Returns the index of the class containing a word. | |
| template<typename Word> | |
| index_type | index_of_no_checks (ToddCoxeter< Word > &tc, Word const &w) | 
| Returns the index of the class containing a word. | |
| tril | is_non_trivial (detail::ToddCoxeterImpl &tc, size_t tries=10, std::chrono::milliseconds try_for=std::chrono::milliseconds(100), float threshold=0.99) | 
| Check if the congruence has more than one class. | |
| template<typename Thing, typename Range, typename = std::enable_if_t<rx::is_input_or_sink_v<Range>>> | |
| std::vector< std::vector< typename Thing::native_word_type > > | non_trivial_classes (Thing &thing, Range r) | 
| Find the non-trivial classes in the partition of a range of words. | |
| template<typename Word> | |
| auto | normal_forms (Kambites< Word > &k) | 
| Returns a range object containing normal forms. | |
| template<typename Thing, typename Range, typename = std::enable_if_t<rx::is_input_or_sink_v<Range>>> | |
| std::vector< std::vector< typename Thing::native_word_type > > | partition (Thing &thing, Range r) | 
| Partition a range of words. | |
| void | perform_lookbehind (detail::ToddCoxeterImpl &tc) | 
| Perform a lookbehind. | |
| template<typename Thing> | |
| Thing::native_word_type | reduce (Thing const &thing, typename Thing::native_word_type const &w) | 
| Reduce a word. | |
| template<typename Thing> | |
| Thing::native_word_type | reduce_no_checks (Thing const &thing, typename Thing::native_word_type const &w) | 
| Reduce a word with no checks. | |
| template<typename Thing> | |
| Thing::native_word_type | reduce_no_run (Thing const &thing, typename Thing::native_word_type const &w) | 
| Reduce a word with no enumeration. | |
| template<typename Thing> | |
| Thing::native_word_type | reduce_no_run_no_checks (Thing const &thing, typename Thing::native_word_type const &w) | 
| Reduce a word with no enumeration or checks. | |
| template<typename Word, typename Time> | |
| std::vector< Word >::const_iterator | redundant_rule (Presentation< Word > const &p, Time t) | 
| Return an iterator pointing at the left hand side of a redundant rule. | |
| template<typename Word> | |
| Word | word_of (ToddCoxeter< Word > &tc, index_type i) | 
| Returns a word representing a class with given index. | |
| template<typename Word> | |
| Word | word_of_no_checks (ToddCoxeter< Word > &tc, index_type i) | 
| Returns a word representing a class with given index. | |
| void add_generating_pair | ( | Thing & | thing, | 
| typename Thing::native_word_type const & | u, | ||
| typename Thing::native_word_type const & | v ) | 
Defined in cong-common-helpers.hpp.
This function can be used to add a generating pair to thing using objects themselves rather than iterators.
| Thing | the type of the first parameter must be one of Kambites, KnuthBendix, ToddCoxeter, or Congruence. | 
| thing | the object to add generating pairs to. | 
| u | the left hand side of the pair to add. | 
| v | the right hand side of the pair to add. | 
| LibsemigroupsException | if any of the values pointed at by the iterators is out of range, i.e. they do not belong to presentation().alphabet()andPresentation::validate_wordthrows. | 
| void add_generating_pair_no_checks | ( | Thing & | thing, | 
| typename Thing::native_word_type const & | u, | ||
| typename Thing::native_word_type const & | v ) | 
Defined in cong-common-helpers.hpp.
This function can be used to add a generating pair to thing using objects themselves rather than iterators.
| Thing | the type of the first parameter must be one of Kambites, KnuthBendix, ToddCoxeter, or Congruence. | 
| thing | the object to add generating pairs to. | 
| u | the left hand side of the pair to add. | 
| v | the right hand side of the pair to add. | 
presentation().alphabet(). | 
 | nodiscard | 
Defined in cong-common-helpers.hpp.
This function checks whether or not the words u and v are contained in the congruence represented by thing. This function triggers a full enumeration of thing, which may never terminate.
| Thing | the type of the first parameter must be one of Kambites, KnuthBendix, ToddCoxeter, or Congruence. | 
| thing | the object to check containment in. | 
| u | the left hand side of the pair to add. | 
| v | the right hand side of the pair to add. | 
| LibsemigroupsException | if any of the values pointed at by the iterators is out of range, i.e. they do not belong to presentation().alphabet()andPresentation::validate_wordthrows. | 
| 
 | nodiscard | 
Defined in cong-common-helpers.hpp.
This function checks whether or not the words u and v are contained in the congruence represented by thing. This function triggers a full enumeration of thing, which may never terminate.
| Thing | the type of the first parameter must be one of Kambites, KnuthBendix, ToddCoxeter, or Congruence. | 
| thing | the object to check containment in. | 
| u | the left hand side of the pair to add. | 
| v | the right hand side of the pair to add. | 
presentation().alphabet(). | 
 | nodiscard | 
Defined in cong-common-helpers.hpp.
This function checks whether or not the words u and v are already known to be contained in the congruence represented by thing. This function performs no enumeration of thing, so it is possible for the words to be contained in the congruence, but that this is not currently known.
| Thing | the type of the first parameter must be one of Kambites, KnuthBendix, ToddCoxeter, or Congruence. | 
| thing | the object to check containment in. | 
| u | the first word. | 
| v | the second word. | 
| LibsemigroupsException | if any of the values pointed at by the iterators is out of range, i.e. they do not belong to presentation().alphabet()andPresentation::validate_wordthrows. | 
| 
 | nodiscard | 
Defined in cong-common-helpers.hpp.
This function checks whether or not the words u and v are already known to be contained in the congruence represented by thing. This function performs no enumeration of thing, so it is possible for the words to be contained in the congruence, but that this is not currently known.
| Thing | the type of the first parameter must be one of Kambites, KnuthBendix, ToddCoxeter, or Congruence. | 
| thing | the object to check containment in. | 
| u | the first word. | 
| v | the second word. | 
presentation().alphabet(). | 
 | nodiscard | 
Defined in cong-common-helpers.hpp.
This function returns the classes with size at least \(2\) in the partition of the words in the range r according to thing. This function triggers a full enumeration of thing.
| Thing | the type of the first parameter must be one of Kambites, KnuthBendix, ToddCoxeter, or Congruence. | 
| Range | the type of the input range of words, must satisfy std::enable_if_t<rx::is_input_or_sink_v<Range>>andRange::output_typemust decay toThing::native_word_type. | 
| thing | the object used to partition r. | 
| r | the input range of words. | 
| LibsemigroupsException | if the input range of words is infinite. | 
| auto normal_forms | ( | Kambites< Word > & | k | ) | 
Defined in kambites.hpp.
This function returns a range object containing short-lex normal forms of the classes of the congruence represented by a Kambites instance.
| Word | the type of the words contained in the parameter k. | 
| k | the Kambites instance. | 
| LibsemigroupsException | if the Kambites::small_overlap_class of kis not at least \(4\). | 
| 
 | nodiscard | 
Defined in cong-common-helpers.hpp.
This function returns the partition of the words in the range r induced by the object thing. This function triggers a full enumeration of thing.
| Thing | the type of the first parameter must be one of Kambites, KnuthBendix, ToddCoxeter, or Congruence. | 
| Range | the type of the input range of words, must satisfy std::enable_if_t<rx::is_input_or_sink_v<Range>>andRange::output_typemust decay toThing::native_word_type. | 
| thing | the object used to partition r. | 
| r | the input range of words. | 
| LibsemigroupsException | if the input range of words is infinite. | 
| 
 | nodiscard | 
Defined in cong-common-helpers.hpp.
This function returns a reduced word equivalent to the input word w in the congruence represented by thing. This function triggers a full enumeration of thing. The output word is a normal form for the input word.
| Thing | the type of the first parameter must be one of Kambites, KnuthBendix, ToddCoxeter, or Congruence. | 
| thing | the object to reduce words in. | 
| w | the word to reduce. | 
w.| LibsemigroupsException | if any of the values pointed at by the iterators is out of range, i.e. they do not belong to presentation().alphabet()andPresentation::validate_wordthrows. | 
| 
 | nodiscard | 
Defined in cong-common-helpers.hpp.
This function returns a reduced word equivalent to the input word w in the congruence represented by thing. This function triggers a full enumeration of thing. The output word is a normal form for the input word.
| Thing | the type of the first parameter must be one of Kambites, KnuthBendix, ToddCoxeter, or Congruence. | 
| thing | the object to reduce words in. | 
| w | the word to reduce. | 
w.presentation().alphabet(). | 
 | nodiscard | 
Defined in cong-common-helpers.hpp.
This function returns a reduced word equivalent to the input word w in the congruence represented by thing. This function triggers no enumeration of thing. The word output by this function is equivalent to the input word in the congruence. If thing is finished, then the output word is a normal form for the input word. If thing is not finished, then it might be that equivalent input words produce different output words.
| Thing | the type of the first parameter must be one of Kambites, KnuthBendix, ToddCoxeter, or Congruence. | 
| thing | the object to reduce words in. | 
| w | the word to reduce. | 
w.| LibsemigroupsException | if any of the values pointed at by the iterators is out of range, i.e. they do not belong to presentation().alphabet()andPresentation::validate_wordthrows. | 
| 
 | nodiscard | 
Defined in cong-common-helpers.hpp.
This function returns a reduced word equivalent to the input word w in the congruence represented by thing. This function triggers no enumeration of thing. The word output by this function is equivalent to the input word in the congruence. If thing is finished, then the output word is a normal form for the input word. If thing is not finished, then it might be that equivalent input words produce different output words.
| Thing | the type of the first parameter must be one of Kambites, KnuthBendix, ToddCoxeter, or Congruence. | 
| thing | the object to reduce words in. | 
| w | the word to reduce. | 
w.presentation().alphabet().