E.V.E
v2023.02.15
 
Loading...
Searching...
No Matches

◆ pow_abs

eve::pow_abs = functor<pow_abs_t>
inlineconstexpr

Header file

#include <eve/module/math.hpp>

Callable Signatures

namespace eve
{
// Regular overload
constexpr auto pow_abs(floating_value auto x, floating_value auto y) noexcept; // 1
// Lanes masking
constexpr auto pow_abs[conditional_expr auto c](floating_value auto x, floating_value auto y) noexcept; // 2
constexpr auto pow_abs[logical_value auto m](floating_value auto x, floating_value auto y) noexcept; // 2
// Semantic options
constexpr auto pow_abs[raw](floating_value auto x, floating_value auto y) noexcept; // 3
}
Specifies that a type is a Conditional Expression.
Definition: conditional.hpp:27
The concept floating_value<T> is satisfied if and only if T satisfies eve::value and the element type...
Definition: value.hpp:95
The concept logical_value<T> is satisfied if and only if T satisfies eve::value and the element type ...
Definition: value.hpp:107
constexpr auto pow_abs
Callable object computing the pow_abs function .
Definition: pow_abs.hpp:98
EVE Main Namespace.
Definition: abi.hpp:18

Parameters

* `x`, `y`: [floating_value](@ref floating_value) arguments.
* `c`: [Conditional expression](@ref conditional_expr) masking the operation.
* `m`: [Logical value](@ref logical) masking the operation.

Return value

Returns elementwise \(|x|^y\).

  1. The result type is the common type of the two parameters. In particular we have (IEC 60559) for floating entries:
    • pow_abs( \(\pm0\), y), where y is a negative odd integer, returns \(+\infty\).
    • pow_abs( \(\pm0\), y), where y is negative, finite, and is an even integer or a non-integer, returns \(+\infty\).
    • pow_abs( \(\pm0\), \(-\infty\)) returns \(+\infty\).
    • pow_abs( \(\pm0\), y), where y is a positive odd integer, returns \(+0\).
    • pow_abs( \(\pm0\), y), where y is positive non-integer or a positive even integer, returns \(+0\).
    • pow_abs(-1, \(\pm\infty\)) returns 1.
    • pow_abs( \(\pm1\), y) returns 1 for any y, even when y is NaN.
    • pow_abs(x, \(\pm0\)) returns 1 for any x, even when x is NaN.
    • pow_abs(x, \(-\infty\)) returns \(+\infty\) for any |x| < 1.
    • pow_abs(x, \(-\infty\)) returns \(+0\) for any |x| > 1.
    • pow_abs(x, \(+\infty\)) returns \(+0\) for any |x| < 1.
    • pow_abs(x, \(+\infty\)) returns \(+\infty\) for any |x| > 1.
    • pow_abs( \(+\infty\), y) returns \(+0\) for any negative y.
    • pow_abs( \(+\infty\), y) returns \(+\infty\) for any positive y.
    • except where specified above, if any argument is NaN, NaN is returned.

The operation is performed conditionnaly

  1. faster but less accurate call.

Example

// revision 1
#include <eve/module/math.hpp>
#include <iostream>
int main()
{
eve::wide pf = {2.0f, 3.0f, -4.0f, 2.0f, 2.0f,
eve::wide qf = {4.0f, 1.0f, -1.0f, 0.5f, 0.0f, 2.0f, -3.0f, 2.5f};
std::cout << "<- pf = " << pf << "\n";
std::cout << "<- qf = " << qf << "\n";
std::cout << "-> pow_abs(pf, qf) = " << eve::pow_abs(pf, qf) << "\n";
std::cout << "-> pow_abs[ignore_last(2)](pf, qf)= " << eve::pow_abs[eve::ignore_last(2)](pf, qf) << "\n";
std::cout << "-> pow_abs[qf > 0.0f](pf, qf) = " << eve::pow_abs[qf > 0.0f](pf, qf) << "\n";
std::cout << "-> pow_abs[raw](pf, qf) = " << eve::pow_abs[eve::raw](pf, qf) << "\n";
}
constexpr auto nan
Computes the IEEE quiet NaN constant.
Definition: nan.hpp:67
constexpr auto minf
Computes the -infinity ieee value.
Definition: minf.hpp:66
constexpr auto inf
Computes the infinity ieee value.
Definition: inf.hpp:66
Lightweight type-wrapper.
Definition: as.hpp:29
Conditional expression ignoring the k last lanes from a eve::simd_value.
Definition: conditional.hpp:304
Wrapper for SIMD registers.
Definition: wide.hpp:71