Vcsn  2.3
Be Rational
vcsn::detail::star_height_visitor< ExpSet > Class Template Reference

#include <star-height.hh>

Inheritance diagram for vcsn::detail::star_height_visitor< ExpSet >:
Collaboration diagram for vcsn::detail::star_height_visitor< ExpSet >:

Classes

struct  visit_tuple
 
struct  visit_tuple< false, Dummy >
 

Public Types

using expressionset_t = ExpSet
 
using super_t = typename expressionset_t::const_visitor
 
using self_t = star_height_visitor
 
using expression_t = typename expressionset_t::value_t
 
using context_t = context_t_of< expressionset_t >
 
using node_t = typename super_t::node_t
 

Public Member Functions

 star_height_visitor (const expressionset_t &rs)
 
unsigned operator() (const expression_t &v)
 The star height of v. More...
 

Static Public Member Functions

static constexpr const charme ()
 Name of this algorithm, for error messages. More...
 

Private Types

template<rat::type_t Type>
using unary_t = typename super_t::template unary_t< Type >
 
template<rat::type_t Type>
using variadic_t = typename super_t::template variadic_t< Type >
 
using tuple_t = typename super_t::tuple_t
 

Private Member Functions

unsigned recurse_ (const expression_t &v)
 Easy recursion: the star height of v, saving height_. More...
 
 VCSN_RAT_VISIT (add, v)
 
 VCSN_RAT_VISIT (atom,)
 
 VCSN_RAT_VISIT (complement, v)
 
 VCSN_RAT_VISIT (compose, v)
 
 VCSN_RAT_VISIT (conjunction, v)
 
 VCSN_RAT_VISIT (infiltrate, v)
 
 VCSN_RAT_VISIT (ldivide, v)
 
 VCSN_RAT_VISIT (lweight, v)
 
 VCSN_RAT_VISIT (mul, v)
 
 VCSN_RAT_VISIT (one,)
 
 VCSN_RAT_VISIT (rweight, v)
 
 VCSN_RAT_VISIT (shuffle, v)
 
 VCSN_RAT_VISIT (star, v)
 
 VCSN_RAT_VISIT (transposition, v)
 
 VCSN_RAT_VISIT (zero,)
 
template<rat::exp::type_t Type>
void visit_ (const unary_t< Type > &v)
 Traverse unary node. More...
 
template<rat::type_t Type>
void visit_ (const variadic_t< Type > &n)
 Traverse variadic node. More...
 
void visit (const tuple_t &v, std::true_type) override
 

Private Attributes

const expressionset_trs_
 The expressionset. More...
 
unsigned height_
 The current star height. More...
 

Detailed Description

template<typename ExpSet>
class vcsn::detail::star_height_visitor< ExpSet >

Definition at line 16 of file star-height.hh.

Member Typedef Documentation

template<typename ExpSet >
using vcsn::detail::star_height_visitor< ExpSet >::context_t = context_t_of<expressionset_t>

Definition at line 24 of file star-height.hh.

template<typename ExpSet >
using vcsn::detail::star_height_visitor< ExpSet >::expression_t = typename expressionset_t::value_t

Definition at line 23 of file star-height.hh.

template<typename ExpSet >
using vcsn::detail::star_height_visitor< ExpSet >::expressionset_t = ExpSet

Definition at line 20 of file star-height.hh.

template<typename ExpSet >
using vcsn::detail::star_height_visitor< ExpSet >::node_t = typename super_t::node_t

Definition at line 25 of file star-height.hh.

template<typename ExpSet >
using vcsn::detail::star_height_visitor< ExpSet >::self_t = star_height_visitor

Definition at line 22 of file star-height.hh.

template<typename ExpSet >
using vcsn::detail::star_height_visitor< ExpSet >::super_t = typename expressionset_t::const_visitor

Definition at line 21 of file star-height.hh.

template<typename ExpSet >
using vcsn::detail::star_height_visitor< ExpSet >::tuple_t = typename super_t::tuple_t
private

