C++ Mathematical Expression Toolkit (ExprTk) release
Loading...
Searching...
No Matches
Public Types | Public Member Functions | Private Attributes | List of all members
exprtk::details::vec_binop_vecval_node< T, Operation > Class Template Reference
Inheritance diagram for exprtk::details::vec_binop_vecval_node< T, Operation >:
[legend]
Collaboration diagram for exprtk::details::vec_binop_vecval_node< T, Operation >:
[legend]

Public Types

typedef expression_node< T > * expression_ptr
 
typedef vector_node< T > * vector_node_ptr
 
typedef vector_holder< Tvector_holder_t
 
typedef vector_holder_tvector_holder_ptr
 
typedef vec_data_store< Tvds_t
 
typedef memory_context_t< Tmemory_context
 
- Public Types inherited from exprtk::details::binary_node< T >
typedef expression_node< T > * expression_ptr
 
typedef std::pair< expression_ptr, boolbranch_t
 
- Public Types inherited from exprtk::details::expression_node< T >
enum  node_type {
  e_none , e_null , e_constant , e_unary ,
  e_binary , e_binary_ext , e_trinary , e_quaternary ,
  e_vararg , e_conditional , e_while , e_repeat ,
  e_for , e_switch , e_mswitch , e_return ,
  e_retenv , e_variable , e_stringvar , e_stringconst ,
  e_stringvarrng , e_cstringvarrng , e_strgenrange , e_strconcat ,
  e_stringvarsize , e_strswap , e_stringsize , e_stringvararg ,
  e_function , e_vafunction , e_genfunction , e_strfunction ,
  e_strcondition , e_strccondition , e_add , e_sub ,
  e_mul , e_div , e_mod , e_pow ,
  e_lt , e_lte , e_gt , e_gte ,
  e_eq , e_ne , e_and , e_nand ,
  e_or , e_nor , e_xor , e_xnor ,
  e_in , e_like , e_ilike , e_inranges ,
  e_ipow , e_ipowinv , e_abs , e_acos ,
  e_acosh , e_asin , e_asinh , e_atan ,
  e_atanh , e_ceil , e_cos , e_cosh ,
  e_exp , e_expm1 , e_floor , e_log ,
  e_log10 , e_log2 , e_log1p , e_neg ,
  e_pos , e_round , e_sin , e_sinc ,
  e_sinh , e_sqrt , e_tan , e_tanh ,
  e_cot , e_sec , e_csc , e_r2d ,
  e_d2r , e_d2g , e_g2d , e_notl ,
  e_sgn , e_erf , e_erfc , e_ncdf ,
  e_frac , e_trunc , e_uvouv , e_vov ,
  e_cov , e_voc , e_vob , e_bov ,
  e_cob , e_boc , e_vovov , e_vovoc ,
  e_vocov , e_covov , e_covoc , e_vovovov ,
  e_vovovoc , e_vovocov , e_vocovov , e_covovov ,
  e_covocov , e_vocovoc , e_covovoc , e_vococov ,
  e_sf3ext , e_sf4ext , e_nulleq , e_strass ,
  e_vector , e_vecsize , e_vecelem , e_veccelem ,
  e_vecelemrtc , e_veccelemrtc , e_rbvecelem , e_rbvecelemrtc ,
  e_rbveccelem , e_rbveccelemrtc , e_vecinit , e_vecvalass ,
  e_vecvecass , e_vecopvalass , e_vecopvecass , e_vecfunc ,
  e_vecvecswap , e_vecvecineq , e_vecvalineq , e_valvecineq ,
  e_vecvecarith , e_vecvalarith , e_valvecarith , e_vecunaryop ,
  e_vecondition , e_break , e_continue , e_swap ,
  e_assert
}
 
typedef T value_type
 
typedef expression_node< T > * expression_ptr
 
typedef node_collector_interface< expression_node< T > > nci_t
 
typedef nci_t::noderef_list_t noderef_list_t
 
typedef node_depth_base< expression_node< T > > ndb_t
 
- Public Types inherited from exprtk::details::node_collector_interface< expression_node< T > >
typedef expression_node< T > * node_ptr_t
 
typedef expression_node< T > ** node_pp_t
 
typedef std::vector< node_pp_tnoderef_list_t
 
- Public Types inherited from exprtk::details::node_depth_base< expression_node< T > >
typedef expression_node< T > * node_ptr_t
 
typedef std::pair< node_ptr_t, bool > nb_pair_t
 
- Public Types inherited from exprtk::details::vector_interface< T >
typedef vector_node< T > * vector_node_ptr
 
