Loading [MathJax]/extensions/tex2jax.js
E.V.E
v2023.02.15
 
All Classes Namespaces Functions Variables Typedefs Enumerations Friends Modules Pages Concepts
Loading...
Searching...
No Matches

◆ round

eve::round = functor<round_t>
inlineconstexpr

Header file

#include <eve/module/core.hpp>

Callable Signatures

namespace eve
{
// Regular overload
constexpr auto round(value auto x) noexcept; // 1
// Lanes masking
constexpr auto round[conditional_expr auto c](value auto x) noexcept; // 2
constexpr auto round[logical_value auto m](value auto x) noexcept; // 2
// Semantic options
constexpr auto round[upward](floating_value auto x) noexcept; // 3
constexpr auto round[downward](floating_value auto x) noexcept; // 4
constexpr auto round[to_nearest](floating_value auto x) noexcept; // 5
constexpr auto round[toward_zero](floating_value auto x) noexcept; // 6
}
Specifies that a type is a Conditional Expression.
Definition: conditional.hpp:28
The concept floating_value<T> is satisfied if and only if T satisfies eve::value and the element type...
Definition: value.hpp:116
The concept logical_value<T> is satisfied if and only if T satisfies eve::value and the element type ...
Definition: value.hpp:132
The concept value<T> is satisfied if and only if T satisfies either eve::scalar_value or eve::simd_va...
Definition: value.hpp:34
constexpr auto round
Computes the integer nearest to the input.
Definition: round.hpp:81
EVE Main Namespace.
Definition: abi.hpp:18

Parameters

Return value

  1. The integer nearest to x.
  2. The operation is performed conditionnaly.
  3. equivalent to ceil(x).
  4. equivalent to floor(x).
  5. equivalent to nearest(x).
  6. equivalent to trunc(x).

Example

// revision 0
#include <eve/module/core.hpp>
#include <iostream>
int main()
{
eve::wide wf0{0.0, 1.0, 2.0, 3.0, -1.0, -2.0, -3.0, -4.0};
eve::wide wi0{0, 1, 2, 3, -1, -2, -3, -4};
eve::wide wu0{0u, 1u, 2u, 3u, 4u, 5u, 6u, 7u};
std::cout << "<- wf0 = " << wf0 << "\n";
std::cout << "<- wi0 = " << wi0 << "\n";
std::cout << "<- wu0 = " << wu0 << "\n";
std::cout << "-> round(wf0) = " << eve::round(wf0) << "\n";
std::cout << "-> round[ignore_last(2)](wf0) = " << eve::round[eve::ignore_last(2)](wf0) << "\n";
std::cout << "-> round[wf0 != 0](wf0) = " << eve::round[wf0 != 0](wf0) << "\n";
std::cout << "-> round[upward](wf0) = " << eve::round[eve::upward](wf0) << "\n";
std::cout << "-> round[downward](wf0) = " << eve::round[eve::downward](wf0) << "\n";
std::cout << "-> round[to_nearest](wf0) = " << eve::round[eve::to_nearest](wf0) << "\n";
std::cout << "-> round[toward_zero](wf0) = " << eve::round[eve::toward_zero](wf0) << "\n";
std::cout << "-> round(wu0) = " << eve::round(wu0) << "\n";
std::cout << "-> round[ignore_last(2)](wu0) = " << eve::round[eve::ignore_last(2)](wu0) << "\n";
std::cout << "-> round[wu0 != 0](wu0) = " << eve::round[wu0 != 0](wu0) << "\n";
std::cout << "-> round(wi0) = " << eve::round(wi0) << "\n";
std::cout << "-> round[ignore_last(2)](wi0) = " << eve::round[eve::ignore_last(2)](wi0) << "\n";
std::cout << "-> round[wi0 != 0](wi0) = " << eve::round[wi0 != 0](wi0) << "\n";
}
Conditional expression ignoring the k last lanes from a eve::simd_value.
Definition: conditional.hpp:307
Wrapper for SIMD registers.
Definition: wide.hpp:93