Definition at line 91 of file star-height.hh.

template<typename ExpSet >
template<rat::type_t Type>
using vcsn::detail::star_height_visitor< ExpSet >::unary_t = typename super_t::template unary_t<Type>
private

Definition at line 69 of file star-height.hh.

template<typename ExpSet >
template<rat::type_t Type>
using vcsn::detail::star_height_visitor< ExpSet >::variadic_t = typename super_t::template variadic_t<Type>
private

Definition at line 79 of file star-height.hh.

Constructor & Destructor Documentation

template<typename ExpSet >
vcsn::detail::star_height_visitor< ExpSet >::star_height_visitor ( const expressionset_t rs)
inline

Definition at line 30 of file star-height.hh.

Member Function Documentation

template<typename ExpSet >
static constexpr const char* vcsn::detail::star_height_visitor< ExpSet >::me ( )
inlinestatic

Name of this algorithm, for error messages.

Definition at line 28 of file star-height.hh.

template<typename ExpSet >
unsigned vcsn::detail::star_height_visitor< ExpSet >::operator() ( const expression_t v)
inline

The star height of v.

Definition at line 35 of file star-height.hh.

References vcsn::detail::star_height_visitor< ExpSet >::height_, and vcsn::detail::star_height_visitor< ExpSet >::recurse_().

Here is the call graph for this function:

template<typename ExpSet >
unsigned vcsn::detail::star_height_visitor< ExpSet >::recurse_ ( const expression_t v)
inlineprivate

Easy recursion: the star height of v, saving height_.

Definition at line 43 of file star-height.hh.

References vcsn::detail::star_height_visitor< ExpSet >::height_, and vcsn::res.

Referenced by vcsn::detail::star_height_visitor< ExpSet >::operator()(), and vcsn::detail::star_height_visitor< ExpSet >::visit_().

template<typename ExpSet >
vcsn::detail::star_height_visitor< ExpSet >::VCSN_RAT_VISIT ( add  ,
v   
)
inlineprivate

Definition at line 52 of file star-height.hh.

References vcsn::detail::v, and vcsn::detail::star_height_visitor< ExpSet >::visit_().

Here is the call graph for this function:

template<typename ExpSet >
vcsn::detail::star_height_visitor< ExpSet >::VCSN_RAT_VISIT ( atom  )
inlineprivate

Definition at line 53 of file star-height.hh.

template<typename ExpSet >
vcsn::detail::star_height_visitor< ExpSet >::VCSN_RAT_VISIT ( complement  ,
v   
)
inlineprivate

Definition at line 54 of file star-height.hh.

References vcsn::detail::v, and vcsn::detail::star_height_visitor< ExpSet >::visit_().

Here is the call graph for this function:

template<typename ExpSet >
vcsn::detail::star_height_visitor< ExpSet >::VCSN_RAT_VISIT ( compose  ,
v   
)
inlineprivate

Definition at line 55 of file star-height.hh.

References vcsn::detail::v, and vcsn::detail::star_height_visitor< ExpSet >::visit_().

Here is the call graph for this function:

template<typename ExpSet >
vcsn::detail::star_height_visitor< ExpSet >::VCSN_RAT_VISIT ( conjunction  ,
v   
)
inlineprivate

Definition at line 56 of file star-height.hh.

References vcsn::detail::v, and vcsn::detail::star_height_visitor< ExpSet >::visit_().

Here is the call graph for this function:

template<typename ExpSet >
vcsn::detail::star_height_visitor< ExpSet >::VCSN_RAT_VISIT ( infiltrate  ,
v   
)
inlineprivate

Definition at line 57 of file star-height.hh.

References vcsn::detail::v, and vcsn::detail::star_height_visitor< ExpSet >::visit_().

Here is the call graph for this function:

template<typename ExpSet >
vcsn::detail::star_height_visitor< ExpSet >::VCSN_RAT_VISIT ( ldivide  ,
v   
)
inlineprivate

Definition at line 58 of file star-height.hh.