typedef vec_data_store< Tvds_t
 

Public Member Functions

 vec_binop_vecval_node (const operator_type &opr, expression_ptr branch0, expression_ptr branch1)
 
 ~vec_binop_vecval_node ()
 
T value () const
 
vector_node_ptr vec () const
 
vector_node_ptr vec ()
 
expression_node< T >::node_type type () const
 
bool valid () const
 
std::size_t size () const
 
std::size_t base_size () const
 
vds_tvds ()
 
const vds_tvds () const
 
- Public Member Functions inherited from exprtk::details::binary_node< T >
 binary_node (const operator_type &opr, expression_ptr branch0, expression_ptr branch1)
 
operator_type operation ()
 
expression_node< T > * branch (const std::size_t &index=0) const
 
void collect_nodes (typename expression_node< T >::noderef_list_t &node_delete_list)
 
std::size_t node_depth () const
 
- Public Member Functions inherited from exprtk::details::expression_node< T >
virtual ~expression_node ()
 
- Public Member Functions inherited from exprtk::details::node_collector_interface< expression_node< T > >
virtual ~node_collector_interface ()
 
virtual void collect_nodes (noderef_list_t &)
 
- Public Member Functions inherited from exprtk::details::node_depth_base< expression_node< T > >
 node_depth_base ()
 
virtual ~node_depth_base ()
 
std::size_t compute_node_depth (const expression_node< T > *const &node) const
 
std::size_t compute_node_depth (const nb_pair_t &branch) const
 
std::size_t compute_node_depth (const nb_pair_t(&branch)[N]) const
 
std::size_t compute_node_depth (const BranchType &n0, const BranchType &n1) const
 
std::size_t compute_node_depth (const BranchType &n0, const BranchType &n1, const BranchType &n2) const
 
std::size_t compute_node_depth (const BranchType &n0, const BranchType &n1, const BranchType &n2, const BranchType &n3) const
 
std::size_t compute_node_depth (const Sequence< node_ptr_t, Allocator > &branch_list) const
 
std::size_t compute_node_depth (const Sequence< nb_pair_t, Allocator > &branch_list) const
 
std::size_t max_node_depth (const BranchType &n0, const BranchType &n1) const
 
std::size_t max_node_depth (const BranchType &n0, const BranchType &n1, const BranchType &n2) const
 
std::size_t max_node_depth (const BranchType &n0, const BranchType &n1, const BranchType &n2, const BranchType &n3) const
 
void collect (node_ptr_t const &node, const bool deletable, NodeSequence &delete_node_list) const
 
void collect (const nb_pair_t &branch, NodeSequence &delete_node_list) const
 
void collect (expression_node< T > *&node, NodeSequence &delete_node_list) const
 
void collect (const nb_pair_t(&branch)[N], NodeSequence &delete_node_list) const
 
void collect (const Sequence< nb_pair_t, Allocator > &branch, NodeSequence &delete_node_list) const
 
void collect (const Sequence< node_ptr_t, Allocator > &branch_list, NodeSequence &delete_node_list) const
 
void collect (const Sequence< node_ptr_t, AllocatorT > &branch_list, const Sequence< Boolean, AllocatorB > &branch_deletable_list, NodeSequence &delete_node_list) const
 
- Public Member Functions inherited from exprtk::details::vector_interface< T >
virtual ~vector_interface ()
 
virtual bool side_effect () const
 

Private Attributes

vector_node_ptr vec0_node_ptr_
 
vds_t vds_
 
memory_context memory_context_
 

Additional Inherited Members

- Public Attributes inherited from exprtk::details::node_depth_base< expression_node< T > >
bool depth_set
 
std::size_t depth
 

Detailed Description

template<typename T, typename Operation>
class exprtk::details::vec_binop_vecval_node< T, Operation >

Definition at line 13709 of file exprtk.hpp.

Member Typedef Documentation

◆ expression_ptr

Definition at line 13715 of file exprtk.hpp.

◆ memory_context

Definition at line 13720 of file exprtk.hpp.

◆ vds_t

Definition at line 13719 of file exprtk.hpp.

◆ vector_holder_ptr

Definition at line 13718 of file exprtk.hpp.

◆ vector_holder_t

Definition at line 13717 of file exprtk.hpp.

◆ vector_node_ptr

Definition at line 13716 of file exprtk.hpp.

Constructor & Destructor Documentation

◆ vec_binop_vecval_node()

