#[repr(transparent)]pub struct OrderedFloat<T>(pub T);
Expand description
A wrapper around floats providing implementations of Eq
, Ord
, and Hash
.
NaN is sorted as greater than all other values and equal to itself, in contradiction with the IEEE standard.
use ordered_float::OrderedFloat;
use std::f32::NAN;
let mut v = [OrderedFloat(NAN), OrderedFloat(2.0), OrderedFloat(1.0)];
v.sort();
assert_eq!(v, [OrderedFloat(1.0), OrderedFloat(2.0), OrderedFloat(NAN)]);
Because OrderedFloat
implements Ord
and Eq
, it can be used as a key in a HashSet
,
HashMap
, BTreeMap
, or BTreeSet
(unlike the primitive f32
or f64
types):
let mut s: HashSet<OrderedFloat<f32>> = HashSet::new();
s.insert(OrderedFloat(NAN));
assert!(s.contains(&OrderedFloat(NAN)));
Some non-identical values are still considered equal by the PartialEq
implementation,
and will therefore also be considered equal by maps, sets, and the ==
operator:
-0.0
and+0.0
are considered equal. This different sign may show up in printing, or when dividing by zero (the sign of the zero becomes the sign of the resulting infinity).- All NaN values are considered equal, even though they may have different bits, and therefore different sign, signaling/quiet status, and NaN payload bits.
Therefore, OrderedFloat
may be unsuitable for use as a key in interning and memoization
applications which require equal results from equal inputs, unless these cases make no
difference or are canonicalized before insertion.
§Representation
OrderedFloat
has #[repr(transparent)]
and permits any value, so it is sound to use
transmute or pointer casts to convert between any type T
and
OrderedFloat<T>
.
However, consider using bytemuck
as a safe alternative if possible.
Tuple Fields§
§0: T
Implementations§
Source§impl<T> OrderedFloat<T>where
T: FloatCore,
impl<T> OrderedFloat<T>where
T: FloatCore,
Sourcepub fn into_inner(self) -> T
pub fn into_inner(self) -> T
Get the value out.
Trait Implementations§
Source§impl<'a, T> Add<&'a OrderedFloat<T>> for OrderedFloat<T>
impl<'a, T> Add<&'a OrderedFloat<T>> for OrderedFloat<T>
Source§type Output = OrderedFloat<<T as Add<&'a T>>::Output>
type Output = OrderedFloat<<T as Add<&'a T>>::Output>
+
operator.Source§fn add(
self,
other: &'a OrderedFloat<T>,
) -> <OrderedFloat<T> as Add<&'a OrderedFloat<T>>>::Output
fn add( self, other: &'a OrderedFloat<T>, ) -> <OrderedFloat<T> as Add<&'a OrderedFloat<T>>>::Output
+
operation. Read moreSource§impl<'a, T> Add<&'a T> for &'a OrderedFloat<T>
impl<'a, T> Add<&'a T> for &'a OrderedFloat<T>
Source§impl<'a, T> Add<&'a T> for OrderedFloat<T>
impl<'a, T> Add<&'a T> for OrderedFloat<T>
Source§impl<'a, T> Add<OrderedFloat<T>> for &'a OrderedFloat<T>
impl<'a, T> Add<OrderedFloat<T>> for &'a OrderedFloat<T>
Source§type Output = OrderedFloat<<&'a T as Add<T>>::Output>
type Output = OrderedFloat<<&'a T as Add<T>>::Output>
+
operator.Source§fn add(
self,
other: OrderedFloat<T>,
) -> <&'a OrderedFloat<T> as Add<OrderedFloat<T>>>::Output
fn add( self, other: OrderedFloat<T>, ) -> <&'a OrderedFloat<T> as Add<OrderedFloat<T>>>::Output
+
operation. Read moreSource§impl<'a, T> Add<T> for &'a OrderedFloat<T>
impl<'a, T> Add<T> for &'a OrderedFloat<T>
Source§impl<T> Add<T> for OrderedFloat<T>where
T: Add,
impl<T> Add<T> for OrderedFloat<T>where
T: Add,
Source§impl<'a, T> Add for &'a OrderedFloat<T>
impl<'a, T> Add for &'a OrderedFloat<T>
Source§type Output = OrderedFloat<<T as Add>::Output>
type Output = OrderedFloat<<T as Add>::Output>
+
operator.Source§fn add(self, other: &'a OrderedFloat<T>) -> <&'a OrderedFloat<T> as Add>::Output
fn add(self, other: &'a OrderedFloat<T>) -> <&'a OrderedFloat<T> as Add>::Output
+
operation. Read moreSource§impl<T> Add for OrderedFloat<T>where
T: Add,
impl<T> Add for OrderedFloat<T>where
T: Add,
Source§type Output = OrderedFloat<<T as Add>::Output>
type Output = OrderedFloat<<T as Add>::Output>
+
operator.Source§fn add(self, other: OrderedFloat<T>) -> <OrderedFloat<T> as Add>::Output
fn add(self, other: OrderedFloat<T>) -> <OrderedFloat<T> as Add>::Output
+
operation. Read moreSource§impl<'a, T> AddAssign<&'a OrderedFloat<T>> for OrderedFloat<T>
impl<'a, T> AddAssign<&'a OrderedFloat<T>> for OrderedFloat<T>
Source§fn add_assign(&mut self, other: &'a OrderedFloat<T>)
fn add_assign(&mut self, other: &'a OrderedFloat<T>)
+=
operation. Read moreSource§impl<'a, T> AddAssign<&'a T> for OrderedFloat<T>
impl<'a, T> AddAssign<&'a T> for OrderedFloat<T>
Source§fn add_assign(&mut self, other: &'a T)
fn add_assign(&mut self, other: &'a T)
+=
operation. Read moreSource§impl<T> AddAssign<T> for OrderedFloat<T>where
T: AddAssign,
impl<T> AddAssign<T> for OrderedFloat<T>where
T: AddAssign,
Source§fn add_assign(&mut self, other: T)
fn add_assign(&mut self, other: T)
+=
operation. Read moreSource§impl<T> AddAssign for OrderedFloat<T>where
T: AddAssign,
impl<T> AddAssign for OrderedFloat<T>where
T: AddAssign,
Source§fn add_assign(&mut self, other: OrderedFloat<T>)
fn add_assign(&mut self, other: OrderedFloat<T>)
+=
operation. Read moreSource§impl<T> AsMut<T> for OrderedFloat<T>where
T: FloatCore,
impl<T> AsMut<T> for OrderedFloat<T>where
T: FloatCore,
Source§impl AsPrimitive<OrderedFloat<f32>> for OrderedFloat<f32>
impl AsPrimitive<OrderedFloat<f32>> for OrderedFloat<f32>
Source§fn as_(self) -> OrderedFloat<f32>
fn as_(self) -> OrderedFloat<f32>
as
operator.Source§impl AsPrimitive<OrderedFloat<f32>> for OrderedFloat<f64>
impl AsPrimitive<OrderedFloat<f32>> for OrderedFloat<f64>
Source§fn as_(self) -> OrderedFloat<f32>
fn as_(self) -> OrderedFloat<f32>
as
operator.Source§impl AsPrimitive<OrderedFloat<f32>> for u32
impl AsPrimitive<OrderedFloat<f32>> for u32
Source§fn as_(self) -> OrderedFloat<f32>
fn as_(self) -> OrderedFloat<f32>
as
operator.Source§impl AsPrimitive<OrderedFloat<f64>> for OrderedFloat<f32>
impl AsPrimitive<OrderedFloat<f64>> for OrderedFloat<f32>
Source§fn as_(self) -> OrderedFloat<f64>
fn as_(self) -> OrderedFloat<f64>
as
operator.Source§impl AsPrimitive<OrderedFloat<f64>> for OrderedFloat<f64>
impl AsPrimitive<OrderedFloat<f64>> for OrderedFloat<f64>
Source§fn as_(self) -> OrderedFloat<f64>
fn as_(self) -> OrderedFloat<f64>
as
operator.Source§impl AsPrimitive<OrderedFloat<f64>> for u32
impl AsPrimitive<OrderedFloat<f64>> for u32
Source§fn as_(self) -> OrderedFloat<f64>
fn as_(self) -> OrderedFloat<f64>
as
operator.Source§impl AsPrimitive<f32> for OrderedFloat<f32>
impl AsPrimitive<f32> for OrderedFloat<f32>
Source§impl AsPrimitive<f32> for OrderedFloat<f64>
impl AsPrimitive<f32> for OrderedFloat<f64>
Source§impl AsPrimitive<f64> for OrderedFloat<f32>
impl AsPrimitive<f64> for OrderedFloat<f32>
Source§impl AsPrimitive<f64> for OrderedFloat<f64>
impl AsPrimitive<f64> for OrderedFloat<f64>
Source§impl AsPrimitive<i16> for OrderedFloat<f32>
impl AsPrimitive<i16> for OrderedFloat<f32>
Source§impl AsPrimitive<i16> for OrderedFloat<f64>
impl AsPrimitive<i16> for OrderedFloat<f64>
Source§impl AsPrimitive<i32> for OrderedFloat<f32>
impl AsPrimitive<i32> for OrderedFloat<f32>
Source§impl AsPrimitive<i32> for OrderedFloat<f64>
impl AsPrimitive<i32> for OrderedFloat<f64>
Source§impl AsPrimitive<i64> for OrderedFloat<f32>
impl AsPrimitive<i64> for OrderedFloat<f32>
Source§impl AsPrimitive<i64> for OrderedFloat<f64>
impl AsPrimitive<i64> for OrderedFloat<f64>
Source§impl AsPrimitive<i8> for OrderedFloat<f32>
impl AsPrimitive<i8> for OrderedFloat<f32>
Source§impl AsPrimitive<i8> for OrderedFloat<f64>
impl AsPrimitive<i8> for OrderedFloat<f64>
Source§impl AsPrimitive<isize> for OrderedFloat<f32>
impl AsPrimitive<isize> for OrderedFloat<f32>
Source§impl AsPrimitive<isize> for OrderedFloat<f64>
impl AsPrimitive<isize> for OrderedFloat<f64>
Source§impl AsPrimitive<u16> for OrderedFloat<f32>
impl AsPrimitive<u16> for OrderedFloat<f32>
Source§impl AsPrimitive<u16> for OrderedFloat<f64>
impl AsPrimitive<u16> for OrderedFloat<f64>
Source§impl AsPrimitive<u32> for OrderedFloat<f32>
impl AsPrimitive<u32> for OrderedFloat<f32>
Source§impl AsPrimitive<u32> for OrderedFloat<f64>
impl AsPrimitive<u32> for OrderedFloat<f64>
Source§impl AsPrimitive<u64> for OrderedFloat<f32>
impl AsPrimitive<u64> for OrderedFloat<f32>
Source§impl AsPrimitive<u64> for OrderedFloat<f64>
impl AsPrimitive<u64> for OrderedFloat<f64>
Source§impl AsPrimitive<u8> for OrderedFloat<f32>
impl AsPrimitive<u8> for OrderedFloat<f32>
Source§impl AsPrimitive<u8> for OrderedFloat<f64>
impl AsPrimitive<u8> for OrderedFloat<f64>
Source§impl AsPrimitive<usize> for OrderedFloat<f32>
impl AsPrimitive<usize> for OrderedFloat<f32>
Source§impl AsPrimitive<usize> for OrderedFloat<f64>
impl AsPrimitive<usize> for OrderedFloat<f64>
Source§impl<T> AsRef<T> for OrderedFloat<T>where
T: FloatCore,
impl<T> AsRef<T> for OrderedFloat<T>where
T: FloatCore,
Source§impl<T> Bounded for OrderedFloat<T>where
T: Bounded,
impl<T> Bounded for OrderedFloat<T>where
T: Bounded,
Source§fn min_value() -> OrderedFloat<T>
fn min_value() -> OrderedFloat<T>
Source§fn max_value() -> OrderedFloat<T>
fn max_value() -> OrderedFloat<T>
Source§impl<T> Clone for OrderedFloat<T>where
T: Clone,
impl<T> Clone for OrderedFloat<T>where
T: Clone,
Source§fn clone(&self) -> OrderedFloat<T>
fn clone(&self) -> OrderedFloat<T>
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moreSource§impl<T> Debug for OrderedFloat<T>where
T: Debug,
impl<T> Debug for OrderedFloat<T>where
T: Debug,
Source§impl<T> Default for OrderedFloat<T>where
T: Default,
impl<T> Default for OrderedFloat<T>where
T: Default,
Source§fn default() -> OrderedFloat<T>
fn default() -> OrderedFloat<T>
Source§impl<T> Deref for OrderedFloat<T>where
T: FloatCore,
impl<T> Deref for OrderedFloat<T>where
T: FloatCore,
Source§impl<T> DerefMut for OrderedFloat<T>where
T: FloatCore,
impl<T> DerefMut for OrderedFloat<T>where
T: FloatCore,
Source§impl<T> Display for OrderedFloat<T>
impl<T> Display for OrderedFloat<T>
Source§impl<'a, T> Div<&'a OrderedFloat<T>> for OrderedFloat<T>
impl<'a, T> Div<&'a OrderedFloat<T>> for OrderedFloat<T>
Source§type Output = OrderedFloat<<T as Div<&'a T>>::Output>
type Output = OrderedFloat<<T as Div<&'a T>>::Output>
/
operator.Source§fn div(
self,
other: &'a OrderedFloat<T>,
) -> <OrderedFloat<T> as Div<&'a OrderedFloat<T>>>::Output
fn div( self, other: &'a OrderedFloat<T>, ) -> <OrderedFloat<T> as Div<&'a OrderedFloat<T>>>::Output
/
operation. Read moreSource§impl<'a, T> Div<&'a T> for &'a OrderedFloat<T>
impl<'a, T> Div<&'a T> for &'a OrderedFloat<T>
Source§impl<'a, T> Div<&'a T> for OrderedFloat<T>
impl<'a, T> Div<&'a T> for OrderedFloat<T>
Source§impl<'a, T> Div<OrderedFloat<T>> for &'a OrderedFloat<T>
impl<'a, T> Div<OrderedFloat<T>> for &'a OrderedFloat<T>
Source§type Output = OrderedFloat<<&'a T as Div<T>>::Output>
type Output = OrderedFloat<<&'a T as Div<T>>::Output>
/
operator.Source§fn div(
self,
other: OrderedFloat<T>,
) -> <&'a OrderedFloat<T> as Div<OrderedFloat<T>>>::Output
fn div( self, other: OrderedFloat<T>, ) -> <&'a OrderedFloat<T> as Div<OrderedFloat<T>>>::Output
/
operation. Read moreSource§impl<'a, T> Div<T> for &'a OrderedFloat<T>
impl<'a, T> Div<T> for &'a OrderedFloat<T>
Source§impl<T> Div<T> for OrderedFloat<T>where
T: Div,
impl<T> Div<T> for OrderedFloat<T>where
T: Div,
Source§impl<'a, T> Div for &'a OrderedFloat<T>
impl<'a, T> Div for &'a OrderedFloat<T>
Source§type Output = OrderedFloat<<T as Div>::Output>
type Output = OrderedFloat<<T as Div>::Output>
/
operator.Source§fn div(self, other: &'a OrderedFloat<T>) -> <&'a OrderedFloat<T> as Div>::Output
fn div(self, other: &'a OrderedFloat<T>) -> <&'a OrderedFloat<T> as Div>::Output
/
operation. Read moreSource§impl<T> Div for OrderedFloat<T>where
T: Div,
impl<T> Div for OrderedFloat<T>where
T: Div,
Source§type Output = OrderedFloat<<T as Div>::Output>
type Output = OrderedFloat<<T as Div>::Output>
/
operator.Source§fn div(self, other: OrderedFloat<T>) -> <OrderedFloat<T> as Div>::Output
fn div(self, other: OrderedFloat<T>) -> <OrderedFloat<T> as Div>::Output
/
operation. Read moreSource§impl<'a, T> DivAssign<&'a OrderedFloat<T>> for OrderedFloat<T>
impl<'a, T> DivAssign<&'a OrderedFloat<T>> for OrderedFloat<T>
Source§fn div_assign(&mut self, other: &'a OrderedFloat<T>)
fn div_assign(&mut self, other: &'a OrderedFloat<T>)
/=
operation. Read moreSource§impl<'a, T> DivAssign<&'a T> for OrderedFloat<T>
impl<'a, T> DivAssign<&'a T> for OrderedFloat<T>
Source§fn div_assign(&mut self, other: &'a T)
fn div_assign(&mut self, other: &'a T)
/=
operation. Read moreSource§impl<T> DivAssign<T> for OrderedFloat<T>where
T: DivAssign,
impl<T> DivAssign<T> for OrderedFloat<T>where
T: DivAssign,
Source§fn div_assign(&mut self, other: T)
fn div_assign(&mut self, other: T)
/=
operation. Read moreSource§impl<T> DivAssign for OrderedFloat<T>where
T: DivAssign,
impl<T> DivAssign for OrderedFloat<T>where
T: DivAssign,
Source§fn div_assign(&mut self, other: OrderedFloat<T>)
fn div_assign(&mut self, other: OrderedFloat<T>)
/=
operation. Read moreSource§impl<T> Float for OrderedFloat<T>
impl<T> Float for OrderedFloat<T>
Source§fn nan() -> OrderedFloat<T>
fn nan() -> OrderedFloat<T>
NaN
value. Read moreSource§fn infinity() -> OrderedFloat<T>
fn infinity() -> OrderedFloat<T>
Source§fn neg_infinity() -> OrderedFloat<T>
fn neg_infinity() -> OrderedFloat<T>
Source§fn neg_zero() -> OrderedFloat<T>
fn neg_zero() -> OrderedFloat<T>
-0.0
. Read moreSource§fn min_value() -> OrderedFloat<T>
fn min_value() -> OrderedFloat<T>
Source§fn min_positive_value() -> OrderedFloat<T>
fn min_positive_value() -> OrderedFloat<T>
Source§fn max_value() -> OrderedFloat<T>
fn max_value() -> OrderedFloat<T>
Source§fn is_infinite(self) -> bool
fn is_infinite(self) -> bool
true
if this value is positive infinity or negative infinity and
false otherwise. Read moreSource§fn classify(self) -> FpCategory
fn classify(self) -> FpCategory
Source§fn floor(self) -> OrderedFloat<T>
fn floor(self) -> OrderedFloat<T>
Source§fn ceil(self) -> OrderedFloat<T>
fn ceil(self) -> OrderedFloat<T>
Source§fn round(self) -> OrderedFloat<T>
fn round(self) -> OrderedFloat<T>
0.0
. Read moreSource§fn trunc(self) -> OrderedFloat<T>
fn trunc(self) -> OrderedFloat<T>
Source§fn fract(self) -> OrderedFloat<T>
fn fract(self) -> OrderedFloat<T>
Source§fn abs(self) -> OrderedFloat<T>
fn abs(self) -> OrderedFloat<T>
Source§fn signum(self) -> OrderedFloat<T>
fn signum(self) -> OrderedFloat<T>
self
. Read moreSource§fn is_sign_positive(self) -> bool
fn is_sign_positive(self) -> bool
Source§fn is_sign_negative(self) -> bool
fn is_sign_negative(self) -> bool
true
if self
is negative, including -0.0
,
Float::neg_infinity()
, and -Float::nan()
. Read moreSource§fn mul_add(self, a: OrderedFloat<T>, b: OrderedFloat<T>) -> OrderedFloat<T>
fn mul_add(self, a: OrderedFloat<T>, b: OrderedFloat<T>) -> OrderedFloat<T>
(self * a) + b
with only one rounding
error, yielding a more accurate result than an unfused multiply-add. Read moreSource§fn recip(self) -> OrderedFloat<T>
fn recip(self) -> OrderedFloat<T>
1/x
. Read moreSource§fn powf(self, n: OrderedFloat<T>) -> OrderedFloat<T>
fn powf(self, n: OrderedFloat<T>) -> OrderedFloat<T>
Source§fn sqrt(self) -> OrderedFloat<T>
fn sqrt(self) -> OrderedFloat<T>
Source§fn exp(self) -> OrderedFloat<T>
fn exp(self) -> OrderedFloat<T>
e^(self)
, (the exponential function). Read moreSource§fn exp2(self) -> OrderedFloat<T>
fn exp2(self) -> OrderedFloat<T>
2^(self)
. Read moreSource§fn ln(self) -> OrderedFloat<T>
fn ln(self) -> OrderedFloat<T>
Source§fn log(self, base: OrderedFloat<T>) -> OrderedFloat<T>
fn log(self, base: OrderedFloat<T>) -> OrderedFloat<T>
Source§fn log2(self) -> OrderedFloat<T>
fn log2(self) -> OrderedFloat<T>
Source§fn log10(self) -> OrderedFloat<T>
fn log10(self) -> OrderedFloat<T>
Source§fn max(self, other: OrderedFloat<T>) -> OrderedFloat<T>
fn max(self, other: OrderedFloat<T>) -> OrderedFloat<T>
Source§fn min(self, other: OrderedFloat<T>) -> OrderedFloat<T>
fn min(self, other: OrderedFloat<T>) -> OrderedFloat<T>
Source§fn abs_sub(self, other: OrderedFloat<T>) -> OrderedFloat<T>
fn abs_sub(self, other: OrderedFloat<T>) -> OrderedFloat<T>
Source§fn cbrt(self) -> OrderedFloat<T>
fn cbrt(self) -> OrderedFloat<T>
Source§fn hypot(self, other: OrderedFloat<T>) -> OrderedFloat<T>
fn hypot(self, other: OrderedFloat<T>) -> OrderedFloat<T>
x
and y
. Read moreSource§fn sin(self) -> OrderedFloat<T>
fn sin(self) -> OrderedFloat<T>
Source§fn cos(self) -> OrderedFloat<T>
fn cos(self) -> OrderedFloat<T>
Source§fn tan(self) -> OrderedFloat<T>
fn tan(self) -> OrderedFloat<T>
Source§fn asin(self) -> OrderedFloat<T>
fn asin(self) -> OrderedFloat<T>
Source§fn acos(self) -> OrderedFloat<T>
fn acos(self) -> OrderedFloat<T>
Source§fn atan(self) -> OrderedFloat<T>
fn atan(self) -> OrderedFloat<T>
Source§fn atan2(self, other: OrderedFloat<T>) -> OrderedFloat<T>
fn atan2(self, other: OrderedFloat<T>) -> OrderedFloat<T>
Source§fn sin_cos(self) -> (OrderedFloat<T>, OrderedFloat<T>)
fn sin_cos(self) -> (OrderedFloat<T>, OrderedFloat<T>)
Source§fn exp_m1(self) -> OrderedFloat<T>
fn exp_m1(self) -> OrderedFloat<T>
e^(self) - 1
in a way that is accurate even if the
number is close to zero. Read moreSource§fn ln_1p(self) -> OrderedFloat<T>
fn ln_1p(self) -> OrderedFloat<T>
ln(1+n)
(natural logarithm) more accurately than if
the operations were performed separately. Read moreSource§fn sinh(self) -> OrderedFloat<T>
fn sinh(self) -> OrderedFloat<T>
Source§fn cosh(self) -> OrderedFloat<T>
fn cosh(self) -> OrderedFloat<T>
Source§fn tanh(self) -> OrderedFloat<T>
fn tanh(self) -> OrderedFloat<T>
Source§fn asinh(self) -> OrderedFloat<T>
fn asinh(self) -> OrderedFloat<T>
Source§fn acosh(self) -> OrderedFloat<T>
fn acosh(self) -> OrderedFloat<T>
Source§fn atanh(self) -> OrderedFloat<T>
fn atanh(self) -> OrderedFloat<T>
Source§fn integer_decode(self) -> (u64, i16, i8)
fn integer_decode(self) -> (u64, i16, i8)
sign * mantissa * 2 ^ exponent
. Read moreSource§fn epsilon() -> OrderedFloat<T>
fn epsilon() -> OrderedFloat<T>
Source§fn to_degrees(self) -> OrderedFloat<T>
fn to_degrees(self) -> OrderedFloat<T>
Source§fn to_radians(self) -> OrderedFloat<T>
fn to_radians(self) -> OrderedFloat<T>
Source§impl<T> FloatConst for OrderedFloat<T>where
T: FloatConst,
impl<T> FloatConst for OrderedFloat<T>where
T: FloatConst,
Source§fn E() -> OrderedFloat<T>
fn E() -> OrderedFloat<T>
Source§fn FRAC_1_PI() -> OrderedFloat<T>
fn FRAC_1_PI() -> OrderedFloat<T>
1.0 / π
.Source§fn FRAC_1_SQRT_2() -> OrderedFloat<T>
fn FRAC_1_SQRT_2() -> OrderedFloat<T>
1.0 / sqrt(2.0)
.Source§fn FRAC_2_PI() -> OrderedFloat<T>
fn FRAC_2_PI() -> OrderedFloat<T>
2.0 / π
.Source§fn FRAC_2_SQRT_PI() -> OrderedFloat<T>
fn FRAC_2_SQRT_PI() -> OrderedFloat<T>
2.0 / sqrt(π)
.Source§fn FRAC_PI_2() -> OrderedFloat<T>
fn FRAC_PI_2() -> OrderedFloat<T>
π / 2.0
.Source§fn FRAC_PI_3() -> OrderedFloat<T>
fn FRAC_PI_3() -> OrderedFloat<T>
π / 3.0
.Source§fn FRAC_PI_4() -> OrderedFloat<T>
fn FRAC_PI_4() -> OrderedFloat<T>
π / 4.0
.Source§fn FRAC_PI_6() -> OrderedFloat<T>
fn FRAC_PI_6() -> OrderedFloat<T>
π / 6.0
.Source§fn FRAC_PI_8() -> OrderedFloat<T>
fn FRAC_PI_8() -> OrderedFloat<T>
π / 8.0
.Source§fn LN_10() -> OrderedFloat<T>
fn LN_10() -> OrderedFloat<T>
ln(10.0)
.Source§fn LN_2() -> OrderedFloat<T>
fn LN_2() -> OrderedFloat<T>
ln(2.0)
.Source§fn LOG10_E() -> OrderedFloat<T>
fn LOG10_E() -> OrderedFloat<T>
log10(e)
.Source§fn LOG2_E() -> OrderedFloat<T>
fn LOG2_E() -> OrderedFloat<T>
log2(e)
.Source§fn PI() -> OrderedFloat<T>
fn PI() -> OrderedFloat<T>
π
.Source§fn SQRT_2() -> OrderedFloat<T>
fn SQRT_2() -> OrderedFloat<T>
sqrt(2.0)
.Source§impl<T> FloatCore for OrderedFloat<T>where
T: FloatCore,
impl<T> FloatCore for OrderedFloat<T>where
T: FloatCore,
Source§fn nan() -> OrderedFloat<T>
fn nan() -> OrderedFloat<T>
Source§fn infinity() -> OrderedFloat<T>
fn infinity() -> OrderedFloat<T>
Source§fn neg_infinity() -> OrderedFloat<T>
fn neg_infinity() -> OrderedFloat<T>
Source§fn neg_zero() -> OrderedFloat<T>
fn neg_zero() -> OrderedFloat<T>
-0.0
. Read moreSource§fn min_value() -> OrderedFloat<T>
fn min_value() -> OrderedFloat<T>
Source§fn min_positive_value() -> OrderedFloat<T>
fn min_positive_value() -> OrderedFloat<T>
Source§fn max_value() -> OrderedFloat<T>
fn max_value() -> OrderedFloat<T>
Source§fn is_infinite(self) -> bool
fn is_infinite(self) -> bool
true
if the number is infinite. Read moreSource§fn is_normal(self) -> bool
fn is_normal(self) -> bool
true
if the number is neither zero, infinite, subnormal or NaN. Read moreSource§fn classify(self) -> FpCategory
fn classify(self) -> FpCategory
Source§fn floor(self) -> OrderedFloat<T>
fn floor(self) -> OrderedFloat<T>
Source§fn ceil(self) -> OrderedFloat<T>
fn ceil(self) -> OrderedFloat<T>
Source§fn round(self) -> OrderedFloat<T>
fn round(self) -> OrderedFloat<T>
0.0
. Read moreSource§fn trunc(self) -> OrderedFloat<T>
fn trunc(self) -> OrderedFloat<T>
Source§fn fract(self) -> OrderedFloat<T>
fn fract(self) -> OrderedFloat<T>
Source§fn abs(self) -> OrderedFloat<T>
fn abs(self) -> OrderedFloat<T>
self
. Returns FloatCore::nan()
if the
number is FloatCore::nan()
. Read moreSource§fn signum(self) -> OrderedFloat<T>
fn signum(self) -> OrderedFloat<T>
self
. Read moreSource§fn is_sign_positive(self) -> bool
fn is_sign_positive(self) -> bool
true
if self
is positive, including +0.0
and
FloatCore::infinity()
, and FloatCore::nan()
. Read moreSource§fn is_sign_negative(self) -> bool
fn is_sign_negative(self) -> bool
true
if self
is negative, including -0.0
and
FloatCore::neg_infinity()
, and -FloatCore::nan()
. Read moreSource§fn recip(self) -> OrderedFloat<T>
fn recip(self) -> OrderedFloat<T>
Source§fn integer_decode(self) -> (u64, i16, i8)
fn integer_decode(self) -> (u64, i16, i8)
sign * mantissa * 2 ^ exponent
. Read moreSource§fn epsilon() -> OrderedFloat<T>
fn epsilon() -> OrderedFloat<T>
Source§fn to_degrees(self) -> OrderedFloat<T>
fn to_degrees(self) -> OrderedFloat<T>
Source§fn to_radians(self) -> OrderedFloat<T>
fn to_radians(self) -> OrderedFloat<T>
Source§impl<'a, T> From<&'a T> for &'a OrderedFloat<T>where
T: FloatCore,
impl<'a, T> From<&'a T> for &'a OrderedFloat<T>where
T: FloatCore,
Source§fn from(t: &'a T) -> &'a OrderedFloat<T>
fn from(t: &'a T) -> &'a OrderedFloat<T>
Source§impl<'a, T> From<&'a mut T> for &'a mut OrderedFloat<T>where
T: FloatCore,
impl<'a, T> From<&'a mut T> for &'a mut OrderedFloat<T>where
T: FloatCore,
Source§fn from(t: &'a mut T) -> &'a mut OrderedFloat<T>
fn from(t: &'a mut T) -> &'a mut OrderedFloat<T>
Source§impl From<OrderedFloat<f64>> for ExprResult
impl From<OrderedFloat<f64>> for ExprResult
Source§fn from(f: OrderedFloat<f64>) -> ExprResult
fn from(f: OrderedFloat<f64>) -> ExprResult
Source§impl<T> From<T> for OrderedFloat<T>where
T: FloatCore,
impl<T> From<T> for OrderedFloat<T>where
T: FloatCore,
Source§fn from(val: T) -> OrderedFloat<T>
fn from(val: T) -> OrderedFloat<T>
Source§impl<T> FromPrimitive for OrderedFloat<T>where
T: FromPrimitive,
impl<T> FromPrimitive for OrderedFloat<T>where
T: FromPrimitive,
Source§fn from_i64(n: i64) -> Option<OrderedFloat<T>>
fn from_i64(n: i64) -> Option<OrderedFloat<T>>
i64
to return an optional value of this type. If the
value cannot be represented by this type, then None
is returned.Source§fn from_u64(n: u64) -> Option<OrderedFloat<T>>
fn from_u64(n: u64) -> Option<OrderedFloat<T>>
u64
to return an optional value of this type. If the
value cannot be represented by this type, then None
is returned.Source§fn from_isize(n: isize) -> Option<OrderedFloat<T>>
fn from_isize(n: isize) -> Option<OrderedFloat<T>>
isize
to return an optional value of this type. If the
value cannot be represented by this type, then None
is returned.Source§fn from_i8(n: i8) -> Option<OrderedFloat<T>>
fn from_i8(n: i8) -> Option<OrderedFloat<T>>
i8
to return an optional value of this type. If the
value cannot be represented by this type, then None
is returned.Source§fn from_i16(n: i16) -> Option<OrderedFloat<T>>
fn from_i16(n: i16) -> Option<OrderedFloat<T>>
i16
to return an optional value of this type. If the
value cannot be represented by this type, then None
is returned.Source§fn from_i32(n: i32) -> Option<OrderedFloat<T>>
fn from_i32(n: i32) -> Option<OrderedFloat<T>>
i32
to return an optional value of this type. If the
value cannot be represented by this type, then None
is returned.Source§fn from_usize(n: usize) -> Option<OrderedFloat<T>>
fn from_usize(n: usize) -> Option<OrderedFloat<T>>
usize
to return an optional value of this type. If the
value cannot be represented by this type, then None
is returned.Source§fn from_u8(n: u8) -> Option<OrderedFloat<T>>
fn from_u8(n: u8) -> Option<OrderedFloat<T>>
u8
to return an optional value of this type. If the
value cannot be represented by this type, then None
is returned.Source§fn from_u16(n: u16) -> Option<OrderedFloat<T>>
fn from_u16(n: u16) -> Option<OrderedFloat<T>>
u16
to return an optional value of this type. If the
value cannot be represented by this type, then None
is returned.Source§fn from_u32(n: u32) -> Option<OrderedFloat<T>>
fn from_u32(n: u32) -> Option<OrderedFloat<T>>
u32
to return an optional value of this type. If the
value cannot be represented by this type, then None
is returned.Source§fn from_f32(n: f32) -> Option<OrderedFloat<T>>
fn from_f32(n: f32) -> Option<OrderedFloat<T>>
f32
to return an optional value of this type. If the
value cannot be represented by this type, then None
is returned.Source§fn from_f64(n: f64) -> Option<OrderedFloat<T>>
fn from_f64(n: f64) -> Option<OrderedFloat<T>>
f64
to return an optional value of this type. If the
value cannot be represented by this type, then None
is returned. Read moreSource§impl<T> FromStr for OrderedFloat<T>where
T: FromStr,
impl<T> FromStr for OrderedFloat<T>where
T: FromStr,
Source§fn from_str(
s: &str,
) -> Result<OrderedFloat<T>, <OrderedFloat<T> as FromStr>::Err>
fn from_str( s: &str, ) -> Result<OrderedFloat<T>, <OrderedFloat<T> as FromStr>::Err>
Convert a &str to OrderedFloat
. Returns an error if the string fails to parse.
use ordered_float::OrderedFloat;
assert!("-10".parse::<OrderedFloat<f32>>().is_ok());
assert!("abc".parse::<OrderedFloat<f32>>().is_err());
assert!("NaN".parse::<OrderedFloat<f32>>().is_ok());
Source§impl<T> Hash for OrderedFloat<T>where
T: FloatCore,
impl<T> Hash for OrderedFloat<T>where
T: FloatCore,
Source§impl<T> LowerExp for OrderedFloat<T>
impl<T> LowerExp for OrderedFloat<T>
Source§impl<'a, T> Mul<&'a OrderedFloat<T>> for OrderedFloat<T>
impl<'a, T> Mul<&'a OrderedFloat<T>> for OrderedFloat<T>
Source§type Output = OrderedFloat<<T as Mul<&'a T>>::Output>
type Output = OrderedFloat<<T as Mul<&'a T>>::Output>
*
operator.Source§fn mul(
self,
other: &'a OrderedFloat<T>,
) -> <OrderedFloat<T> as Mul<&'a OrderedFloat<T>>>::Output
fn mul( self, other: &'a OrderedFloat<T>, ) -> <OrderedFloat<T> as Mul<&'a OrderedFloat<T>>>::Output
*
operation. Read moreSource§impl<'a, T> Mul<&'a T> for &'a OrderedFloat<T>
impl<'a, T> Mul<&'a T> for &'a OrderedFloat<T>
Source§impl<'a, T> Mul<&'a T> for OrderedFloat<T>
impl<'a, T> Mul<&'a T> for OrderedFloat<T>
Source§impl<'a, T> Mul<OrderedFloat<T>> for &'a OrderedFloat<T>
impl<'a, T> Mul<OrderedFloat<T>> for &'a OrderedFloat<T>
Source§type Output = OrderedFloat<<&'a T as Mul<T>>::Output>
type Output = OrderedFloat<<&'a T as Mul<T>>::Output>
*
operator.Source§fn mul(
self,
other: OrderedFloat<T>,
) -> <&'a OrderedFloat<T> as Mul<OrderedFloat<T>>>::Output
fn mul( self, other: OrderedFloat<T>, ) -> <&'a OrderedFloat<T> as Mul<OrderedFloat<T>>>::Output
*
operation. Read moreSource§impl<'a, T> Mul<T> for &'a OrderedFloat<T>
impl<'a, T> Mul<T> for &'a OrderedFloat<T>
Source§impl<T> Mul<T> for OrderedFloat<T>where
T: Mul,
impl<T> Mul<T> for OrderedFloat<T>where
T: Mul,
Source§impl<'a, T> Mul for &'a OrderedFloat<T>
impl<'a, T> Mul for &'a OrderedFloat<T>
Source§type Output = OrderedFloat<<T as Mul>::Output>
type Output = OrderedFloat<<T as Mul>::Output>
*
operator.Source§fn mul(self, other: &'a OrderedFloat<T>) -> <&'a OrderedFloat<T> as Mul>::Output
fn mul(self, other: &'a OrderedFloat<T>) -> <&'a OrderedFloat<T> as Mul>::Output
*
operation. Read moreSource§impl<T> Mul for OrderedFloat<T>where
T: Mul,
impl<T> Mul for OrderedFloat<T>where
T: Mul,
Source§type Output = OrderedFloat<<T as Mul>::Output>
type Output = OrderedFloat<<T as Mul>::Output>
*
operator.Source§fn mul(self, other: OrderedFloat<T>) -> <OrderedFloat<T> as Mul>::Output
fn mul(self, other: OrderedFloat<T>) -> <OrderedFloat<T> as Mul>::Output
*
operation. Read moreSource§impl<'a, T> MulAssign<&'a OrderedFloat<T>> for OrderedFloat<T>
impl<'a, T> MulAssign<&'a OrderedFloat<T>> for OrderedFloat<T>
Source§fn mul_assign(&mut self, other: &'a OrderedFloat<T>)
fn mul_assign(&mut self, other: &'a OrderedFloat<T>)
*=
operation. Read moreSource§impl<'a, T> MulAssign<&'a T> for OrderedFloat<T>
impl<'a, T> MulAssign<&'a T> for OrderedFloat<T>
Source§fn mul_assign(&mut self, other: &'a T)
fn mul_assign(&mut self, other: &'a T)
*=
operation. Read moreSource§impl<T> MulAssign<T> for OrderedFloat<T>where
T: MulAssign,
impl<T> MulAssign<T> for OrderedFloat<T>where
T: MulAssign,
Source§fn mul_assign(&mut self, other: T)
fn mul_assign(&mut self, other: T)
*=
operation. Read moreSource§impl<T> MulAssign for OrderedFloat<T>where
T: MulAssign,
impl<T> MulAssign for OrderedFloat<T>where
T: MulAssign,
Source§fn mul_assign(&mut self, other: OrderedFloat<T>)
fn mul_assign(&mut self, other: OrderedFloat<T>)
*=
operation. Read moreSource§impl<'a, T> Neg for &'a OrderedFloat<T>
impl<'a, T> Neg for &'a OrderedFloat<T>
Source§impl<T> Neg for OrderedFloat<T>where
T: Neg,
impl<T> Neg for OrderedFloat<T>where
T: Neg,
Source§impl<T> Num for OrderedFloat<T>
impl<T> Num for OrderedFloat<T>
type FromStrRadixErr = <T as Num>::FromStrRadixErr
Source§fn from_str_radix(
str: &str,
radix: u32,
) -> Result<OrderedFloat<T>, <OrderedFloat<T> as Num>::FromStrRadixErr>
fn from_str_radix( str: &str, radix: u32, ) -> Result<OrderedFloat<T>, <OrderedFloat<T> as Num>::FromStrRadixErr>
2..=36
). Read moreSource§impl<T> NumCast for OrderedFloat<T>where
T: NumCast,
impl<T> NumCast for OrderedFloat<T>where
T: NumCast,
Source§fn from<F>(n: F) -> Option<OrderedFloat<T>>where
F: ToPrimitive,
fn from<F>(n: F) -> Option<OrderedFloat<T>>where
F: ToPrimitive,
ToPrimitive
trait. If the source value cannot be
represented by the target type, then None
is returned. Read moreSource§impl<T> One for OrderedFloat<T>where
T: One,
impl<T> One for OrderedFloat<T>where
T: One,
Source§fn one() -> OrderedFloat<T>
fn one() -> OrderedFloat<T>
Source§impl<T> Ord for OrderedFloat<T>where
T: FloatCore,
impl<T> Ord for OrderedFloat<T>where
T: FloatCore,
Source§fn cmp(&self, other: &OrderedFloat<T>) -> Ordering
fn cmp(&self, other: &OrderedFloat<T>) -> Ordering
1.21.0 · Source§fn max(self, other: Self) -> Selfwhere
Self: Sized,
fn max(self, other: Self) -> Selfwhere
Self: Sized,
Source§impl<T> PartialEq<T> for OrderedFloat<T>where
T: FloatCore,
impl<T> PartialEq<T> for OrderedFloat<T>where
T: FloatCore,
Source§impl<T> PartialEq for OrderedFloat<T>where
T: FloatCore,
impl<T> PartialEq for OrderedFloat<T>where
T: FloatCore,
Source§impl<T> PartialOrd for OrderedFloat<T>where
T: FloatCore,
impl<T> PartialOrd for OrderedFloat<T>where
T: FloatCore,
Source§fn partial_cmp(&self, other: &OrderedFloat<T>) -> Option<Ordering>
fn partial_cmp(&self, other: &OrderedFloat<T>) -> Option<Ordering>
Source§fn lt(&self, other: &OrderedFloat<T>) -> bool
fn lt(&self, other: &OrderedFloat<T>) -> bool
Source§fn le(&self, other: &OrderedFloat<T>) -> bool
fn le(&self, other: &OrderedFloat<T>) -> bool
Source§fn gt(&self, other: &OrderedFloat<T>) -> bool
fn gt(&self, other: &OrderedFloat<T>) -> bool
Source§impl<'a, 'b> Pow<&'a OrderedFloat<f32>> for &'b OrderedFloat<f32>
impl<'a, 'b> Pow<&'a OrderedFloat<f32>> for &'b OrderedFloat<f32>
Source§type Output = OrderedFloat<f32>
type Output = OrderedFloat<f32>
Source§fn pow(self, rhs: &'a OrderedFloat<f32>) -> OrderedFloat<f32>
fn pow(self, rhs: &'a OrderedFloat<f32>) -> OrderedFloat<f32>
Source§impl<'a, 'b> Pow<&'a OrderedFloat<f32>> for &'b OrderedFloat<f64>
impl<'a, 'b> Pow<&'a OrderedFloat<f32>> for &'b OrderedFloat<f64>
Source§type Output = OrderedFloat<f64>
type Output = OrderedFloat<f64>
Source§fn pow(self, rhs: &'a OrderedFloat<f32>) -> OrderedFloat<f64>
fn pow(self, rhs: &'a OrderedFloat<f32>) -> OrderedFloat<f64>
Source§impl<'a> Pow<&'a OrderedFloat<f32>> for OrderedFloat<f32>
impl<'a> Pow<&'a OrderedFloat<f32>> for OrderedFloat<f32>
Source§type Output = OrderedFloat<f32>
type Output = OrderedFloat<f32>
Source§fn pow(self, rhs: &'a OrderedFloat<f32>) -> OrderedFloat<f32>
fn pow(self, rhs: &'a OrderedFloat<f32>) -> OrderedFloat<f32>
Source§impl<'a> Pow<&'a OrderedFloat<f32>> for OrderedFloat<f64>
impl<'a> Pow<&'a OrderedFloat<f32>> for OrderedFloat<f64>
Source§type Output = OrderedFloat<f64>
type Output = OrderedFloat<f64>
Source§fn pow(self, rhs: &'a OrderedFloat<f32>) -> OrderedFloat<f64>
fn pow(self, rhs: &'a OrderedFloat<f32>) -> OrderedFloat<f64>
Source§impl<'a, 'b> Pow<&'a OrderedFloat<f64>> for &'b OrderedFloat<f64>
impl<'a, 'b> Pow<&'a OrderedFloat<f64>> for &'b OrderedFloat<f64>
Source§type Output = OrderedFloat<f64>
type Output = OrderedFloat<f64>
Source§fn pow(self, rhs: &'a OrderedFloat<f64>) -> OrderedFloat<f64>
fn pow(self, rhs: &'a OrderedFloat<f64>) -> OrderedFloat<f64>
Source§impl<'a> Pow<&'a OrderedFloat<f64>> for OrderedFloat<f64>
impl<'a> Pow<&'a OrderedFloat<f64>> for OrderedFloat<f64>
Source§type Output = OrderedFloat<f64>
type Output = OrderedFloat<f64>
Source§fn pow(self, rhs: &'a OrderedFloat<f64>) -> OrderedFloat<f64>
fn pow(self, rhs: &'a OrderedFloat<f64>) -> OrderedFloat<f64>
Source§impl<'a> Pow<OrderedFloat<f32>> for &'a OrderedFloat<f32>
impl<'a> Pow<OrderedFloat<f32>> for &'a OrderedFloat<f32>
Source§type Output = OrderedFloat<f32>
type Output = OrderedFloat<f32>
Source§fn pow(self, rhs: OrderedFloat<f32>) -> OrderedFloat<f32>
fn pow(self, rhs: OrderedFloat<f32>) -> OrderedFloat<f32>
Source§impl<'a> Pow<OrderedFloat<f32>> for &'a OrderedFloat<f64>
impl<'a> Pow<OrderedFloat<f32>> for &'a OrderedFloat<f64>
Source§type Output = OrderedFloat<f64>
type Output = OrderedFloat<f64>
Source§fn pow(self, rhs: OrderedFloat<f32>) -> OrderedFloat<f64>
fn pow(self, rhs: OrderedFloat<f32>) -> OrderedFloat<f64>
Source§impl Pow<OrderedFloat<f32>> for OrderedFloat<f32>
impl Pow<OrderedFloat<f32>> for OrderedFloat<f32>
Source§type Output = OrderedFloat<f32>
type Output = OrderedFloat<f32>
Source§fn pow(self, rhs: OrderedFloat<f32>) -> OrderedFloat<f32>
fn pow(self, rhs: OrderedFloat<f32>) -> OrderedFloat<f32>
Source§impl Pow<OrderedFloat<f32>> for OrderedFloat<f64>
impl Pow<OrderedFloat<f32>> for OrderedFloat<f64>
Source§type Output = OrderedFloat<f64>
type Output = OrderedFloat<f64>
Source§fn pow(self, rhs: OrderedFloat<f32>) -> OrderedFloat<f64>
fn pow(self, rhs: OrderedFloat<f32>) -> OrderedFloat<f64>
Source§impl<'a> Pow<OrderedFloat<f64>> for &'a OrderedFloat<f64>
impl<'a> Pow<OrderedFloat<f64>> for &'a OrderedFloat<f64>
Source§type Output = OrderedFloat<f64>
type Output = OrderedFloat<f64>
Source§fn pow(self, rhs: OrderedFloat<f64>) -> OrderedFloat<f64>
fn pow(self, rhs: OrderedFloat<f64>) -> OrderedFloat<f64>
Source§impl Pow<OrderedFloat<f64>> for OrderedFloat<f64>
impl Pow<OrderedFloat<f64>> for OrderedFloat<f64>
Source§type Output = OrderedFloat<f64>
type Output = OrderedFloat<f64>
Source§fn pow(self, rhs: OrderedFloat<f64>) -> OrderedFloat<f64>
fn pow(self, rhs: OrderedFloat<f64>) -> OrderedFloat<f64>
Source§impl<'a, T> Product<&'a OrderedFloat<T>> for OrderedFloat<T>
impl<'a, T> Product<&'a OrderedFloat<T>> for OrderedFloat<T>
Source§fn product<I>(iter: I) -> OrderedFloat<T>where
I: Iterator<Item = &'a OrderedFloat<T>>,
fn product<I>(iter: I) -> OrderedFloat<T>where
I: Iterator<Item = &'a OrderedFloat<T>>,
Self
from the elements by multiplying
the items.Source§impl<T> Product for OrderedFloat<T>
impl<T> Product for OrderedFloat<T>
Source§fn product<I>(iter: I) -> OrderedFloat<T>where
I: Iterator<Item = OrderedFloat<T>>,
fn product<I>(iter: I) -> OrderedFloat<T>where
I: Iterator<Item = OrderedFloat<T>>,
Self
from the elements by multiplying
the items.Source§impl<'a, T> Rem<&'a OrderedFloat<T>> for OrderedFloat<T>
impl<'a, T> Rem<&'a OrderedFloat<T>> for OrderedFloat<T>
Source§type Output = OrderedFloat<<T as Rem<&'a T>>::Output>
type Output = OrderedFloat<<T as Rem<&'a T>>::Output>
%
operator.Source§fn rem(
self,
other: &'a OrderedFloat<T>,
) -> <OrderedFloat<T> as Rem<&'a OrderedFloat<T>>>::Output
fn rem( self, other: &'a OrderedFloat<T>, ) -> <OrderedFloat<T> as Rem<&'a OrderedFloat<T>>>::Output
%
operation. Read moreSource§impl<'a, T> Rem<&'a T> for &'a OrderedFloat<T>
impl<'a, T> Rem<&'a T> for &'a OrderedFloat<T>
Source§impl<'a, T> Rem<&'a T> for OrderedFloat<T>
impl<'a, T> Rem<&'a T> for OrderedFloat<T>
Source§impl<'a, T> Rem<OrderedFloat<T>> for &'a OrderedFloat<T>
impl<'a, T> Rem<OrderedFloat<T>> for &'a OrderedFloat<T>
Source§type Output = OrderedFloat<<&'a T as Rem<T>>::Output>
type Output = OrderedFloat<<&'a T as Rem<T>>::Output>
%
operator.Source§fn rem(
self,
other: OrderedFloat<T>,
) -> <&'a OrderedFloat<T> as Rem<OrderedFloat<T>>>::Output
fn rem( self, other: OrderedFloat<T>, ) -> <&'a OrderedFloat<T> as Rem<OrderedFloat<T>>>::Output
%
operation. Read moreSource§impl<'a, T> Rem<T> for &'a OrderedFloat<T>
impl<'a, T> Rem<T> for &'a OrderedFloat<T>
Source§impl<T> Rem<T> for OrderedFloat<T>where
T: Rem,
impl<T> Rem<T> for OrderedFloat<T>where
T: Rem,
Source§impl<'a, T> Rem for &'a OrderedFloat<T>
impl<'a, T> Rem for &'a OrderedFloat<T>
Source§type Output = OrderedFloat<<T as Rem>::Output>
type Output = OrderedFloat<<T as Rem>::Output>
%
operator.Source§fn rem(self, other: &'a OrderedFloat<T>) -> <&'a OrderedFloat<T> as Rem>::Output
fn rem(self, other: &'a OrderedFloat<T>) -> <&'a OrderedFloat<T> as Rem>::Output
%
operation. Read moreSource§impl<T> Rem for OrderedFloat<T>where
T: Rem,
impl<T> Rem for OrderedFloat<T>where
T: Rem,
Source§type Output = OrderedFloat<<T as Rem>::Output>
type Output = OrderedFloat<<T as Rem>::Output>
%
operator.Source§fn rem(self, other: OrderedFloat<T>) -> <OrderedFloat<T> as Rem>::Output
fn rem(self, other: OrderedFloat<T>) -> <OrderedFloat<T> as Rem>::Output
%
operation. Read moreSource§impl<'a, T> RemAssign<&'a OrderedFloat<T>> for OrderedFloat<T>
impl<'a, T> RemAssign<&'a OrderedFloat<T>> for OrderedFloat<T>
Source§fn rem_assign(&mut self, other: &'a OrderedFloat<T>)
fn rem_assign(&mut self, other: &'a OrderedFloat<T>)
%=
operation. Read moreSource§impl<'a, T> RemAssign<&'a T> for OrderedFloat<T>
impl<'a, T> RemAssign<&'a T> for OrderedFloat<T>
Source§fn rem_assign(&mut self, other: &'a T)
fn rem_assign(&mut self, other: &'a T)
%=
operation. Read moreSource§impl<T> RemAssign<T> for OrderedFloat<T>where
T: RemAssign,
impl<T> RemAssign<T> for OrderedFloat<T>where
T: RemAssign,
Source§fn rem_assign(&mut self, other: T)
fn rem_assign(&mut self, other: T)
%=
operation. Read moreSource§impl<T> RemAssign for OrderedFloat<T>where
T: RemAssign,
impl<T> RemAssign for OrderedFloat<T>where
T: RemAssign,
Source§fn rem_assign(&mut self, other: OrderedFloat<T>)
fn rem_assign(&mut self, other: OrderedFloat<T>)
%=
operation. Read moreSource§impl<T> Signed for OrderedFloat<T>
impl<T> Signed for OrderedFloat<T>
Source§fn abs(&self) -> OrderedFloat<T>
fn abs(&self) -> OrderedFloat<T>
Source§fn abs_sub(&self, other: &OrderedFloat<T>) -> OrderedFloat<T>
fn abs_sub(&self, other: &OrderedFloat<T>) -> OrderedFloat<T>
Source§fn signum(&self) -> OrderedFloat<T>
fn signum(&self) -> OrderedFloat<T>
Source§fn is_positive(&self) -> bool
fn is_positive(&self) -> bool
Source§fn is_negative(&self) -> bool
fn is_negative(&self) -> bool
Source§impl<'a, T> Sub<&'a OrderedFloat<T>> for OrderedFloat<T>
impl<'a, T> Sub<&'a OrderedFloat<T>> for OrderedFloat<T>
Source§type Output = OrderedFloat<<T as Sub<&'a T>>::Output>
type Output = OrderedFloat<<T as Sub<&'a T>>::Output>
-
operator.Source§fn sub(
self,
other: &'a OrderedFloat<T>,
) -> <OrderedFloat<T> as Sub<&'a OrderedFloat<T>>>::Output
fn sub( self, other: &'a OrderedFloat<T>, ) -> <OrderedFloat<T> as Sub<&'a OrderedFloat<T>>>::Output
-
operation. Read moreSource§impl<'a, T> Sub<&'a T> for &'a OrderedFloat<T>
impl<'a, T> Sub<&'a T> for &'a OrderedFloat<T>
Source§impl<'a, T> Sub<&'a T> for OrderedFloat<T>
impl<'a, T> Sub<&'a T> for OrderedFloat<T>
Source§impl<'a, T> Sub<OrderedFloat<T>> for &'a OrderedFloat<T>
impl<'a, T> Sub<OrderedFloat<T>> for &'a OrderedFloat<T>
Source§type Output = OrderedFloat<<&'a T as Sub<T>>::Output>
type Output = OrderedFloat<<&'a T as Sub<T>>::Output>
-
operator.Source§fn sub(
self,
other: OrderedFloat<T>,
) -> <&'a OrderedFloat<T> as Sub<OrderedFloat<T>>>::Output
fn sub( self, other: OrderedFloat<T>, ) -> <&'a OrderedFloat<T> as Sub<OrderedFloat<T>>>::Output
-
operation. Read moreSource§impl<'a, T> Sub<T> for &'a OrderedFloat<T>
impl<'a, T> Sub<T> for &'a OrderedFloat<T>
Source§impl<T> Sub<T> for OrderedFloat<T>where
T: Sub,
impl<T> Sub<T> for OrderedFloat<T>where
T: Sub,
Source§impl<'a, T> Sub for &'a OrderedFloat<T>
impl<'a, T> Sub for &'a OrderedFloat<T>
Source§type Output = OrderedFloat<<T as Sub>::Output>
type Output = OrderedFloat<<T as Sub>::Output>
-
operator.Source§fn sub(self, other: &'a OrderedFloat<T>) -> <&'a OrderedFloat<T> as Sub>::Output
fn sub(self, other: &'a OrderedFloat<T>) -> <&'a OrderedFloat<T> as Sub>::Output
-
operation. Read moreSource§impl<T> Sub for OrderedFloat<T>where
T: Sub,
impl<T> Sub for OrderedFloat<T>where
T: Sub,
Source§type Output = OrderedFloat<<T as Sub>::Output>
type Output = OrderedFloat<<T as Sub>::Output>
-
operator.Source§fn sub(self, other: OrderedFloat<T>) -> <OrderedFloat<T> as Sub>::Output
fn sub(self, other: OrderedFloat<T>) -> <OrderedFloat<T> as Sub>::Output
-
operation. Read moreSource§impl<'a, T> SubAssign<&'a OrderedFloat<T>> for OrderedFloat<T>
impl<'a, T> SubAssign<&'a OrderedFloat<T>> for OrderedFloat<T>
Source§fn sub_assign(&mut self, other: &'a OrderedFloat<T>)
fn sub_assign(&mut self, other: &'a OrderedFloat<T>)
-=
operation. Read moreSource§impl<'a, T> SubAssign<&'a T> for OrderedFloat<T>
impl<'a, T> SubAssign<&'a T> for OrderedFloat<T>
Source§fn sub_assign(&mut self, other: &'a T)
fn sub_assign(&mut self, other: &'a T)
-=
operation. Read moreSource§impl<T> SubAssign<T> for OrderedFloat<T>where
T: SubAssign,
impl<T> SubAssign<T> for OrderedFloat<T>where
T: SubAssign,
Source§fn sub_assign(&mut self, other: T)
fn sub_assign(&mut self, other: T)
-=
operation. Read moreSource§impl<T> SubAssign for OrderedFloat<T>where
T: SubAssign,
impl<T> SubAssign for OrderedFloat<T>where
T: SubAssign,
Source§fn sub_assign(&mut self, other: OrderedFloat<T>)
fn sub_assign(&mut self, other: OrderedFloat<T>)
-=
operation. Read moreSource§impl<'a, T> Sum<&'a OrderedFloat<T>> for OrderedFloat<T>
impl<'a, T> Sum<&'a OrderedFloat<T>> for OrderedFloat<T>
Source§fn sum<I>(iter: I) -> OrderedFloat<T>where
I: Iterator<Item = &'a OrderedFloat<T>>,
fn sum<I>(iter: I) -> OrderedFloat<T>where
I: Iterator<Item = &'a OrderedFloat<T>>,
Self
from the elements by “summing up”
the items.Source§impl<T> Sum for OrderedFloat<T>
impl<T> Sum for OrderedFloat<T>
Adds a float directly.
Source§fn sum<I>(iter: I) -> OrderedFloat<T>where
I: Iterator<Item = OrderedFloat<T>>,
fn sum<I>(iter: I) -> OrderedFloat<T>where
I: Iterator<Item = OrderedFloat<T>>,
Self
from the elements by “summing up”
the items.Source§impl<T> ToPrimitive for OrderedFloat<T>where
T: ToPrimitive,
impl<T> ToPrimitive for OrderedFloat<T>where
T: ToPrimitive,
Source§fn to_i64(&self) -> Option<i64>
fn to_i64(&self) -> Option<i64>
self
to an i64
. If the value cannot be
represented by an i64
, then None
is returned.Source§fn to_u64(&self) -> Option<u64>
fn to_u64(&self) -> Option<u64>
self
to a u64
. If the value cannot be
represented by a u64
, then None
is returned.Source§fn to_isize(&self) -> Option<isize>
fn to_isize(&self) -> Option<isize>
self
to an isize
. If the value cannot be
represented by an isize
, then None
is returned.Source§fn to_i8(&self) -> Option<i8>
fn to_i8(&self) -> Option<i8>
self
to an i8
. If the value cannot be
represented by an i8
, then None
is returned.Source§fn to_i16(&self) -> Option<i16>
fn to_i16(&self) -> Option<i16>
self
to an i16
. If the value cannot be
represented by an i16
, then None
is returned.Source§fn to_i32(&self) -> Option<i32>
fn to_i32(&self) -> Option<i32>
self
to an i32
. If the value cannot be
represented by an i32
, then None
is returned.Source§fn to_usize(&self) -> Option<usize>
fn to_usize(&self) -> Option<usize>
self
to a usize
. If the value cannot be
represented by a usize
, then None
is returned.Source§fn to_u8(&self) -> Option<u8>
fn to_u8(&self) -> Option<u8>
self
to a u8
. If the value cannot be
represented by a u8
, then None
is returned.Source§fn to_u16(&self) -> Option<u16>
fn to_u16(&self) -> Option<u16>
self
to a u16
. If the value cannot be
represented by a u16
, then None
is returned.Source§fn to_u32(&self) -> Option<u32>
fn to_u32(&self) -> Option<u32>
self
to a u32
. If the value cannot be
represented by a u32
, then None
is returned.Source§fn to_f32(&self) -> Option<f32>
fn to_f32(&self) -> Option<f32>
self
to an f32
. Overflows may map to positive
or negative inifinity, otherwise None
is returned if the value cannot
be represented by an f32
.Source§fn to_f64(&self) -> Option<f64>
fn to_f64(&self) -> Option<f64>
self
to an f64
. Overflows may map to positive
or negative inifinity, otherwise None
is returned if the value cannot
be represented by an f64
. Read moreSource§impl<T> UpperExp for OrderedFloat<T>
impl<T> UpperExp for OrderedFloat<T>
Source§impl<T> Zero for OrderedFloat<T>where
T: Zero,
impl<T> Zero for OrderedFloat<T>where
T: Zero,
impl<T> Copy for OrderedFloat<T>where
T: Copy,
impl<T> Eq for OrderedFloat<T>where
T: FloatCore,
Auto Trait Implementations§
impl<T> Freeze for OrderedFloat<T>where
T: Freeze,
impl<T> RefUnwindSafe for OrderedFloat<T>where
T: RefUnwindSafe,
impl<T> Send for OrderedFloat<T>where
T: Send,
impl<T> Sync for OrderedFloat<T>where
T: Sync,
impl<T> Unpin for OrderedFloat<T>where
T: Unpin,
impl<T> UnwindSafe for OrderedFloat<T>where
T: UnwindSafe,
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> ComplexFloat for Twhere
T: Float + FloatConst,
impl<T> ComplexFloat for Twhere
T: Float + FloatConst,
Source§fn re(self) -> <T as ComplexFloat>::Real
fn re(self) -> <T as ComplexFloat>::Real
Source§fn im(self) -> <T as ComplexFloat>::Real
fn im(self) -> <T as ComplexFloat>::Real
Source§fn l1_norm(&self) -> <T as ComplexFloat>::Real
fn l1_norm(&self) -> <T as ComplexFloat>::Real
|re| + |im|
– the Manhattan distance from the origin.Source§fn arg(self) -> <T as ComplexFloat>::Real
fn arg(self) -> <T as ComplexFloat>::Real
Source§fn powc(
self,
exp: Complex<<T as ComplexFloat>::Real>,
) -> Complex<<T as ComplexFloat>::Real>
fn powc( self, exp: Complex<<T as ComplexFloat>::Real>, ) -> Complex<<T as ComplexFloat>::Real>
self
to a complex power.Source§fn expf(self, base: <T as ComplexFloat>::Real) -> T
fn expf(self, base: <T as ComplexFloat>::Real) -> T
base^(self)
.Source§fn is_infinite(self) -> bool
fn is_infinite(self) -> bool
true
if this value is positive infinity or negative infinity and
false otherwise.Source§fn recip(self) -> T
fn recip(self) -> T
1/x
. See also Complex::finv.Source§fn log(self, base: T) -> T
fn log(self, base: T) -> T
Source§fn asin(self) -> T
fn asin(self) -> T
Source§fn acos(self) -> T
fn acos(self) -> T
Source§fn atan(self) -> T
fn atan(self) -> T
Source§fn abs(self) -> T
fn abs(self) -> T
Source§impl<T> FmtForward for T
impl<T> FmtForward for T
Source§fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
self
to use its Binary
implementation when Debug
-formatted.Source§fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
self
to use its Display
implementation when
Debug
-formatted.Source§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
self
to use its LowerExp
implementation when
Debug
-formatted.Source§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
self
to use its LowerHex
implementation when
Debug
-formatted.Source§fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
self
to use its Octal
implementation when Debug
-formatted.Source§fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
self
to use its Pointer
implementation when
Debug
-formatted.Source§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
self
to use its UpperExp
implementation when
Debug
-formatted.Source§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
self
to use its UpperHex
implementation when
Debug
-formatted.Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§impl<T> LowerBounded for Twhere
T: Bounded,
impl<T> LowerBounded for Twhere
T: Bounded,
Source§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
Source§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
Source§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
self
and passes that borrow into the pipe function. Read moreSource§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
self
and passes that borrow into the pipe function. Read moreSource§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
Source§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R,
) -> R
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
Source§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
self
, then passes self.as_ref()
into the pipe function.Source§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
self
, then passes self.as_mut()
into the pipe
function.Source§fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
self
, then passes self.deref()
into the pipe function.Source§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<R, P> ReadPrimitive<R> for P
impl<R, P> ReadPrimitive<R> for P
Source§fn read_from_little_endian(read: &mut R) -> Result<Self, Error>
fn read_from_little_endian(read: &mut R) -> Result<Self, Error>
ReadEndian::read_from_little_endian()
.Source§impl<T> Real for Twhere
T: Float,
impl<T> Real for Twhere
T: Float,
Source§fn min_positive_value() -> T
fn min_positive_value() -> T
Source§fn round(self) -> T
fn round(self) -> T
0.0
. Read moreSource§fn is_sign_positive(self) -> bool
fn is_sign_positive(self) -> bool
true
if self
is positive, including +0.0
,
Float::infinity()
, and with newer versions of Rust f64::NAN
. Read moreSource§fn is_sign_negative(self) -> bool
fn is_sign_negative(self) -> bool
true
if self
is negative, including -0.0
,
Float::neg_infinity()
, and with newer versions of Rust -f64::NAN
. Read moreSource§fn mul_add(self, a: T, b: T) -> T
fn mul_add(self, a: T, b: T) -> T
(self * a) + b
with only one rounding
error, yielding a more accurate result than an unfused multiply-add. Read moreSource§fn log(self, base: T) -> T
fn log(self, base: T) -> T
Source§fn to_degrees(self) -> T
fn to_degrees(self) -> T
Source§fn to_radians(self) -> T
fn to_radians(self) -> T
Source§fn hypot(self, other: T) -> T
fn hypot(self, other: T) -> T
x
and y
. Read moreSource§fn asin(self) -> T
fn asin(self) -> T
Source§fn acos(self) -> T
fn acos(self) -> T
Source§fn atan(self) -> T
fn atan(self) -> T
Source§fn exp_m1(self) -> T
fn exp_m1(self) -> T
e^(self) - 1
in a way that is accurate even if the
number is close to zero. Read moreSource§impl<T> Tap for T
impl<T> Tap for T
Source§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Borrow<B>
of a value. Read moreSource§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
BorrowMut<B>
of a value. Read moreSource§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
AsRef<R>
view of a value. Read moreSource§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
AsMut<R>
view of a value. Read moreSource§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Deref::Target
of a value. Read moreSource§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Deref::Target
of a value. Read moreSource§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
.tap()
only in debug builds, and is erased in release builds.Source§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
.tap_mut()
only in debug builds, and is erased in release
builds.Source§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
.tap_borrow()
only in debug builds, and is erased in release
builds.Source§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
.tap_borrow_mut()
only in debug builds, and is erased in release
builds.Source§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
.tap_ref()
only in debug builds, and is erased in release
builds.Source§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
.tap_ref_mut()
only in debug builds, and is erased in release
builds.Source§fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
.tap_deref()
only in debug builds, and is erased in release
builds.Source§impl<T> ToCompactString for Twhere
T: Display,
impl<T> ToCompactString for Twhere
T: Display,
Source§fn to_compact_string(&self) -> CompactString
fn to_compact_string(&self) -> CompactString
CompactString
. Read more