35#ifndef _BLAZE_MATH_SIMD_EXP_H_
36#define _BLAZE_MATH_SIMD_EXP_H_
71# if BLAZE_AVX512F_MODE || BLAZE_MIC_MODE
73 return _mm512_exp_ps( (*a).eval().value );
77 return _mm256_exp_ps( (*a).eval().value );
81 return _mm_exp_ps( (*a).eval().value );
85# if BLAZE_AVX512F_MODE || BLAZE_MIC_MODE
87 return Sleef_expf16_u10( (*a).eval().value );
91 return Sleef_expf8_u10( (*a).eval().value );
95 return Sleef_expf4_u10( (*a).eval().value );
121template<
typename T >
124# if BLAZE_AVX512F_MODE || BLAZE_MIC_MODE
126 return _mm512_exp_pd( (*a).eval().value );
130 return _mm256_exp_pd( (*a).eval().value );
134 return _mm_exp_pd( (*a).eval().value );
137#elif BLAZE_SLEEF_MODE
138# if BLAZE_AVX512F_MODE || BLAZE_MIC_MODE
140 return Sleef_expd8_u10( (*a).eval().value );
144 return Sleef_expd4_u10( (*a).eval().value );
148 return Sleef_expd2_u10( (*a).eval().value );
Header file for the basic SIMD types.
SIMD type for 64-bit double precision floating point data values.
SIMD type for 32-bit single precision floating point data values.
BLAZE_ALWAYS_INLINE const SIMDdouble exp(const SIMDf64< T > &a) noexcept=delete
Computes for a vector of double precision floating point values.
#define BLAZE_ALWAYS_INLINE
Platform dependent setup of an enforced inline keyword.
Definition: Inline.h:85
System settings for the inline keywords.
System settings for the SSE mode.