E.V.E
v2023.02.15
Loading...
Searching...
No Matches
◆
mantissa
auto eve::mantissa =
functor
<mantissa_t>
inline
constexpr
Header file
#include <eve/module/core.hpp>
Callable Signatures
namespace
eve
{
// Regular overload
constexpr
auto
mantissa
(
floating_value
auto
x)
noexcept
;
// 1
// Lanes masking
constexpr
auto
mantissa
[
conditional_expr
auto
c](
floating_value
auto
x)
noexcept
;
// 2
constexpr
auto
mantissa
[
logical_value
auto
m](
floating_value
auto
x)
noexcept
;
// 2
// Semantic options
constexpr
auto
mantissa
[raw](
floating_value
auto
x)
noexcept
;
// 3
}
eve::conditional_expr
Specifies that a type is a Conditional Expression.
Definition
conditional.hpp:28
eve::floating_value
The concept floating_value<T> is satisfied if and only if T satisfies eve::value and the element type...
Definition
value.hpp:116
eve::logical_value
The concept logical_value<T> is satisfied if and only if T satisfies eve::value and the element type ...
Definition
value.hpp:134
eve::mantissa
constexpr auto mantissa
elementwise_callable object computing the IEEE mantissa of the floating value.
Definition
mantissa.hpp:81
eve
EVE Main Namespace.
Definition
abi.hpp:19
Parameters
x
:
real argument
.
c
:
Conditional expression
masking the operation.
m
:
Logical value
masking the operation.
Return value
The value of the IEEE mantissa is returned. In particular:
nan
returns nan
\(\pm\infty\) returns \(\pm\1\).
zero returns zero
The operation is performed conditionnaly
.
The results for zero and nan are unspecified.
Note
The
exponent
\(e\) and
mantissa
\(m\) of a floating point entry \(x\) are related by \(x = m\times 2^e\), with \(|m| \in \{0, nan\} \cup [1, 2[\).
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};
std::cout <<
"<- wf0 = "
<< wf0 <<
"\n"
;
std::cout <<
"-> mantissa(wf0) = "
<<
eve::mantissa
(wf0) <<
"\n"
;
std::cout <<
"-> mantissa[ignore_last(2)](wf0) = "
<<
eve::mantissa
[
eve::ignore_last
(2)](wf0) <<
"\n"
;
std::cout <<
"-> mantissa[wf0 != 0](wf0) = "
<<
eve::mantissa
[wf0 != 0](wf0) <<
"\n"
;
std::cout <<
"-> mantissa[raw](wf0) = "
<<
eve::mantissa
[eve::raw](wf0) <<
"\n"
;
}
eve::ignore_last
Conditional expression ignoring the k last lanes from a eve::simd_value.
Definition
conditional.hpp:353
eve::wide
Wrapper for SIMD registers.
Definition
wide.hpp:94
eve