3#ifndef pRC_CORE_VALUE_FLOAT_H
4#define pRC_CORE_VALUE_FLOAT_H
42 "Float<W>: W has to be a supported Width (16, 32, 64).");
45 template<
class V, If<IsValue<V>> = 0>
79 template<
class U, If<IsConstructible<Fundamental, U>> = 0>
93 template<
class U, If<IsValue<U>> = 0>
108 template<
class U, If<IsValue<U>> = 0>
154 template<
class U, If<IsAssignable<Fundamental, U>> = 0>
169 template<
class U, If<IsValue<U>> = 0>
185 template<
class U, If<IsValue<U>> = 0>
188 return *
this = value.real();
221 constexpr decltype(
auto)
operator()() &&
226 constexpr decltype(
auto)
operator()()
const &&
253 template<
class X, If<IsInvocable<Add, Float &, X>> = 0>
266 template<
class X, If<IsInvocable<Sub, Float &, X>> = 0>
279 template<
class X, If<IsInvocable<Mul, Float &, X>> = 0>
292 template<
class X, If<IsInvocable<Div, Float &, X>> = 0>
Custom Type representing a half-precision floating point number.
Definition bfloat16.hpp:26
Definition complex.hpp:26
Top-level class storing a floating point number.
Definition float.hpp:35
constexpr Float(Complex< U > const &value)
Float initializer from pRC::Complex object.
Definition float.hpp:109
constexpr auto & operator-=(X &&rhs) &
-= operator for Float
Definition float.hpp:267
constexpr Float & operator=(Float const &) &=default
constexpr Float(U const &value)
Float initializer from pRC value data type (like Float, Integer)
Definition float.hpp:94
pRC::Constant< Size, W > Width
Definition float.hpp:52
constexpr Float(Float &&)=default
Conditional< IsSatisfied<(W==16)>, BFloat16, Conditional< IsSatisfied<(W==32)>, float, Conditional< IsSatisfied<(W==64)>, double, Undefined > > > Fundamental
Definition float.hpp:39
constexpr auto & operator/=(X &&rhs) &
/= operator for Float
Definition float.hpp:293
constexpr auto & operator()() &
Definition float.hpp:231
constexpr auto & operator=(Zero<> const) &
Float assignment from pRC::Zero.
Definition float.hpp:196
constexpr auto & operator=(Identity<> const) &
Float assignment from pRC::Identity.
Definition float.hpp:216
constexpr auto & operator=(Complex< U > const &value) &
Float assignment from Complex object.
Definition float.hpp:186
Conditional< IsSatisfied<(R)>, Float< W >, Undefined > ChangeSigned
Definition float.hpp:50
constexpr Float(U const basic)
Float initializer from standard data types (like float, double)
Definition float.hpp:80
constexpr auto & operator*=(X &&rhs) &
*= operator for Float
Definition float.hpp:280
constexpr Float(Float const &)=default
constexpr Float & operator=(Float &&) &=default
V ChangeValue
Definition float.hpp:46
constexpr auto & operator+=(X &&rhs) &
+= operator for Float
Definition float.hpp:254
constexpr Float(Zero<> const)
Float initializer from pRC::Zero.
Definition float.hpp:119
constexpr auto & operator=(U const &value) &
Float assignment from pRC value data type (like Float, Integer)
Definition float.hpp:170
constexpr auto & operator=(Unit<> const) &
Float assignment from pRC::Unit.
Definition float.hpp:206
constexpr Float(Unit<> const)
Float initializer from pRC::Unit.
Definition float.hpp:129
constexpr auto & operator=(U const basic) &
Float assignment from standard data types (like float, double)
Definition float.hpp:155
constexpr Float()=default
constexpr Float(Identity<> const)
Float initializer from pRC::Identity.
Definition float.hpp:139
constexpr auto & operator()() const &
Definition float.hpp:236
Definition cholesky.hpp:18
static constexpr decltype(auto) real(X &&a)
Definition real.hpp:11
static constexpr auto zero()
Definition zero.hpp:12
std::integral_constant< T, V > Constant
Definition type_traits.hpp:34
Constant< Bool, B > IsSatisfied
Definition type_traits.hpp:71
static constexpr Conditional< IsSatisfied< C >, RemoveConstReference< X >, X > copy(X &&a)
Definition copy.hpp:13
static constexpr auto unit()
Definition unit.hpp:12
std::conditional_t< B{}, T, F > Conditional
Definition type_traits.hpp:131
static constexpr auto identity()
Definition identity.hpp:12
Definition type_traits.hpp:262
Definition type_traits.hpp:265
Definition type_traits.hpp:268