28 template <vector_mode_t V>
36 static constexpr
bool gpu_computable = (is_single_precision_t<T> && impl::egblas::has_stanh) || (is_double_precision_t<T> && impl::egblas::has_dtanh)
37 || (is_complex_single_t<T> && impl::egblas::has_ctanh) || (is_complex_double_t<T> && impl::egblas::has_ztanh);
50 template <
typename V = default_vec>
58 static constexpr T
apply(
const T& x) noexcept {
68 template <
typename V = default_vec>
71 auto emx =
V::exp(V::minus(x));
72 return V::div(V::sub(ex, emx), V::add(ex, emx));
82 template <
typename X,
typename Y>
89 impl::egblas::tanh(
etl::size(y), alpha, t1.gpu_memory(), 1, t2.gpu_memory(), 1);
100 template <
typename X,
typename Y>
105 impl::egblas::tanh(
etl::size(y), alpha, t1.gpu_memory(), 1, y.gpu_memory(), 1);
117 static std::string
desc() noexcept {
126 template <
typename TT>
130 static constexpr
bool linear =
true;
131 static constexpr
bool thread_safe =
true;
138 template <vector_mode_t V>
139 static constexpr
bool vectorizable =
false;
144 template <
typename E>
145 static constexpr
bool gpu_computable = (is_single_precision_t<T> && impl::egblas::has_stanh) || (is_double_precision_t<T> && impl::egblas::has_dtanh)
146 || (is_complex_single_t<T> && impl::egblas::has_ctanh) || (is_complex_double_t<T> && impl::egblas::has_ztanh);
161 static constexpr
T apply(
const T& x) noexcept {
172 template <
typename X,
typename Y>
179 impl::egblas::tanh(
etl::size(y), alpha, t1.gpu_memory(), 1, t2.gpu_memory(), 1);
190 template <
typename X,
typename Y>
195 impl::egblas::tanh(
etl::size(y), alpha, t1.gpu_memory(), 1, y.gpu_memory(), 1);
207 static std::string
desc() noexcept {
static Y & gpu_compute(const X &x, Y &y) noexcept
Compute the result of the operation using the GPU.
Definition: tanh.hpp:191
Complex number implementation.
Definition: complex.hpp:31
EGBLAS wrappers for the tanh operation.
static constexpr bool vectorizable
Indicates if the expression is vectorizable using the given vector mode.
Definition: tanh.hpp:29
Unary operation computing the hyperbolic tangent.
Definition: tanh.hpp:19
decltype(auto) select_smart_gpu_compute(X &x, Y &y)
Compute the expression into a representation that is GPU up to date and possibly store this represent...
Definition: helpers.hpp:434
static std::string desc() noexcept
Returns a textual representation of the operator.
Definition: tanh.hpp:207
static std::string desc() noexcept
Returns a textual representation of the operator.
Definition: tanh.hpp:117
SSE3 is the max vectorization available.
static Y & gpu_compute(const X &x, Y &y) noexcept
Compute the result of the operation using the GPU.
Definition: tanh.hpp:101
constexpr bool intel_compiler
Indicates if the projectis compiled with intel compiler.
Definition: config.hpp:225
Root namespace for the ETL library.
Definition: adapter.hpp:15
auto tanh(E &&value) -> detail::unary_helper< E, tanh_unary_op >
Apply hyperbolic tangent on each value of the given expression.
Definition: function_expression_builder.hpp:124
static constexpr T apply(const T &x) noexcept
Apply the unary operator on x.
Definition: tanh.hpp:58
static constexpr int complexity()
Estimate the complexity of operator.
Definition: tanh.hpp:152
static constexpr bool thread_safe
Indicates if the operator is thread safe or not.
Definition: tanh.hpp:21
decltype(auto) force_temporary_gpu_dim_only(E &&expr)
Force a temporary out of the expression, without copying its content.
Definition: temporary.hpp:223
constexpr size_t size(const E &expr) noexcept
Returns the size of the given ETL expression.
Definition: helpers.hpp:108
static constexpr bool linear
Indicates if the operator is linear.
Definition: tanh.hpp:20
auto exp(E &&value) -> detail::unary_helper< E, exp_unary_op >
Apply exponential on each value of the given expression.
Definition: function_expression_builder.hpp:154
static vec_type< V > load(const vec_type< V > &x) noexcept
Compute several applications of the operator at a time.
Definition: tanh.hpp:69
AVX is the max vectorization available.
typename V::template vec_type< T > vec_type
Definition: tanh.hpp:51
static constexpr bool gpu_computable
Indicates if the operator can be computed on GPU.
Definition: tanh.hpp:36
decltype(auto) smart_gpu_compute_hint(E &expr, Y &y)
Compute the expression into a representation that is GPU up to date.
Definition: helpers.hpp:368
static constexpr T apply(const T &x) noexcept
Apply the unary operator on x.
Definition: tanh.hpp:161
static auto gpu_compute_hint(const X &x, Y &y) noexcept
Compute the result of the operation using the GPU.
Definition: tanh.hpp:83
static auto gpu_compute_hint(const X &x, Y &y) noexcept
Compute the result of the operation using the GPU.
Definition: tanh.hpp:173
static constexpr int complexity()
Estimate the complexity of operator.
Definition: tanh.hpp:43