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

◆ two_add

eve::two_add = functor<two_add_t>
inlineconstexpr

Header file

#include <eve/module/core.hpp>

Callable Signatures

namespace eve
{
// Regular overload
constexpr auto two_add(floating_value auto x, floating_value auto y) noexcept; // 1
constexpr auto two_add[raw](floating_value auto x, floating_value auto y) noexcept; // 2
// Semantic options
constexpr auto two_add[pedantic](floating_value auto x, floating_value auto y) noexcept; // 3
}
The concept floating_value<T> is satisfied if and only if T satisfies eve::value and the element type...
Definition value.hpp:116
constexpr auto two_add
Computes the elementwise pair consisting of the sum and its resulting rounding error.
Definition two_add.hpp:84
typename decltype(detail::as_translated_type(as< T >{}))::type translate_t
Returns the final translated type of T.
Definition translation.hpp:107
EVE Main Namespace.
Definition abi.hpp:19

Parameters

Return value

Computes elementwise a pair of values [a,e] such that:

  • a is x+y
  • e is a value such that a \(\oplus\)e is equal to x \(\oplus\)y, where \(\oplus\) adds its two parameters with infinite precision.

Classical algorithm, always valid.

  1. 'Fast' algorithm, valid only if |x| < |y|.
  2. Handles overflow.

External references

Example

// revision 1
#include <eve/module/core.hpp>
#include <iostream>
#include <iomanip>
int main()
{
eve::wide wf0 = {3.0f, 2.5f, -32.7f, 1.0f};
eve::wide wf1 = {4.2f, 1.5f, -100.834f, eve::eps(eve::as<float>())/2};
std::cout << "<- wf0 = " << wf0 << "\n";
std::cout << "<- wf1 = " << wf1 << "\n";
std::cout << std::setprecision(20);
std::cout << "-> two_add(wf0, wf1) = " << eve::two_add(wf0, wf1) << "\n";
std::cout << "-> two_add[raw](wf0, wf1) = " << eve::two_add[eve::raw](wf0, wf1) << "\n";
}
constexpr auto eps
Computes a constant to the machine epsilon.
Definition eps.hpp:74
Wrapper for SIMD registers.
Definition wide.hpp:94