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

◆ add

eve::add = functor<add_t>
inlineconstexpr

Header file

#include <eve/module/core.hpp>

Callable Signatures

namespace eve
{
// Regular overloads
constexpr auto add(value auto x, value auto ... xs) noexcept; // 1
constexpr auto add(kumi::non_empty_product_type auto const& tup) noexcept; // 2
// Lanes masking
constexpr auto add[conditional_expr auto c](/*any of the above overloads*/) noexcept; // 3
constexpr auto add[logical_value auto m](/*any of the above overloads*/) noexcept; // 3
// Semantic options
constexpr auto add[saturated](/*any of the above overloads*/) noexcept; // 4
2. [The operation is performed conditionnaly](@ref conditional).
}
Specifies that a type is a Conditional Expression.
Definition: conditional.hpp:27
The concept logical_value<T> is satisfied if and only if T satisfies eve::value and the element type ...
Definition: value.hpp:107
The concept value<T> is satisfied if and only if T satisfies either eve::scalar_value or eve::simd_va...
Definition: value.hpp:33
constexpr auto add
tuple_callable computing the sum of its arguments.
Definition: add.hpp:93
EVE Main Namespace.
Definition: abi.hpp:18

Parameters

  • x, ...xs: real arguments.
  • tup: non empty tuple of arguments.
  • c: Conditional expression masking the operation.
  • m: Logical value masking the operation.

Return value

The value of the sum of the arguments is returned.

  1. Take care that for floating entries, the addition is not perfectly associative due to rounding errors. This call performs additions in reverse incoming order.
  2. equivalent to the call on the elements of the tuple.
  3. The operation is performed conditionnaly
  4. The call add[saturated](...) computes a saturated version of add. Take care that for signed integral entries this kind of addition is not associative at all. This call perform saturated additions in reverse incoming order.
Note
Although the infix notation with + is supported for two parameters, the + operator on standard scalar types is the original one and so can lead to automatic promotion.

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 wf1{0.0, -4.0, 1.0, -1.0, 2.0, -2.0, 3.0, -3.0};
eve::wide wi0{0, 1, 2, 3, -1, -2, -3, -4};
eve::wide wi1{0, -4, 1, -1, 2, -2, 3, -3};
eve::wide wu0{0u, 1u, 2u, 3u, 4u, 5u, 6u, 7u};
eve::wide wu1{7u, 6u, 5u, 4u, 3u, 2u, 1u, 0u};
std::cout << "<- wf0 = " << wf0 << "\n";
std::cout << "<- wf1 = " << wf1 << "\n";
std::cout << "<- wi0 = " << wi0 << "\n";
std::cout << "<- wi1 = " << wi1 << "\n";
std::cout << "<- wu0 = " << wu0 << "\n";
std::cout << "<- wu1 = " << wu1 << "\n";
std::cout << "-> add(wf0, wf1) = " << eve::add(wf0, wf1) << "\n";
std::cout << "-> add[ignore_last(2)](wf0, wf1) = " << eve::add[eve::ignore_last(2)](wf0, wf1) << "\n";
std::cout << "-> add[wf0 != 0](wf0, wf1) = " << eve::add[wf0 != 0](wf0, wf1) << "\n";
std::cout << "-> add(wu0, wu1) = " << eve::add(wu0, wu1) << "\n";
std::cout << "-> add(wi0, wi1) = " << eve::add(wi0, wi1) << "\n";
}
Conditional expression ignoring the k last lanes from a eve::simd_value.
Definition: conditional.hpp:304
Wrapper for SIMD registers.
Definition: wide.hpp:71