InvCbrt.h
Go to the documentation of this file.
1 //=================================================================================================
33 //=================================================================================================
34 
35 #ifndef _BLAZE_MATH_FUNCTORS_INVCBRT_H_
36 #define _BLAZE_MATH_FUNCTORS_INVCBRT_H_
37 
38 
39 //*************************************************************************************************
40 // Includes
41 //*************************************************************************************************
42 
47 #include <blaze/system/Inline.h>
48 
49 
50 namespace blaze {
51 
52 //=================================================================================================
53 //
54 // CLASS DEFINITION
55 //
56 //=================================================================================================
57 
58 //*************************************************************************************************
62 struct InvCbrt
63 {
64  //**********************************************************************************************
70  template< typename T >
71  BLAZE_ALWAYS_INLINE auto operator()( const T& a ) const
72  {
73  return invcbrt( a );
74  }
75  //**********************************************************************************************
76 
77  //**********************************************************************************************
82  template< typename T >
83  static constexpr bool simdEnabled() { return HasSIMDInvCbrt<T>::value; }
84  //**********************************************************************************************
85 
86  //**********************************************************************************************
92  template< typename T >
93  BLAZE_ALWAYS_INLINE auto load( const T& a ) const
94  {
96  return invcbrt( a );
97  }
98  //**********************************************************************************************
99 };
100 //*************************************************************************************************
101 
102 } // namespace blaze
103 
104 #endif
static constexpr bool simdEnabled()
Returns whether SIMD is enabled for the specified data type T.
Definition: InvCbrt.h:83
Header file for the SIMD inverse cubit root functionality.
BLAZE_ALWAYS_INLINE auto operator()(const T &a) const
Returns the result of the invcbrt() function for the given object/value.
Definition: InvCbrt.h:71
#define BLAZE_CONSTRAINT_MUST_BE_SIMD_PACK(T)
Constraint on the data type.In case the given data type T is not a SIMD pack, a compilation error is ...
Definition: SIMDPack.h:60
Namespace of the Blaze C++ math library.
Definition: Blaze.h:57
#define BLAZE_ALWAYS_INLINE
Platform dependent setup of an enforced inline keyword.
Definition: Inline.h:85
const DMatForEachExpr< MT, InvCbrt, SO > invcbrt(const DenseMatrix< MT, SO > &dm)
Computes the inverse cubic root of each single element of the dense matrix dm.
Definition: DMatForEachExpr.h:1375
Header file for the HasSIMDInvCbrt type trait.
Constraint on the data type.
Availability of a SIMD inverse cubic root operation for the given data type.Depending on the availabl...
Definition: HasSIMDInvCbrt.h:107
Generic wrapper for the invcbrt() function.
Definition: InvCbrt.h:62
Header file for the invcbrt shim.
BLAZE_ALWAYS_INLINE auto load(const T &a) const
Returns the result of the invcbrt() function for the given SIMD vector.
Definition: InvCbrt.h:93
System settings for the inline keywords.