#[repr(C, align(8))]pub struct WireF64(pub f64);
Expand description
A wire-encoded f64
Tuple Fields§
§0: f64
Methods from Deref<Target = f64>§
pub const RADIX: u32 = 2u32
pub const MANTISSA_DIGITS: u32 = 53u32
pub const DIGITS: u32 = 15u32
pub const EPSILON: f64 = 2.2204460492503131E-16f64
pub const MIN: f64 = -1.7976931348623157E+308f64
pub const MIN_POSITIVE: f64 = 2.2250738585072014E-308f64
pub const MAX: f64 = 1.7976931348623157E+308f64
pub const MIN_EXP: i32 = -1_021i32
pub const MAX_EXP: i32 = 1_024i32
pub const MIN_10_EXP: i32 = -307i32
pub const MAX_10_EXP: i32 = 308i32
pub const NAN: f64 = NaN_f64
pub const INFINITY: f64 = +Inf_f64
pub const NEG_INFINITY: f64 = -Inf_f64
1.62.0 · Sourcepub fn total_cmp(&self, other: &f64) -> Ordering
pub fn total_cmp(&self, other: &f64) -> Ordering
Returns the ordering between self
and other
.
Unlike the standard partial comparison between floating point numbers,
this comparison always produces an ordering in accordance to
the totalOrder
predicate as defined in the IEEE 754 (2008 revision)
floating point standard. The values are ordered in the following sequence:
- negative quiet NaN
- negative signaling NaN
- negative infinity
- negative numbers
- negative subnormal numbers
- negative zero
- positive zero
- positive subnormal numbers
- positive numbers
- positive infinity
- positive signaling NaN
- positive quiet NaN.
The ordering established by this function does not always agree with the
PartialOrd
and PartialEq
implementations of f64
. For example,
they consider negative and positive zero equal, while total_cmp
doesn’t.
The interpretation of the signaling NaN bit follows the definition in the IEEE 754 standard, which may not match the interpretation by some of the older, non-conformant (e.g. MIPS) hardware implementations.
§Example
struct GoodBoy {
name: String,
weight: f64,
}
let mut bois = vec![
GoodBoy { name: "Pucci".to_owned(), weight: 0.1 },
GoodBoy { name: "Woofer".to_owned(), weight: 99.0 },
GoodBoy { name: "Yapper".to_owned(), weight: 10.0 },
GoodBoy { name: "Chonk".to_owned(), weight: f64::INFINITY },
GoodBoy { name: "Abs. Unit".to_owned(), weight: f64::NAN },
GoodBoy { name: "Floaty".to_owned(), weight: -5.0 },
];
bois.sort_by(|a, b| a.weight.total_cmp(&b.weight));
// `f64::NAN` could be positive or negative, which will affect the sort order.
if f64::NAN.is_sign_negative() {
assert!(bois.into_iter().map(|b| b.weight)
.zip([f64::NAN, -5.0, 0.1, 10.0, 99.0, f64::INFINITY].iter())
.all(|(a, b)| a.to_bits() == b.to_bits()))
} else {
assert!(bois.into_iter().map(|b| b.weight)
.zip([-5.0, 0.1, 10.0, 99.0, f64::INFINITY, f64::NAN].iter())
.all(|(a, b)| a.to_bits() == b.to_bits()))
}
Trait Implementations§
Source§impl AddAssign<&WireF64> for WireF64
impl AddAssign<&WireF64> for WireF64
Source§fn add_assign(&mut self, other: &WireF64)
fn add_assign(&mut self, other: &WireF64)
Performs the
+=
operation. Read moreSource§impl AddAssign<&f64> for WireF64
impl AddAssign<&f64> for WireF64
Source§fn add_assign(&mut self, other: &f64)
fn add_assign(&mut self, other: &f64)
Performs the
+=
operation. Read moreSource§impl AddAssign<f64> for WireF64
impl AddAssign<f64> for WireF64
Source§fn add_assign(&mut self, other: f64)
fn add_assign(&mut self, other: f64)
Performs the
+=
operation. Read moreSource§impl AddAssign for WireF64
impl AddAssign for WireF64
Source§fn add_assign(&mut self, other: WireF64)
fn add_assign(&mut self, other: WireF64)
Performs the
+=
operation. Read moreSource§impl DivAssign<&WireF64> for WireF64
impl DivAssign<&WireF64> for WireF64
Source§fn div_assign(&mut self, other: &WireF64)
fn div_assign(&mut self, other: &WireF64)
Performs the
/=
operation. Read moreSource§impl DivAssign<&f64> for WireF64
impl DivAssign<&f64> for WireF64
Source§fn div_assign(&mut self, other: &f64)
fn div_assign(&mut self, other: &f64)
Performs the
/=
operation. Read moreSource§impl DivAssign<f64> for WireF64
impl DivAssign<f64> for WireF64
Source§fn div_assign(&mut self, other: f64)
fn div_assign(&mut self, other: f64)
Performs the
/=
operation. Read moreSource§impl DivAssign for WireF64
impl DivAssign for WireF64
Source§fn div_assign(&mut self, other: WireF64)
fn div_assign(&mut self, other: WireF64)
Performs the
/=
operation. Read moreSource§impl Encodable for WireF64
impl Encodable for WireF64
Source§const COPY_OPTIMIZATION: CopyOptimization<Self>
const COPY_OPTIMIZATION: CopyOptimization<Self>
An optimization flag that allows the bytes of this type to be copied directly during
encoding instead of calling
encode
. Read moreSource§impl EncodableOption for WireF64
impl EncodableOption for WireF64
Source§type EncodedOption = WireBox<WireF64>
type EncodedOption = WireBox<WireF64>
The wire type for the optional value.
Source§impl<E: Encoder + ?Sized> EncodeOption<E> for WireF64
impl<E: Encoder + ?Sized> EncodeOption<E> for WireF64
Source§fn encode_option(
this: Option<&mut Self>,
encoder: &mut E,
slot: Slot<'_, Self::EncodedOption>,
) -> Result<(), EncodeError>
fn encode_option( this: Option<&mut Self>, encoder: &mut E, slot: Slot<'_, Self::EncodedOption>, ) -> Result<(), EncodeError>
Encodes this optional value into an encoder and slot.
Source§impl FromBytes for WireF64where
f64: FromBytes,
impl FromBytes for WireF64where
f64: FromBytes,
Source§impl IntoBytes for WireF64
impl IntoBytes for WireF64
§fn as_mut_bytes(&mut self) -> &mut [u8] ⓘwhere
Self: FromBytes,
fn as_mut_bytes(&mut self) -> &mut [u8] ⓘwhere
Self: FromBytes,
Gets the bytes of this value mutably. Read more
Source§impl MulAssign<&WireF64> for WireF64
impl MulAssign<&WireF64> for WireF64
Source§fn mul_assign(&mut self, other: &WireF64)
fn mul_assign(&mut self, other: &WireF64)
Performs the
*=
operation. Read moreSource§impl MulAssign<&f64> for WireF64
impl MulAssign<&f64> for WireF64
Source§fn mul_assign(&mut self, other: &f64)
fn mul_assign(&mut self, other: &f64)
Performs the
*=
operation. Read moreSource§impl MulAssign<f64> for WireF64
impl MulAssign<f64> for WireF64
Source§fn mul_assign(&mut self, other: f64)
fn mul_assign(&mut self, other: f64)
Performs the
*=
operation. Read moreSource§impl MulAssign for WireF64
impl MulAssign for WireF64
Source§fn mul_assign(&mut self, other: WireF64)
fn mul_assign(&mut self, other: WireF64)
Performs the
*=
operation. Read moreSource§impl PartialOrd<f64> for WireF64
impl PartialOrd<f64> for WireF64
Source§impl PartialOrd for WireF64
impl PartialOrd for WireF64
Source§impl RemAssign<&WireF64> for WireF64
impl RemAssign<&WireF64> for WireF64
Source§fn rem_assign(&mut self, other: &WireF64)
fn rem_assign(&mut self, other: &WireF64)
Performs the
%=
operation. Read moreSource§impl RemAssign<&f64> for WireF64
impl RemAssign<&f64> for WireF64
Source§fn rem_assign(&mut self, other: &f64)
fn rem_assign(&mut self, other: &f64)
Performs the
%=
operation. Read moreSource§impl RemAssign<f64> for WireF64
impl RemAssign<f64> for WireF64
Source§fn rem_assign(&mut self, other: f64)
fn rem_assign(&mut self, other: f64)
Performs the
%=
operation. Read moreSource§impl RemAssign for WireF64
impl RemAssign for WireF64
Source§fn rem_assign(&mut self, other: WireF64)
fn rem_assign(&mut self, other: WireF64)
Performs the
%=
operation. Read moreSource§impl SubAssign<&WireF64> for WireF64
impl SubAssign<&WireF64> for WireF64
Source§fn sub_assign(&mut self, other: &WireF64)
fn sub_assign(&mut self, other: &WireF64)
Performs the
-=
operation. Read moreSource§impl SubAssign<&f64> for WireF64
impl SubAssign<&f64> for WireF64
Source§fn sub_assign(&mut self, other: &f64)
fn sub_assign(&mut self, other: &f64)
Performs the
-=
operation. Read moreSource§impl SubAssign<f64> for WireF64
impl SubAssign<f64> for WireF64
Source§fn sub_assign(&mut self, other: f64)
fn sub_assign(&mut self, other: f64)
Performs the
-=
operation. Read moreSource§impl SubAssign for WireF64
impl SubAssign for WireF64
Source§fn sub_assign(&mut self, other: WireF64)
fn sub_assign(&mut self, other: WireF64)
Performs the
-=
operation. Read moreSource§impl TakeFrom<WireF64> for WireF64
impl TakeFrom<WireF64> for WireF64
Source§const COPY_OPTIMIZATION: CopyOptimization<Self>
const COPY_OPTIMIZATION: CopyOptimization<Self>
An optimization flag that allows the bytes of this type to be copied directly during
conversion instead of calling
take_from
. Read moreSource§impl TakeFrom<WireF64> for f64
impl TakeFrom<WireF64> for f64
Source§const COPY_OPTIMIZATION: CopyOptimization<Self>
const COPY_OPTIMIZATION: CopyOptimization<Self>
An optimization flag that allows the bytes of this type to be copied directly during
conversion instead of calling
take_from
. Read moreSource§impl TryFromBytes for WireF64where
f64: TryFromBytes,
impl TryFromBytes for WireF64where
f64: TryFromBytes,
§fn try_read_from_bytes(
source: &[u8],
) -> Result<Self, ConvertError<Infallible, SizeError<&[u8], Self>, ValidityError<&[u8], Self>>>where
Self: Sized,
fn try_read_from_bytes(
source: &[u8],
) -> Result<Self, ConvertError<Infallible, SizeError<&[u8], Self>, ValidityError<&[u8], Self>>>where
Self: Sized,
§fn try_read_from_prefix(
source: &[u8],
) -> Result<(Self, &[u8]), ConvertError<Infallible, SizeError<&[u8], Self>, ValidityError<&[u8], Self>>>where
Self: Sized,
fn try_read_from_prefix(
source: &[u8],
) -> Result<(Self, &[u8]), ConvertError<Infallible, SizeError<&[u8], Self>, ValidityError<&[u8], Self>>>where
Self: Sized,
§fn try_read_from_suffix(
source: &[u8],
) -> Result<(&[u8], Self), ConvertError<Infallible, SizeError<&[u8], Self>, ValidityError<&[u8], Self>>>where
Self: Sized,
fn try_read_from_suffix(
source: &[u8],
) -> Result<(&[u8], Self), ConvertError<Infallible, SizeError<&[u8], Self>, ValidityError<&[u8], Self>>>where
Self: Sized,
Source§impl ZeroPadding for WireF64
impl ZeroPadding for WireF64
Source§unsafe fn zero_padding(_: *mut Self)
unsafe fn zero_padding(_: *mut Self)
Writes zeroes to the padding for this type, if any. Read more
impl Copy for WireF64
impl Eq for WireF64
Auto Trait Implementations§
impl Freeze for WireF64
impl RefUnwindSafe for WireF64
impl Send for WireF64
impl Sync for WireF64
impl Unpin for WireF64
impl UnwindSafe for WireF64
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
Mutably borrows from an owned value. Read more