template<typename T , typename Operation >
exprtk::details::vec_binop_vecval_node< T, Operation >::vec_binop_vecval_node ( const operator_type opr,
expression_ptr  branch0,
expression_ptr  branch1 
)
inline

Definition at line 13724 of file exprtk.hpp.

13728 , vec0_node_ptr_(0)
13729 {
13730 bool v0_is_ivec = false;
13731
13732 if (is_vector_node(branch(0)))
13733 {
13734 vec0_node_ptr_ = static_cast<vector_node_ptr>(branch(0));
13735 }
13736 else if (is_ivector_node(branch(0)))
13737 {
13738 vector_interface<T>* vi = reinterpret_cast<vector_interface<T>*>(0);
13739
13740 if (0 != (vi = dynamic_cast<vector_interface<T>*>(branch(0))))
13741 {
13742 vec0_node_ptr_ = vi->vec();
13743 v0_is_ivec = true;
13744 }
13745 }
13746
13747 if (vec0_node_ptr_)
13748 {
13749 if (v0_is_ivec)
13750 vds() = vec0_node_ptr_->vds();
13751 else
13753
13755 }
13756
13757 assert(valid());
13758 }
expression_node< T > * branch(const std::size_t &index=0) const
Definition exprtk.hpp:6951
vector_node_ptr vec() const
Definition exprtk.hpp:8529
std::size_t base_size() const
Definition exprtk.hpp:8554
vector_holder_t & vec_holder()
Definition exprtk.hpp:8569
bool is_ivector_node(const expression_node< T > *node)
Definition exprtk.hpp:5756
bool match_impl(const Iterator pattern_begin, const Iterator pattern_end, const Iterator data_begin, const Iterator data_end, const typename std::iterator_traits< Iterator >::value_type &zero_or_more, const typename std::iterator_traits< Iterator >::value_type &exactly_one)
Definition exprtk.hpp:598
memory_context_t< T > make_memory_context(vector_holder< T > &vec_holder, vec_data_store< T > &vds)
Definition exprtk.hpp:13470
bool is_vector_node(const expression_node< T > *node)
Definition exprtk.hpp:5750

References exprtk::details::vector_node< T >::base_size(), exprtk::details::binary_node< T >::branch(), exprtk::details::is_ivector_node(), exprtk::details::is_vector_node(), exprtk::details::make_memory_context(), exprtk::details::match_impl(), exprtk::details::vec_binop_vecval_node< T, Operation >::memory_context_, exprtk::details::vec_binop_vecval_node< T, Operation >::valid(), exprtk::details::vector_node< T >::vds(), exprtk::details::vec_binop_vecval_node< T, Operation >::vds(), exprtk::details::vector_node< T >::vec(), exprtk::details::vec_binop_vecval_node< T, Operation >::vec0_node_ptr_, and exprtk::details::vector_node< T >::vec_holder().

Here is the call graph for this function:

◆ ~vec_binop_vecval_node()

Definition at line 13760 of file exprtk.hpp.

13761 {
13763 }

References exprtk::details::memory_context_t< T >::clear(), and exprtk::details::vec_binop_vecval_node< T, Operation >::memory_context_.

Here is the call graph for this function:

Member Function Documentation

◆ base_size()

template<typename T , typename Operation >
std::size_t exprtk::details::vec_binop_vecval_node< T, Operation >::base_size ( ) const
inlinevirtual

Implements exprtk::details::vector_interface< T >.

Definition at line 13850 of file exprtk.hpp.

13851 {
13853 }
std::size_t base_size() const
Definition exprtk.hpp:6549

References exprtk::details::vector_holder< Type >::base_size(), exprtk::details::vec_binop_vecval_node< T, Operation >::vec0_node_ptr_, and exprtk::details::vector_node< T >::vec_holder().

Referenced by exprtk::details::vec_binop_vecval_node< T, Operation >::valid().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ size()

template<typename T , typename Operation >
std::size_t exprtk::details::vec_binop_vecval_node< T, Operation >::size ( ) const
inlinevirtual

Implements exprtk::details::vector_interface< T >.

Definition at line 13845 of file exprtk.hpp.

13846 {
13847 return vec0_node_ptr_->size();
13848 }
std::size_t size() const
Definition exprtk.hpp:8549

References exprtk::details::vector_node< T >::size(), and exprtk::details::vec_binop_vecval_node< T, Operation >::vec0_node_ptr_.

Referenced by exprtk::details::vec_binop_vecval_node< T, Operation >::valid(), and exprtk::details::vec_binop_vecval_node< T, Operation >::value().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ type()

Reimplemented from exprtk::details::binary_node< T >.

Definition at line 13832 of file exprtk.hpp.

◆ valid()

template<typename T , typename Operation >
bool exprtk::details::vec_binop_vecval_node< T, Operation >::valid ( ) const
inlinevirtual

Reimplemented from exprtk::details::binary_node< T >.

Definition at line 13837 of file exprtk.hpp.

13838 {
13839 return
13841 (size() <= base_size()) &&
13843 }

References exprtk::details::vec_binop_vecval_node< T, Operation >::base_size(), exprtk::details::vec_binop_vecval_node< T, Operation >::size(), and exprtk::details::vec_binop_vecval_node< T, Operation >::vec0_node_ptr_.

Referenced by exprtk::details::vec_binop_vecval_node< T, Operation >::vec_binop_vecval_node().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ value()

template<typename T , typename Operation >
T exprtk::details::vec_binop_vecval_node< T, Operation >::value ( ) const
inlinevirtual

Reimplemented from exprtk::details::binary_node< T >.

Definition at line 13765 of file exprtk.hpp.

13766 {
13767 branch(0)->value();
13768 const T v = branch(1)->value();
13769
13770 const T* vec0 = vec0_node_ptr_->vds().data();
13771 T* vec1 = vds().data();
13772
13773 loop_unroll::details lud(size());
13774 const T* upper_bound = vec0 + lud.upper_bound;
13775
13776 while (vec0 < upper_bound)
13777 {
13778 #define exprtk_loop(N) \
13779 vec1[N] = Operation::process(vec0[N], v); \
13780
13781 exprtk_loop( 0) exprtk_loop( 1)
13782 exprtk_loop( 2) exprtk_loop( 3)
13783 #ifndef exprtk_disable_superscalar_unroll
13784 exprtk_loop( 4) exprtk_loop( 5)
13785 exprtk_loop( 6) exprtk_loop( 7)
13786 exprtk_loop( 8) exprtk_loop( 9)
13787 exprtk_loop(10) exprtk_loop(11)
13788 exprtk_loop(12) exprtk_loop(13)
13789 exprtk_loop(14) exprtk_loop(15)
13790 #endif
13791
13792 vec0 += lud.batch_size;
13793 vec1 += lud.batch_size;
13794 }
13795
13796 int i = 0;
13797
13798 switch (lud.remainder)
13799 {
13800 #define case_stmt(N,fall_through) \
13801 case N : { vec1[i] = Operation::process(vec0[i], v); ++i; } \
13802 fall_through \
13803
13804 #ifndef exprtk_disable_superscalar_unroll
13811 #endif
13813 case_stmt( 1, (void)0;)
13814 }
13815
13816 #undef exprtk_loop
13817 #undef case_stmt
13818
13819 return (vds().data())[0];
13820 }
#define case_stmt(N)
Definition exprtk.hpp:32731
#define exprtk_fallthrough
Definition exprtk.hpp:86
#define exprtk_loop(N)
static std::string data()
Definition exprtk.hpp:45871

References exprtk::details::binary_node< T >::branch(), case_stmt, exprtk::details::vec_data_store< T >::data(), exprtk_fallthrough, exprtk_loop, exprtk::details::match_impl(), exprtk::details::vec_binop_vecval_node< T, Operation >::size(), exprtk::details::vector_node< T >::vds(), exprtk::details::vec_binop_vecval_node< T, Operation >::vds(), and exprtk::details::vec_binop_vecval_node< T, Operation >::vec0_node_ptr_.

Here is the call graph for this function:

◆ vds() [1/2]

Implements exprtk::details::vector_interface< T >.

Definition at line 13855 of file exprtk.hpp.

13856 {
13857 return vds_;
13858 }

References exprtk::details::vec_binop_vecval_node< T, Operation >::vds_.

Referenced by exprtk::details::vec_binop_vecval_node< T, Operation >::value(), and exprtk::details::vec_binop_vecval_node< T, Operation >::vec_binop_vecval_node().

Here is the caller graph for this function:

◆ vds() [2/2]

template<typename T , typename Operation >
const vds_t & exprtk::details::vec_binop_vecval_node< T, Operation >::vds ( ) const
inlinevirtual

Implements exprtk::details::vector_interface< T >.

Definition at line 13860 of file exprtk.hpp.

13861 {
13862 return vds_;
13863 }

References exprtk::details::vec_binop_vecval_node< T, Operation >::vds_.

◆ vec() [1/2]

◆ vec() [2/2]

Member Data Documentation

◆ memory_context_

◆ vds_

◆ vec0_node_ptr_


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