References vcsn::detail::v, and vcsn::detail::star_height_visitor< ExpSet >::visit_().

Here is the call graph for this function:

template<typename ExpSet >
vcsn::detail::star_height_visitor< ExpSet >::VCSN_RAT_VISIT ( lweight  ,
v   
)
inlineprivate

Definition at line 59 of file star-height.hh.

References vcsn::detail::v.

template<typename ExpSet >
vcsn::detail::star_height_visitor< ExpSet >::VCSN_RAT_VISIT ( mul  ,
v   
)
inlineprivate

Definition at line 60 of file star-height.hh.

References vcsn::detail::v, and vcsn::detail::star_height_visitor< ExpSet >::visit_().

Here is the call graph for this function:

template<typename ExpSet >
vcsn::detail::star_height_visitor< ExpSet >::VCSN_RAT_VISIT ( one  )
inlineprivate

Definition at line 61 of file star-height.hh.

template<typename ExpSet >
vcsn::detail::star_height_visitor< ExpSet >::VCSN_RAT_VISIT ( rweight  ,
v   
)
inlineprivate

Definition at line 62 of file star-height.hh.

References vcsn::detail::v.

template<typename ExpSet >
vcsn::detail::star_height_visitor< ExpSet >::VCSN_RAT_VISIT ( shuffle  ,
v   
)
inlineprivate

Definition at line 63 of file star-height.hh.

References vcsn::detail::v, and vcsn::detail::star_height_visitor< ExpSet >::visit_().

Here is the call graph for this function:

template<typename ExpSet >
vcsn::detail::star_height_visitor< ExpSet >::VCSN_RAT_VISIT ( star  ,
v   
)
inlineprivate

Definition at line 64 of file star-height.hh.

References vcsn::detail::star_height_visitor< ExpSet >::height_, vcsn::detail::v, and vcsn::detail::star_height_visitor< ExpSet >::visit_().

Here is the call graph for this function:

template<typename ExpSet >
vcsn::detail::star_height_visitor< ExpSet >::VCSN_RAT_VISIT ( transposition  ,
v   
)
inlineprivate

Definition at line 65 of file star-height.hh.

References vcsn::detail::v, and vcsn::detail::star_height_visitor< ExpSet >::visit_().

Here is the call graph for this function:

template<typename ExpSet >
vcsn::detail::star_height_visitor< ExpSet >::VCSN_RAT_VISIT ( zero  )
inlineprivate

Definition at line 66 of file star-height.hh.

template<typename ExpSet >
void vcsn::detail::star_height_visitor< ExpSet >::visit ( const tuple_t v,
std::true_type   
)
inlineoverrideprivate
template<typename ExpSet >
template<rat::exp::type_t Type>
void vcsn::detail::star_height_visitor< ExpSet >::visit_ ( const unary_t< Type > &  v)
inlineprivate

Traverse unary node.

Definition at line 73 of file star-height.hh.

References vcsn::detail::star_height_visitor< ExpSet >::height_, and vcsn::detail::star_height_visitor< ExpSet >::recurse_().

Referenced by vcsn::detail::star_height_visitor< ExpSet >::VCSN_RAT_VISIT().

Here is the call graph for this function:

template<typename ExpSet >
template<rat::type_t Type>
void vcsn::detail::star_height_visitor< ExpSet >::visit_ ( const variadic_t< Type > &  n)
inlineprivate

Traverse variadic node.

Definition at line 83 of file star-height.hh.

References vcsn::detail::star_height_visitor< ExpSet >::height_, and vcsn::detail::star_height_visitor< ExpSet >::recurse_().

Here is the call graph for this function:

Member Data Documentation

template<typename ExpSet >
const expressionset_t& vcsn::detail::star_height_visitor< ExpSet >::rs_
private

The expressionset.

Definition at line 136 of file star-height.hh.

Referenced by vcsn::detail::star_height_visitor< ExpSet >::visit_tuple< bool, Dummy >::tape_().


The documentation for this class was generated from the following file: