28 template <vector_mode_t V>
35 static constexpr
bool gpu_computable = (is_single_precision_t<T> && impl::egblas::has_sfloor) || (is_double_precision_t<T> && impl::egblas::has_dfloor)
36 || (is_complex_single_t<T> && impl::egblas::has_cfloor) || (is_complex_double_t<T> && impl::egblas::has_zfloor);
51 static constexpr T
apply(
const T& x) noexcept {
62 template <
typename X,
typename Y>
69 impl::egblas::floor(
etl::size(y), alpha, t1.gpu_memory(), 1, t2.gpu_memory(), 1);
80 template <
typename X,
typename Y>
85 impl::egblas::floor(
etl::size(y), alpha, t1.gpu_memory(), 1, y.gpu_memory(), 1);
97 static std::string
desc() noexcept {
static constexpr bool gpu_computable
Indicates if the operator can be computed on GPU.
Definition: floor.hpp:35
Unary operation rounding down the value.
Definition: floor.hpp:19
EGBLAS wrappers for the floor operation.
static constexpr bool vectorizable
Indicates if the expression is vectorizable using the given vector mode.
Definition: floor.hpp:29
static constexpr T apply(const T &x) noexcept
Apply the unary operator on x.
Definition: floor.hpp:51
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
Root namespace for the ETL library.
Definition: adapter.hpp:15
static constexpr bool linear
Indicates if the operator is linear.
Definition: floor.hpp:20
static std::string desc() noexcept
Returns a textual representation of the operator.
Definition: floor.hpp:97
decltype(auto) force_temporary_gpu_dim_only(E &&expr)
Force a temporary out of the expression, without copying its content.
Definition: temporary.hpp:223
static constexpr int complexity()
Estimate the complexity of operator.
Definition: floor.hpp:42
constexpr size_t size(const E &expr) noexcept
Returns the size of the given ETL expression.
Definition: helpers.hpp:108
static auto gpu_compute_hint(const X &x, Y &y) noexcept
Compute the result of the operation using the GPU.
Definition: floor.hpp:63
static constexpr bool thread_safe
Indicates if the operator is thread safe or not.
Definition: floor.hpp:21
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 Y & gpu_compute(const X &x, Y &y) noexcept
Compute the result of the operation using the GPU.
Definition: floor.hpp:81