Files | |
file | accessible.hh |
Algorithms for accessible/coaccessible states computation. | |
file | aci_canonical.hh |
Declaration for the canonical() algorithm. | |
file | aut_to_exp.hh |
This file provides converter from automaton to expression. | |
file | backward_realtime.hh |
Algorithms to make an automaton realtime. | |
file | complement.hh |
Complementation algorithm for Boolean automata. | |
file | complete.hh |
Completion algorithm for deterministic and Boolean automaton. | |
file | composition_cover.hh |
Composition for normalized and sub-normalized transducers seen as automata over a free monoid product. | |
file | concatenate.hh |
This file provides the general concatenation algorithm. | |
file | derived_term_automaton.hh |
Provides a converter from expression to automaton based on derivatives. | |
file | determinize.hh |
Boolean automata determinization. | |
file | eps_removal.hh |
This files declares the backward and forward eps_removal algorithm. | |
file | eval.hh |
This file provides the evaluation of a word w.r.t an automaton. | |
file | evaluation.hh |
Undocumented stuff. | |
file | evaluation_fmp.hh |
Evaluation over normalized and sub-normalized transducers seen as automata over a free monoid product. | |
file | extension.hh |
Declarations for extension(). | |
file | finite_support_conversion.hh |
Conversion between finite support application types. | |
file | fmp_to_realtime.hh |
This file provides a transformation function that computes the equivalent transducer of a FMP automaton. | |
file | forward_realtime.hh |
Algorithms to make an automaton realtime. | |
file | initial_derivation.hh |
Declaration of the initial derivation visitor, used for smart_derivative_automaton. | |
file | outsplitting.hh |
Outsplitting and insplitting algorithms for normalized and sub-normalized fmp_transducers. | |
file | is_ambiguous.hh |
Test for ambiguity. | |
file | is_letterized.hh |
Letter-to-letter feature testing. | |
file | is_normalized.hh |
Test for transducer normalization. | |
file | is_realtime.hh |
Test for realtime transducers. | |
file | isomorph.hh |
file | krat_exp_cderivation.hh |
Declaration for the cderivate() algorithms. | |
file | krat_exp_constant_term.hh |
Declaration for the constant_term() algorithm. | |
file | krat_exp_derivation.hh |
Declaration for the derivate() algorithms. | |
file | krat_exp_flatten.hh |
This file holds the declaration of the flatten() algorithm. | |
file | krat_exp_linearize.hh |
Declarations for the linearize() algorithm. | |
file | krat_exp_partial_derivation.hh |
Declarations for the partial_derivate() algorithm. | |
file | krat_exp_realtime.hh |
Declarations of the realtime() algorithm for rational expressions. | |
file | letter_to_letter_composition.hh |
Undocumented stuff. | |
file | minimization_hopcroft.hh |
This file provides minimization and quotient algorithms. | |
file | minimization_moore.hh |
This file containes the declaration of minimization_moore(). | |
file | normalized.hh |
Thompson normalization operations. | |
file | normalized_composition.hh |
Composition for normalized and sub-normalized transducers seen as automata over a free monoid product. | |
file | product.hh |
Declarations of product(). | |
file | projection.hh |
Undocumented stuff. | |
file | projections_fmp.hh |
Domain and Image projection for transducers seen as automata over a free monoid product. | |
file | realtime.hh |
General algorithms concerning realtime aspect of automata. | |
file | realtime_composition.hh |
Undocumented stuff. | |
file | realtime_decl.hh |
Declaration of the realtime() function. | |
file | realtime_to_fmp.hh |
This file provides a transformation function that computes the equivalent FMP automaton of a tranducer. | |
file | search.hh |
Rational expression search in text. | |
file | standard.hh |
Several algorithms concerning standard automata. | |
file | standard_of.hh |
This file provides a converter from expression to standard automaton. | |
file | sub_automaton.hh |
This file provides the extraction of sub automaton. | |
file | sub_normalize.hh |
Sub-normalization algorithm for FMP transducers. | |
file | sum.hh |
Summing of automata. | |
file | thompson.hh |
The thompson automaton. | |
file | algorithms/transpose.hh |
This file contain the function which transpose an automaton. | |
file | trim.hh |
Declaration of useful_states() and trim(). | |
Classes | |
struct | KRatExpFlatten |
struct | linearize_element |
The types of a linearized expression. More... | |
struct | FindBestSearch |
Specific implementation for search(). More... | |
struct | WindowedBackSearch |
Specific implementation for search(). More... | |
Determinization algorithms | |
template<typename A, typename T> | |
Element< A, T > | vcsn::determinize (const Element< A, T > &a) |
Returns the determinized of a Boolean automaton. | |
template<typename A, typename T> | |
Element< A, T > | vcsn::determinize (const Element< A, T > &a, std::map< hstate_t, std::set< hstate_t > > &) |
Returns the determinized of a Boolean automaton. | |
FMP automaton to realtime transducer algorithm. | |
template<typename S, typename T, typename SS, typename TT> | |
Element< SS, TT > & | vcsn::fmp_to_realtime (const Element< S, T > &fmp, Element< SS, TT > &res) |
Compute the equivalent transducer of a FMP automaton. | |
Product algorithm | |
template<typename A, typename T, typename U> | |
Element< A, T > | vcsn::product (const Element< A, T > &lhs, const Element< A, U > &rhs, const bool use_geometry=false) |
Returns a fresh automaton that is the product of the two input ones. | |
template<typename A, typename T, typename U> | |
Element< A, T > | vcsn::product (const Element< A, T > &lhs, const Element< A, U > &rhs, std::map< hstate_t, std::pair< hstate_t, hstate_t > > &, const bool use_geometry=false) |
Returns a fresh automaton that is the product of the two input ones. | |
Realtime transducer to FMP automaton algorithm | |
template<typename S, typename T, typename SS, typename TT> | |
Element< SS, TT > & | vcsn::realtime_to_fmp (const Element< S, T > &trans, Element< SS, TT > &res) |
Compute the equivalent FMP automaton of a transducer. | |
Enumerations | |
enum | vcsn::realtime_type |
Enum to indicate which kind of realtime algorithms must be used. | |
Functions | |
template<typename A, typename T> | |
std::set< hstate_t > | vcsn::accessible_states (const Element< A, T > &a) |
Return accessible states. | |
template<typename A, typename T> | |
Element< A, T > | vcsn::accessible (const Element< A, T > &a) |
Extract the sub-automaton composed of accessible states. | |
template<typename A, typename T> | |
void | vcsn::accessible_here (Element< A, T > &a) |
In-place extract the sub-automaton of accessible states. | |
template<typename A, typename T> | |
std::set< hstate_t > | vcsn::coaccessible_states (const Element< A, T > &a) |
Return co-accessible states. | |
template<typename A, typename T> | |
Element< A, T > | vcsn::coaccessible (const Element< A, T > &a) |
Extract the sub-automaton composed of co-accessible states. | |
template<typename A, typename T> | |
void | vcsn::coaccessible_here (Element< A, T > &a) |
In-place extract the sub-automaton of co-accessible states. | |
template<class Series, class T> | |
Element< Series, T > | vcsn::canonical (const Element< Series, T > &exp) |
Transform a krat expression into its canonical form, following aci-rules. | |
template<typename A, typename T> | |
Element< A, T >::series_set_elt_t | vcsn::aut_to_exp (const Element< A, T > &a) |
Returns a series which describes the language of the automaton. | |
template<typename A, typename T, typename Chooser_> | |
Element< A, T >::series_set_elt_t | vcsn::aut_to_exp (const Element< A, T > &a, const Chooser_ &c) |
Returns a series which describes the language of the automaton. | |
template<typename A, typename T> | |
void | vcsn::backward_realtime_here (Element< A, T > &a) |
In place modification of the automaton to make it realtime. | |
template<typename A, typename T> | |
Element< A, T > | vcsn::backward_realtime (const Element< A, T > &a) |
Returns a fresh realtime automaton. | |
template<typename A, typename T, typename Exp> | |
void | vcsn::berry_sethi (Element< A, T > &, const Exp &) |
Build an automaton from an expression using the Berry-Sethi construction. | |
template<typename A, typename T, typename Exp> | |
void | vcsn::brzozowski (Element< A, T > &, const Exp &) |
Build an automaton from an expression using the Brzozowski construction. | |
template<typename A, typename T> | |
void | vcsn::complement_here (Element< A, T > &a) |
Complement in place the set of final states. | |
template<typename A, typename T> | |
Element< A, T > | vcsn::complement (const Element< A, T > &a) |
Complement the set of final states. | |
template<typename A, typename T> | |
void | vcsn::complete_here (Element< A, T > &a) |
Make the transition function of an automaton total w.r.t alphabet. | |
template<typename A, typename T> | |
Element< A, T > | vcsn::complete (const Element< A, T > &a) |
Make the transition function of an automaton total w.r.t alphabet. | |
template<class A, class T> | |
bool | vcsn::is_complete (const Element< A, T > &a) |
Test if the transition function is complete for each state. | |
template<typename S, typename T> | |
Element< S, T > | vcsn::composition_cover (const Element< S, T > &fmp) |
Facade for composition cover. | |
template<typename S, typename T> | |
void | vcsn::composition_cover (const Element< S, T > &fmp, Element< S, T > &ret) |
template<typename S, typename T> | |
Element< S, T > | vcsn::composition_co_cover (const Element< S, T > &fmp) |
Facade for composition co-cover. | |
template<typename S, typename T> | |
void | vcsn::composition_co_cover (const Element< S, T > &fmp, Element< S, T > &ret) |
template<class A, class T> | |
Element< A, T > | vcsn::concatenate (const Element< A, T > &lhs, const Element< A, T > &rhs) |
Return the concatenation of two automata. | |
template<class A, class T> | |
void | vcsn::concatenate_here (Element< A, T > &lhs, const Element< A, T > &rhs) |
In place concatenation of two automata. | |
template<typename A, typename T, typename Exp> | |
void | vcsn::derived_term_automaton (Element< A, T > &a, const Exp &e) |
Convert a krat expression into an automaton using derivatives. | |
template<typename A, typename T, typename Exp> | |
void | vcsn::broken_derived_term_automaton (Element< A, T > &a, const Exp &e) |
template<typename A, typename T, typename Exp> | |
Element< A, T > | vcsn::derived_term_automaton (const Exp &e) |
Convert a krat expression into an automaton using derivatives. | |
template<typename A, typename T, typename Exp> | |
Element< A, T > | vcsn::broken_derived_term_automaton (const Exp &e) |
Convert a krat expression into an automaton using derivatives. | |
template<typename A, typename T> | |
bool | vcsn::is_deterministic (const Element< A, T > &a) |
Test if an automaton is deterministic. | |
template<typename A, typename T> | |
void | vcsn::eps_removal_here (Element< A, T > &a, bool bck=true) |
In place eps_removal of an automaton (default is backward eps_removal). | |
template<typename A, typename T> | |
Element< A, T > | vcsn::eps_removal (const Element< A, T > &a, bool bck=true) |
Eps_Removal of an automaton (default is backward eps_removal). | |
template<typename A, typename T> | |
void | vcsn::backward_eps_removal_here (Element< A, T > &a) |
In place backward eps_removal of an automaton. | |
template<typename A, typename T> | |
Element< A, T > | vcsn::backward_eps_removal (const Element< A, T > &a) |
Backward eps_removal of an automaton. | |
template<typename A, typename T> | |
void | vcsn::forward_eps_removal_here (Element< A, T > &a) |
In place forward eps_removal of an automaton. | |
template<typename A, typename T> | |
Element< A, T > | vcsn::forward_eps_removal (const Element< A, T > &a) |
Forward eps_removal of an automaton. | |
template<typename A, typename T, typename W> | |
Element< A, T >::semiring_elt_t | vcsn::eval (const Element< A, T > &a, const W &word) |
Return the image of a word by an automaton. | |
template<typename SA, typename TA, typename ST, typename TT, typename SARET, typename TARET> | |
void | vcsn::evaluation (const Element< SA, TA > &, const Element< ST, TT > &, Element< SARET, TARET > &) |
Evaluate for a "letterized" automaton and a realtime transducer. | |
template<typename SA, typename TA, typename ST, typename TT, typename M> | |
void | vcsn::partial_1 (const Element< SA, TA > &, const Element< ST, TT > &, M &) |
template<typename SA, typename TA, typename ST, typename TT, typename Exp> | |
void | vcsn::partial_2 (const Element< SA, TA > &, const Element< ST, TT > &, const hstate_t, Exp &) |
template<typename SA, typename TA, typename ST, typename TT, typename M> | |
void | vcsn::partial_3 (const Element< SA, TA > &, const Element< ST, TT > &, const hstate_t, M &) |
template<typename SA, typename TA, typename ST, typename TT, typename SARET, typename TARET> | |
void | vcsn::evaluation_fmp (const Element< ST, TT > &, const Element< SA, TA > &, Element< SARET, TARET > &) |
Evaluation over normalized and sub-normalized transducers, seen as automata over a free monoid product. | |
template<typename S, typename T> | |
identity_transducer_helper< S, T >::ret | vcsn::extension (const Element< S, T > &) |
Extend an automaton to a transducer. | |
template<typename SA, typename TA, typename ST, typename TT> | |
Element< ST, TT > | vcsn::extension (const Element< SA, TA > &, const Element< ST, TT > &) |
Extend an automaton to a transducer. | |
template<typename S, typename T, typename Ss, typename Ts> | |
void | vcsn::finite_support_convert (Element< S, T > &dst, const Element< Ss, Ts > &org) |
Finite support conversion. | |
template<typename A, typename T> | |
void | vcsn::forward_realtime_here (Element< A, T > &a) |
In place modification of the automaton to make it realtime. | |
template<typename A, typename T> | |
Element< A, T > | vcsn::forward_realtime (const Element< A, T > &a) |
Returns a fresh realtime automaton. | |
template<typename S, typename A> | |
bool | vcsn::is_ambiguous (const Element< S, A > &aut) |
Test the ambiguity of automaton. | |
template<typename S, typename A> | |
bool | vcsn::is_letterized_transducer (const Element< S, A > &t) |
Test the letter to letter features. | |
template<typename S, typename A> | |
bool | vcsn::is_normalized_transducer (const Element< S, A > &t) |
Test the normalization of transducer. | |
template<typename A, typename T> | |
bool | vcsn::are_isomorphic (const Element< A, T > &a, const Element< A, T > &b) |
Returns true if the two automata are isomorphic. | |
template<class Series, class T, class Letter> | |
Element< Series, T > | vcsn::cderivate (const Element< Series, T > &exp, Letter a) |
The c-derivative of the krat expression w.r.t to a letter. | |
template<class Series, class T, class Word> | |
Element< Series, T > | vcsn::word_cderivate (const Element< Series, T > &exp, Word a) |
The c-derivative of the krat expression w.r.t to a word. | |
template<class Series, class T> | |
std::pair< typename Element< Series, T >::semiring_elt_t, bool > | vcsn::constant_term (const Element< Series, T > &exp) |
Return the constant term of the krat expression. | |
template<class Series, class T, class Letter> | |
std::pair< Element< Series, T >, bool > | vcsn::derivate (const Element< Series, T > &exp, Letter a) |
The antimirov derivative of the krat expression w.r.t to a letter. | |
template<class Series, class T, class Word> | |
std::pair< Element< Series, T >, bool > | vcsn::word_derivate (const Element< Series, T > &exp, Word a) |
The antimirov derivative of the krat expression w.r.t to a word. | |
template<class Series, class T> | |
std::list< typename Series::monoid_t::alphabet_t::letter_t > | vcsn::flatten (const Element< Series, T > &exp) |
This algorithm extracts the letters from a rational expression. | |
template<class Series, class T> | |
linearize_element< Series, T >::element_t | vcsn::linearize (const Element< Series, T > &exp) |
The linearization of the krat expression. | |
template<class Series, class T, class Letter> | |
std::pair< std::set< Element< Series, T > >, bool > | vcsn::partial_derivate (const Element< Series, T > &exp, Letter a) |
The partial derivative of the krat expression w.r.t to a letter. | |
template<class S, class T> | |
Element< S, T > | vcsn::letter_to_letter_composition (const Element< S, T > &lhs, const Element< S, T > &rhs) |
Undocumented. | |
template<typename A, typename T> | |
Element< A, T > | vcsn::minimization_hopcroft (const Element< A, T > &a) |
Return the minimal automaton using the hopcroft algorithm. | |
template<typename A, typename T> | |
Element< A, T > | vcsn::quotient (const Element< A, T > &a) |
Return the quotient of a non-deterministic acceptor. | |
template<typename A, typename T> | |
Element< A, T > | vcsn::minimization_moore (const Element< A, T > &a) |
Returns the minimal deterministic automaton associated to the input one. | |
template<typename A, typename T> | |
Element< A, T > | vcsn::co_minimization_moore (const Element< A, T > &a) |
Returns the co-minimal co-deterministic automaton associated to the input one. | |
template<typename A, typename T> | |
void | vcsn::minimization_moore_here (Element< A, T > &a) |
Minimalize the deterministic input automaton. | |
template<typename A, typename T> | |
void | vcsn::co_minimization_moore_here (Element< A, T > &a) |
Co-minimalize the co-deterministic input automaton. | |
template<typename A, typename T> | |
Element< A, T > | vcsn::normalize (const Element< A, T > &a) |
Return the fresh thompson-normalized automaton. | |
template<typename A, typename T> | |
void | vcsn::normalize_here (Element< A, T > &a) |
In-place normalize to the thompson form. | |
template<typename A, typename T> | |
bool | vcsn::is_normalized (const Element< A, T > &a) |
Return true if the input automaton is thompson-normalized. | |
template<typename A, typename T, typename U> | |
void | vcsn::union_of_normalized_here (Element< A, T > &lhs, const Element< A, U > &rhs) |
Do the in-place union of two thompson-normalized automata. | |
template<typename A, typename T, typename U> | |
Element< A, T > | vcsn::union_of_normalized (const Element< A, T > &lhs, const Element< A, U > &rhs) |
Return the fresh union of two thompson-normalized automata. | |
template<typename A, typename T, typename U> | |
void | vcsn::concatenate_of_normalized_here (Element< A, T > &lhs, const Element< A, U > &rhs) |
Do the in-place concatenation of two thompson-normalized automata. | |
template<typename A, typename T, typename U> | |
Element< A, T > | vcsn::concatenate_of_normalized (const Element< A, T > &lhs, const Element< A, U > &rhs) |
Return the fresh concatenation of two thompson-normalized automata. | |
template<typename A, typename T> | |
void | vcsn::star_of_normalized_here (Element< A, T > &a) |
Do in-place star transformation on the thompson-normalized input. | |
template<typename A, typename T> | |
Element< A, T > | vcsn::star_of_normalized (const Element< A, T > &a) |
Return the fresh star transformation of its normalized input. | |
template<typename S, typename T> | |
void | vcsn::compose (const Element< S, T > &lhs, const Element< S, T > &rhs, Element< S, T > &ret) |
Facade for compose. | |
template<typename S, typename T> | |
Element< S, T > | vcsn::compose (const Element< S, T > &lhs, const Element< S, T > &rhs) |
Composition for unweighted normalized and sub-normalized transducers, seen as automata over a free monoid product. | |
template<typename S, typename T> | |
void | vcsn::u_compose (const Element< S, T > &lhs, const Element< S, T > &rhs, Element< S, T > &ret) |
Facade for unambiguous composition. | |
template<typename S, typename T> | |
Element< S, T > | vcsn::u_compose (const Element< S, T > &lhs, const Element< S, T > &rhs) |
Unambiguous composition for unweighted normalized and sub-normalized transducers, seen as automata over a free monoid product. | |
template<class ST, class TT, class SA, class TA> | |
void | vcsn::output_projection (const Element< ST, TT > &, Element< SA, TA > &) |
template<class S, class T> | |
output_projection_helper< S, T >::ret | vcsn::output_projection (const Element< S, T > &, std::map< hstate_t, hstate_t > &m) |
template<class S, class T> | |
output_projection_helper< S, T >::ret | vcsn::output_projection (const Element< S, T > &) |
template<class S, class T> | |
input_projection_helper< S, T >::ret | vcsn::input_projection (const Element< S, T > &) |
template<typename A, typename T> | |
void | vcsn::realtime_here (Element< A, T > &a, realtime_type type) |
In place modification of the automaton to make it realtime. | |
template<typename A, typename T> | |
Element< A, T > | vcsn::realtime (const Element< A, T > &a, realtime_type type) |
Returns a fresh realtime automaton. | |
template<typename S, typename T> | |
void | vcsn::realtime_composition (const Element< S, T > &, const Element< S, T > &, Element< S, T > &) |
Composition for realtime transducers. | |
template<typename S, typename T> | |
Element< S, T > | vcsn::realtime_composition (const Element< S, T > &, const Element< S, T > &) |
Composition for realtime transducers. | |
template<typename S, typename T> | |
Element< S, T > | vcsn::realtime (const Element< S, T > &e) |
Calls the do_realtime function for rational expression or automata. | |
template<typename S, typename T> | |
void | vcsn::realtime_here (Element< S, T > &e) |
Calls the do_realtime_here function for rational expression or automata. | |
template<typename S, typename T> | |
bool | vcsn::is_realtime (const Element< S, T > &e) |
Test whether an automaton or a regular expression is realtime. | |
template<class InputIterator, class FoundFunctor, class Series, class T> | |
void | vcsn::search (const Element< Automata< Series >, T > &a, const InputIterator &begin, const InputIterator &end, typename Element< Automata< Series >, T >::letter_t eol, FoundFunctor &f) |
Search for a rational expression into a text. | |
template<class Series, class T, class StatesSet> | |
static unsigned int | vcsn::compute_distances (const Element< Automata< Series >, T > &a, std::vector< StatesSet > &distances) |
Compute distances from initial states to final states. | |
template<class InputIterator, class Series, class T, class StatesSet> | |
static std::pair< bool, unsigned int > | vcsn::window_backsearch (const misc::Window< InputIterator, typename Element< Automata< Series >, T >::letter_t > &w, const Element< Automata< Series >, T > &a, const std::vector< StatesSet > &distances) |
Back search inside a window. | |
template<class InputIterator, class FoundFunctor, class Series, class T> | |
static InputIterator | vcsn::confirm_and_report_match (const misc::Window< InputIterator, typename Element< Automata< Series >, T >::letter_t > &w, const Element< Automata< Series >, T > &a, FoundFunctor &f) |
Finds the longest match of a starting from w, and report it to the functor. | |
template<typename A, typename T> | |
void | vcsn::standardize (Element< A, T > &a) |
Returns a standard automaton associated to the input. | |
template<typename A, typename T> | |
bool | vcsn::is_standard (const Element< A, T > &a) |
Returns true if the input automaton is standard. | |
template<typename A, typename T, typename U> | |
void | vcsn::union_of_standard_here (Element< A, T > &lhs, const Element< A, U > &rhs) |
In-place union of two standard automata. | |
template<typename A, typename T, typename U> | |
Element< A, T > | vcsn::union_of_standard (const Element< A, T > &lhs, const Element< A, U > &rhs) |
Return a fresh union of two standard automata. | |
template<typename A, typename T, typename U> | |
void | vcsn::concat_of_standard_here (Element< A, T > &lhs, const Element< A, U > &rhs) |
In-place concatenation of two standard automata. | |
template<typename A, typename T, typename U> | |
Element< A, T > | vcsn::concat_of_standard (const Element< A, T > &lhs, const Element< A, U > &rhs) |
Return a fresh concatenation of two standard automata. | |
template<typename A, typename T> | |
void | vcsn::star_of_standard_here (Element< A, T > &a) |
In-place star transformation of a standard automata. | |
template<typename A, typename T> | |
Element< A, T > | vcsn::star_of_standard (const Element< A, T > &a) |
Return the fresh star transformation of a standard automata. | |
template<typename A, typename T, typename Exp> | |
void | vcsn::standard_of (Element< A, T > &a, const Exp &e) |
Convert a rational expression into a standard automaton. | |
template<typename A, typename T, typename Exp> | |
Element< A, T > | vcsn::standard_of (const Exp &e) |
Convert a rational expression into a standard automaton. | |
template<typename A, typename T, typename StatesSet> | |
Element< A, T > | vcsn::sub_automaton (const Element< A, T > &a, const StatesSet &s, bool check_states=true) |
Returns a fresh automaton that is the sub-automaton defined by a set. | |
template<typename A, typename T, typename StatesSet> | |
void | vcsn::sub_automaton_here (Element< A, T > &a, const StatesSet &s, bool check_states=true) |
Select a sub-automaton into a given automaton. | |
template<class S, class T> | |
Element< S, T > | vcsn::sub_normalize (const Element< S, T > &a) |
Sub-normalize a FMP transducer. | |
template<class S, class T1, class T2> | |
void | vcsn::sub_normalize (const Element< S, T1 > &a, Element< S, T2 > &res) |
Sub-normalize a FMP transducer. | |
template<class S, class T> | |
void | vcsn::sub_normalize_here (Element< S, T > &a) |
Sub-normalize a FMP transducer, in place version. | |
template<class S, class T> | |
bool | vcsn::is_sub_normalized (const Element< S, T > &a) |
Check if a FMP transducer is sub-normalized. | |
template<typename A, typename T, typename U> | |
void | vcsn::sum_here (Element< A, T > &lhs, const Element< A, U > &rhs) |
In place summing of two automata. | |
template<typename A, typename T, typename U> | |
Element< A, T > | vcsn::sum (const Element< A, T > &lhs, const Element< A, U > &rhs) |
Summing of two automata. | |
template<typename A, typename T, typename Letter, typename Weight> | |
void | vcsn::thompson_of (Element< A, T > &out, const rat::exp< Letter, Weight > &kexp) |
The Thompson automaton associated to the krat expression. | |
template<class AutoType, class S, class T> | |
Element< Automata< S >, AutoType > | vcsn::thompson_of (const Element< S, T > &exp) |
The Thompson automaton associated to the krat expression. | |
template<typename lhs_t, typename rhs_t> | |
void | vcsn::transpose (lhs_t &dst, const rhs_t &from) |
Transposition of an automaton. | |
template<typename auto_t> | |
auto_t | vcsn::transpose (const auto_t &from) |
Return a fresh transposed automaton. | |
template<typename A, typename T> | |
std::set< hstate_t > | vcsn::useful_states (const Element< A, T > &a) |
Returns a useful states of the automaton (start reachable and final co-). | |
template<typename A, typename T> | |
Element< A, T > | vcsn::trim (const Element< A, T > &a) |
Return a fresh automaton in which non useful states are removed. | |
template<typename A, typename T> | |
void | vcsn::trim_here (Element< A, T > &a) |
Trim a. |
|
Return accessible states. This functions returns the accessible states set of its input automaton.
Definition at line 87 of file accessible.hxx. References vcsn::do_accessible_states(), and Element::structure(). Referenced by vcsn::accessible(), vcsn::accessible_here(), vcsn::do_coaccessible_states(), and vcsn::do_useful_states(). |
|
Extract the sub-automaton composed of accessible states. This function returns a fresh sub-automaton of its input containing only accessible states.
Definition at line 101 of file accessible.hxx. References vcsn::accessible_states(), and vcsn::sub_automaton(). |
|
In-place extract the sub-automaton of accessible states. This function computes the sub-autmaton of accessible states from its input automaton. The operation is performed in-place.
Definition at line 94 of file accessible.hxx. References vcsn::accessible_states(), and vcsn::sub_automaton_here(). Referenced by vcsn::do_in_standardize(). |
|
Return co-accessible states. This functions returns the co-accessible states set of its input automaton, i.e. states which are accessible from final states.
Definition at line 122 of file accessible.hxx. References vcsn::do_coaccessible_states(), and Element::structure(). Referenced by vcsn::coaccessible(), vcsn::coaccessible_here(), and vcsn::do_useful_states(). |
|
Extract the sub-automaton composed of co-accessible states. This function returns a fresh sub-automaton of its input containing only co-accessible states, i.e. states which are accessible from final states.
Definition at line 129 of file accessible.hxx. References vcsn::coaccessible_states(), and vcsn::sub_automaton(). |
|
In-place extract the sub-automaton of co-accessible states. This function computes the sub-autmaton of co-accessible states from its input automaton. The operation is performed in-place.
Definition at line 136 of file accessible.hxx. References vcsn::coaccessible_states(), and vcsn::sub_automaton_here(). |
|
Returns a series which describes the language of the automaton. This algorithm works on every kind of series. However, if, during the computation, it must take the star of it, it can fail. By passing a "generalized" automaton, that is an automaton with rational expression as label, you will be sure to have the algorithm succeed since we can always take the star of a rational expression.
Definition at line 398 of file aut_to_exp.hxx. Referenced by vcsn::do_partial_2(). |
|
Returns a series which describes the language of the automaton. This algorithm works on every kind of series. However, if, during the computation, it must take the star of it, it can fail. By passing a "generalized" automaton, that is an automaton with rational expression as label, you will be sure to have the algorithm succeed since we can always take the star of a rational expression.
Definition at line 390 of file aut_to_exp.hxx. References vcsn::do_in_aut_to_exp(), and Element::structure(). |
|
In place modification of the automaton to make it realtime. This function make an automaton realtime, using backward version of eps_removal for building.
Definition at line 235 of file backward_realtime.hxx. References vcsn::do_backward_realtime_here(), and Element::structure(). Referenced by vcsn::do_realtime_here(). |
|
Returns a fresh realtime automaton. This fonction build a fresh realtime automaton from those given, using backward version of eps_removal.
Definition at line 251 of file backward_realtime.hxx. References vcsn::do_backward_realtime(), and Element::structure(). Referenced by vcsn::do_realtime(). |
|
Complement in place the set of final states.
Definition at line 38 of file complement.hxx. References vcsn::is_complete(), vcsn::is_deterministic(), and precondition. Referenced by vcsn::complement(). |
|
Complement the set of final states.
Definition at line 57 of file complement.hxx. References vcsn::complement_here(). |
|
Make the transition function of an automaton total w.r.t alphabet.
Definition at line 36 of file complete.hxx. References Element::structure(). Referenced by vcsn::complete(). |
|
Make the transition function of an automaton total w.r.t alphabet.
Definition at line 73 of file complete.hxx. References vcsn::complete_here(). |
|
Test if the transition function is complete for each state.
Definition at line 86 of file complete.hxx. References Element::structure(). Referenced by vcsn::complement_here(). |
|
Return the concatenation of two automata. This function produces a new automata that realizes L(lhs).L(rhs).
Definition at line 59 of file concatenate.hxx. References vcsn::do_auto_in_concat(), and Element::structure(). |
|
In place concatenation of two automata. This function modifies lhs to concatenate the language L(rhs) to its language. It returns the concatenation of two automata using epsilon transitions.
Definition at line 68 of file concatenate.hxx. References vcsn::do_auto_in_concat(), and Element::structure(). |
|
Convert a krat expression into an automaton using derivatives. This algorithm produces an automaton from an expression using the Brzozowski construction. This construction involves multiple derivations on the initial expression.
Definition at line 164 of file derived_term_automaton.hxx. References vcsn::do_derived_term_automaton(). |
|
Convert a krat expression into an automaton using derivatives.
Definition at line 173 of file derived_term_automaton.hxx. References vcsn::do_derived_term_automaton(). |
|
Convert a krat expression into an automaton using derivatives. Derivations are first performed on the starting expression with the following formulae: d(0)={0}, d(1)={1}, d(a)={a} for all a in the alphabet, d(E+F)=d(E) union d(F), d(E.F)=[d(E)].F, d(E*)={E*}
Definition at line 216 of file derived_term_automaton.hxx. References vcsn::do_broken_derived_term_automaton(). |
|
Returns the determinized of a Boolean automaton.
Definition at line 156 of file determinize.hxx. |
|
Returns the determinized of a Boolean automaton.
Definition at line 164 of file determinize.hxx. References vcsn::do_determinize(), and Element::structure(). |
|
Test if an automaton is deterministic.
Definition at line 236 of file determinize.hxx. References vcsn::do_is_deterministic(), and Element::structure(). Referenced by vcsn::complement_here(). |
|
In place eps_removal of an automaton (default is backward eps_removal). This algorithm completes in place the given automaton to make it close over epsilon transition. It is based on the Floyd/McNaughton/Yamada algorithm.
Definition at line 178 of file eps_removal.hxx. References vcsn::do_eps_removal_here(), and Element::structure(). Referenced by vcsn::do_compose(), and vcsn::do_u_compose(). |
|
Eps_Removal of an automaton (default is backward eps_removal). This algorithm completes the given automaton into a copy to make it close over epsilon transition. It is based on the Floyd/McNaughton/Yamada algorithm.
Definition at line 185 of file eps_removal.hxx. References vcsn::do_eps_removal_here(), and Element::structure(). |
|
In place backward eps_removal of an automaton. This algorithm completes in place the given automaton to make it close over epsilon transition. It is based on the Floyd/McNaughton/Yamada algorithm.
Definition at line 194 of file eps_removal.hxx. References vcsn::do_eps_removal_here(), and Element::structure(). Referenced by vcsn::do_backward_realtime_here(). |
|
Backward eps_removal of an automaton. This algorithm completes in place the given automaton to make it close over epsilon transition. It is based on the Floyd/McNaughton/Yamada algorithm.
Definition at line 201 of file eps_removal.hxx. References vcsn::do_eps_removal_here(), and Element::structure(). |
|
In place forward eps_removal of an automaton. This algorithm completes in place the given automaton to make it close over epsilon transition. It is based on the Floyd/McNaughton/Yamada algorithm.
Definition at line 210 of file eps_removal.hxx. References vcsn::do_eps_removal_here(), and Element::structure(). Referenced by vcsn::do_forward_realtime_here(). |
|
Forward eps_removal of an automaton. This algorithm completes in place the given automaton to make it close over epsilon transition. It is based on the Floyd/McNaughton/Yamada algorithm.
Definition at line 217 of file eps_removal.hxx. References vcsn::do_eps_removal_here(), and Element::structure(). |
|
Return the image of a word by an automaton. eval(a, w) returns a series that is the image of the word 'w' in the automaton. This version of computation is the most general one : it works on every types of automaton, deterministic or not. Yet, the automaton must be realtime. Definition at line 105 of file eval.hxx. References Element::structure(). Referenced by vcsn::VCSN_CONTEXT_NAMESPACE::do_evaluation(), and vcsn::op_series_get(). |
|
Evaluation over normalized and sub-normalized transducers, seen as automata over a free monoid product.
Referenced by vcsn::VCSN_CONTEXT_NAMESPACE::do_evaluation(). |
|
Extend an automaton to a transducer. Extend an automaton to a transducer whose multiplicity is the series of the automaton. Definition at line 96 of file extension.hxx. References vcsn::do_extension(), and Element::structure(). Referenced by vcsn::do_evaluation(), vcsn::do_partial_1(), and vcsn::do_partial_2(). |
|
Extend an automaton to a transducer. Extend an automaton to a transducer whose set is the one of another transducer passed in the second argument. This extension is required if we want to make a product of an automaton with a transducer. If this is not the case, we need simply call extension(automaton_t) above. Definition at line 171 of file extension.hxx. References vcsn::do_extension(), and Element::structure(). |
|
Finite support conversion. This algorithm copies the value of a finite support application to another, possibly changing its type.
Definition at line 29 of file finite_support_conversion.hxx. References precondition, and Element::structure(). Referenced by usual_converter_poly::operator()(). |
|
Compute the equivalent transducer of a FMP automaton. Please note that for the moment this function works only if the support of each transition is finite. Algorithm : If the FMP contains transitions with "complex" expression (E), i.e. infinite support, then Thompson of E. With the resulting automaton apply a conversion. i.e. (a,x) -> a|x Definition at line 195 of file fmp_to_realtime.hxx. References vcsn::do_fmp_to_realtime(), and Element::structure(). |
|
In place modification of the automaton to make it realtime. This function make an automaton realtime, using forward version of eps_removal for building.
Definition at line 120 of file forward_realtime.hxx. References vcsn::do_forward_realtime_here(), and Element::structure(). Referenced by vcsn::do_realtime_here(). |
|
Returns a fresh realtime automaton. This fonction build a fresh realtime automaton from those given, using forward version of eps_removal.
Definition at line 137 of file forward_realtime.hxx. References vcsn::do_forward_realtime(), and Element::structure(). Referenced by vcsn::do_realtime(). |
|
Test the ambiguity of automaton.
|
|
Test the letter to letter features.
Definition at line 50 of file is_letterized.hxx. References vcsn::do_is_letterized_transducer(), and Element::structure(). |
|
Test the normalization of transducer.
Definition at line 50 of file is_normalized.hxx. References vcsn::do_is_normalized_transducer(), and Element::structure(). |
|
This algorithm extracts the letters from a rational expression. The flatten() function extracts the letters of a rational expression, keeping the order in which they appear in the expression. The result is just a std::list of letters, with letters having the same type as the expression's letter, i.e. Element<S, T>::monoid_elt_t::set_t::alphabet_t::letter_t.
Definition at line 123 of file krat_exp_flatten.hxx. References KRatExpFlatten::flatten(). |
|
Return the minimal automaton using the hopcroft algorithm.
Definition at line 307 of file minimization_hopcroft.hxx. References vcsn::do_hopcroft_minimization_det(). |
|
Return the quotient of a non-deterministic acceptor. This algorithms works with both Boolean and weighted automata.
Definition at line 861 of file minimization_hopcroft.hxx. References vcsn::do_quotient(), and SELECT. Referenced by vcsn::VCSN_CONTEXT_NAMESPACE::do_evaluation(). |
|
Returns the minimal deterministic automaton associated to the input one. Use Moore's algorithm to compute the minimal equivalent deterministic automaton. The complexity of this algorithm is O(n2). See minimize_hopcroft for O(nlogn).
Definition at line 250 of file minimization_moore.hxx. References Element::structure(). |
|
Returns the co-minimal co-deterministic automaton associated to the input one. Use Moore's algorithm to compute the minimal equivalent co-deterministic automaton. The complexity of this algorithm is O(n2).
Definition at line 269 of file minimization_moore.hxx. References Element::structure(). |
|
Minimalize the deterministic input automaton. Use Moore's algorithm to minimalize (in place) the input automaton. The complexity of this algorithm is O(n2). See minimize_hopcroft for O(nlogn).
Definition at line 240 of file minimization_moore.hxx. References Element::structure(). |
|
Co-minimalize the co-deterministic input automaton. Use Moore's algorithm to co-minimalize (in place) the input automaton. The complexity of this algorithm is O(n2). See minimize_hopcroft for O(nlogn).
Definition at line 259 of file minimization_moore.hxx. References Element::structure(). |
|
Return the fresh thompson-normalized automaton. This function returns the thompson-normalized automaton corresponding to its input.
Definition at line 60 of file normalized.hxx. References vcsn::do_normalize_here(), and Element::structure(). |
|
In-place normalize to the thompson form. This function performs the in-place thompson-normalization of its input.
Definition at line 69 of file normalized.hxx. References vcsn::do_normalize_here(), and Element::structure(). Referenced by vcsn::do_in_aut_to_exp(), and vcsn::do_invert_rw(). |
|
Return true if the input automaton is thompson-normalized. This function indicates whether its input automaton is thompson-normalized or not.
Definition at line 160 of file normalized.hxx. References vcsn::do_is_normalized(), and Element::structure(). Referenced by vcsn::do_in_aut_to_exp(), and vcsn::do_is_normalized_transducer(). |
|
Do the in-place union of two thompson-normalized automata. This function performs the in-place union of two thompson-normalized automata. The result is thompson-normalized.
Definition at line 116 of file normalized.hxx. References vcsn::do_union_of_normalized_here(), and Element::structure(). Referenced by ThompsonVisitor::sum(). |
|
Return the fresh union of two thompson-normalized automata. This function returns a fresh automaton which is the union of input automata. It is thompson-normalized.
Definition at line 125 of file normalized.hxx. References vcsn::do_union_of_normalized_here(), and Element::structure(). |
|
Do the in-place concatenation of two thompson-normalized automata. This function performs the in-place concatenation of two thompson-normalized automata. The result is thompson-normalized.
Definition at line 241 of file normalized.hxx. References vcsn::do_concatenate_of_normalized_here(), and Element::structure(). Referenced by ThompsonVisitor::product(). |
|
Return the fresh concatenation of two thompson-normalized automata. This function returns a fresh automaton which is the concatenation of input automata. It is thompson-normalized.
Definition at line 250 of file normalized.hxx. References vcsn::do_concatenate_of_normalized_here(), and Element::structure(). |
|
Do in-place star transformation on the thompson-normalized input. This function performs the in-place star transformation of a thompson-normalized automaton. The result is thompson-normalized.
Definition at line 286 of file normalized.hxx. References vcsn::do_star_of_normalized_here(), and Element::structure(). Referenced by ThompsonVisitor::star(). |
|
Return the fresh star transformation of its normalized input. This function performs a star transformation on its input, and returns it as a fresh automaton. The input must be thompson-normalized, and the result is thompson-normalized.
Definition at line 293 of file normalized.hxx. References vcsn::do_star_of_normalized_here(), and Element::structure(). |
|
Facade for compose.
Definition at line 416 of file normalized_composition.hxx. References vcsn::do_compose(), SELECT, and Element::structure(). Referenced by vcsn::do_evaluation_fmp(). |
|
Composition for unweighted normalized and sub-normalized transducers, seen as automata over a free monoid product.
Definition at line 436 of file normalized_composition.hxx. References vcsn::do_compose(), SELECT, and Element::structure(). |
|
Facade for unambiguous composition.
Definition at line 471 of file normalized_composition.hxx. References vcsn::do_u_compose(), SELECT, and Element::structure(). |
|
Unambiguous composition for unweighted normalized and sub-normalized transducers, seen as automata over a free monoid product.
Definition at line 489 of file normalized_composition.hxx. References vcsn::do_u_compose(), SELECT, and Element::structure(). |
|
In place modification of the automaton to make it realtime.
This algorithm makes an automaton realtime. It calls
Definition at line 65 of file realtime.hxx. References vcsn::do_realtime_here(), and Element::structure(). |
|
Returns a fresh realtime automaton.
As
Definition at line 88 of file realtime.hxx. References vcsn::do_realtime(), and Element::structure(). Referenced by vcsn::do_broken_derived_term_automaton(), vcsn::do_derived_term_automaton(), and vcsn::VCSN_CONTEXT_NAMESPACE::do_evaluation(). |
|
Calls the do_realtime function for rational expression or automata. This function is a wrapper which select a realtime either from realtime.hh or from krat_exp_realtime.hh. When called upon an automaton, this function uses the functions declared in realtime.hh to make this automaton realtime using the forward_realtime() algorithm. When called with a rational expression, a function from krat_exp_realtime.hh is selected to expand words in the expression as a product of a letter.
Definition at line 26 of file realtime_decl.hxx. References vcsn::do_realtime(), and Element::structure(). |
|
Calls the do_realtime_here function for rational expression or automata. This function is a wrapper which select a realtime either from realtime.hh or from krat_exp_realtime.hh. It behaves exactly as realtime(), but do the operation in place.
Definition at line 33 of file realtime_decl.hxx. References vcsn::do_realtime_here(), and Element::structure(). |
|
Test whether an automaton or a regular expression is realtime. This function returns true if the input is realtime.
Definition at line 40 of file realtime_decl.hxx. References vcsn::do_is_realtime(), and Element::structure(). |
|
Compute the equivalent FMP automaton of a transducer. Please note that for the moment this function works only if the support of each transition is finite. Preconditions : The transducer is realtime. The weight of each transition must have a finite support. Definition at line 235 of file realtime_to_fmp.hxx. References vcsn::do_realtime_to_fmp(), and Element::structure(). |
|
Search for a rational expression into a text. This function searches a rational expression into a text, given a iterator on the text and an automaton which recognizes the corresponding langage. The result cannot spread over two lines.
Definition at line 31 of file search.hxx. Referenced by FindBestSearch::search(). |
|
Compute distances from initial states to final states. For each i, compute the set of states reachable in i steps or less. the result is stored into a vector of set of states distances[i]. This algorithm stops when it first encounter a final state. The last i value is returned. Definition at line 65 of file search.hxx. References precondition. Referenced by WindowedBackSearch::search(). |
|
Back search inside a window. Returns whether the window is a potential match for the given automaton or not as the first element of the pair. The second element is the maximal value we can use to shift the window without skipping matches.
Definition at line 123 of file search.hxx. References precondition, and std::swap(). Referenced by WindowedBackSearch::search(). |
|
Returns a standard automaton associated to the input.
Definition at line 62 of file standard.hxx. References vcsn::do_in_standardize(), and Element::structure(). Referenced by vcsn::do_partial_elimination(). |
|
Returns true if the input automaton is standard.
Definition at line 166 of file standard.hxx. References vcsn::do_is_standard(), and Element::structure(). |
|
In-place union of two standard automata. This function make the union of two standard automata. The result is a standard automaton.
Definition at line 122 of file standard.hxx. References vcsn::do_union_of_standard_here(), and Element::structure(). Referenced by Standard_OfVisitor::MATCH__(). |
|
Return a fresh union of two standard automata.
As
Definition at line 131 of file standard.hxx. References vcsn::do_union_of_standard_here(), and Element::structure(). |
|
In-place concatenation of two standard automata. This function make the concatenation of two standard automata. The result is a standard automaton.
Definition at line 247 of file standard.hxx. References vcsn::do_concat_of_standard_here(), and Element::structure(). Referenced by Standard_OfVisitor::MATCH__(). |
|
Return a fresh concatenation of two standard automata.
As
Definition at line 256 of file standard.hxx. References vcsn::do_concat_of_standard_here(), and Element::structure(). |
|
In-place star transformation of a standard automata. This function make the star transformation of a standard automaton, and replace those given by the result.
Definition at line 311 of file standard.hxx. References vcsn::do_star_of_standard_here(), and Element::structure(). Referenced by Standard_OfVisitor::MATCH_(). |
|
Return the fresh star transformation of a standard automata.
As
Definition at line 318 of file standard.hxx. References vcsn::do_star_of_standard_here(), and Element::structure(). |
|
Convert a rational expression into a standard automaton.
Definition at line 214 of file standard_of.hxx. References vcsn::do_standard_of(), and Element::structure(). Referenced by vcsn::do_cut_up(), vcsn::do_invert_rw(), vcsn::do_partial_evaluation(), vcsn::do_realtime_composition(), vcsn::op_series_get(), and vcsn::standard_of(). |
|
Convert a rational expression into a standard automaton.
Definition at line 222 of file standard_of.hxx. References vcsn::standard_of(). |
|
Returns a fresh automaton that is the sub-automaton defined by a set.
Definition at line 58 of file sub_automaton.hxx. References vcsn::do_sub_automaton_here(), and Element::structure(). Referenced by vcsn::accessible(), vcsn::coaccessible(), and vcsn::trim(). |
|
Select a sub-automaton into a given automaton.
Definition at line 66 of file sub_automaton.hxx. References vcsn::do_sub_automaton_here(), and Element::structure(). Referenced by vcsn::accessible_here(), vcsn::coaccessible_here(), vcsn::do_compose(), vcsn::do_u_compose(), and vcsn::trim_here(). |
|
Sub-normalize a FMP transducer.
Definition at line 216 of file sub_normalize.hxx. References vcsn::do_sub_normalize(), and Element::structure(). Referenced by vcsn::do_evaluation_fmp(). |
|
Sub-normalize a FMP transducer.
|
|
Sub-normalize a FMP transducer, in place version.
Definition at line 234 of file sub_normalize.hxx. References vcsn::do_sub_normalize(), and Element::structure(). |
|
Check if a FMP transducer is sub-normalized.
Definition at line 240 of file sub_normalize.hxx. References vcsn::do_is_sub_normalized(), and Element::structure(). |
|
In place summing of two automata. This function adds states and transitions of an automaton to states and transitions of a second automaton.
Definition at line 88 of file sum.hxx. References vcsn::do_sum(), and Element::structure(). Referenced by vcsn::do_union_of_normalized_here(), and vcsn::do_union_of_standard_here(). |
|
Summing of two automata. This function returns the fresh union of two automata. It put transitions and states of the two automata together, and create a news one with the result.
Definition at line 96 of file sum.hxx. References vcsn::do_sum(), and Element::structure(). |
|
The Thompson automaton associated to the krat expression. This function build the automaton associated to the rational expression implemented by a krat_exp, using Thompson algorithm.
Definition at line 172 of file thompson.hxx. References vcsn::do_thompson_of(), and Element::structure(). Referenced by vcsn::thompson_of(). |
|
The Thompson automaton associated to the krat expression. This function build the automaton associated to the rational expression implemented by a krat_exp, using Thompson algorithm. The kind of returned automaton is a default one.
Definition at line 180 of file thompson.hxx. References AutoType, Element::structure(), vcsn::thompson_of(), and Element::value(). |
|
Transposition of an automaton.
This function copy in
Definition at line 27 of file algorithms/transpose.hxx. References vcsn::auto_copy(), and vcsn::transpose_view(). |
|
Return a fresh transposed automaton. This function returns the transposition of an automaton.
Definition at line 34 of file algorithms/transpose.hxx. References vcsn::transpose(). |