Struct cranelift_codegen::ir::immediates::Ieee64
source · #[repr(C)]pub struct Ieee64(/* private fields */);
Expand description
An IEEE binary64 immediate floating point value, represented as a u64 containing the bit pattern.
We specifically avoid using a f64 here since some architectures may silently alter floats. See: https://github.com/bytecodealliance/wasmtime/pull/2251#discussion_r498508646
The PartialEq and Hash implementations are over the underlying bit pattern, but PartialOrd respects IEEE754 semantics.
All bit patterns are allowed.
Implementations§
source§impl Ieee64
impl Ieee64
sourcepub fn fcvt_to_sint_negative_overflow<I: Into<i64>>(n: I) -> Self
pub fn fcvt_to_sint_negative_overflow<I: Into<i64>>(n: I) -> Self
Create an Ieee64
number representing the greatest negative value
not convertible from f64 to a signed integer with width n.
sourcepub fn with_float(x: f64) -> Self
pub fn with_float(x: f64) -> Self
Create a new Ieee64
representing the number x
.
sourcepub fn is_nan(&self) -> bool
pub fn is_nan(&self) -> bool
Check if the value is a NaN. For Ieee64, this means checking that the 11 exponent bits are all set.
sourcepub fn copysign(self, sign: Self) -> Self
pub fn copysign(self, sign: Self) -> Self
Returns a number composed of the magnitude of self and the sign of sign.
sourcepub fn is_negative(&self) -> bool
pub fn is_negative(&self) -> bool
Returns true if self has a negative sign, including -0.0, NaNs with negative sign bit and negative infinity.
sourcepub fn trunc(self) -> Self
pub fn trunc(self) -> Self
Returns the integer part of self
. This means that non-integer numbers are always truncated towards zero.
sourcepub fn round_ties_even(self) -> Self
pub fn round_ties_even(self) -> Self
Returns the nearest integer to self
. Rounds half-way cases to the number
with an even least significant digit.
Trait Implementations§
source§impl PartialOrd for Ieee64
impl PartialOrd for Ieee64
impl Copy for Ieee64
impl Eq for Ieee64
impl StructuralPartialEq for Ieee64
Auto Trait Implementations§
impl Freeze for Ieee64
impl RefUnwindSafe for Ieee64
impl Send for Ieee64
impl Sync for Ieee64
impl Unpin for Ieee64
impl UnwindSafe for Ieee64
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§default unsafe fn clone_to_uninit(&self, dst: *mut T)
default unsafe fn clone_to_uninit(&self, dst: *mut T)
clone_to_uninit
)source§impl<T> CloneToUninit for Twhere
T: Copy,
impl<T> CloneToUninit for Twhere
T: Copy,
source§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
clone_to_uninit
)source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.