Struct dashu_float::Repr
source · [−]pub struct Repr<const BASE: Word> { /* private fields */ }
Expand description
Underlying representation of an arbitrary precision floating number.
The floating point number is represented as significand * base^exponent
, where the
type of the significand is IBig, and the type of exponent is isize. The representation
is always normalized (nonzero signficand is not divisible by the base, or zero signficand
with zero exponent).
When it’s used together with a Context, its precision will be limited so that
|signficand| < base^precision
. However, the precision limit is not always enforced.
In rare cases, the significand can have one more digit than the precision limit.
Infinity
This struct supports representing the infinity, but the infinity is only supposed to be used as sentinels. That is, only equality test and comparison are implemented for the infinity. Any other operations on the infinity will lead to panic. If an operation result is too large or too small, the operation will panic instead of returning an infinity.
Implementations
sourceimpl<const B: Word> Repr<B>
impl<const B: Word> Repr<B>
sourcepub const fn neg_infinity() -> Self
pub const fn neg_infinity() -> Self
Create a Repr instance representing the negative infinity
sourcepub const fn is_infinite(&self) -> bool
pub const fn is_infinite(&self) -> bool
sourcepub const fn sign(&self) -> Sign
pub const fn sign(&self) -> Sign
Get the sign of the number
Examples
assert_eq!(Repr::<2>::zero().sign(), Sign::Positive);
assert_eq!(Repr::<2>::neg_one().sign(), Sign::Negative);
assert_eq!(Repr::<10>::neg_infinity().sign(), Sign::Negative);
sourcepub fn digits(&self) -> usize
pub fn digits(&self) -> usize
Get the number of digits (under base B
) in the significand.
If the number is 0, then 0 is returned (instead of 1).
Examples
assert_eq!(Repr::<2>::zero().digits(), 0);
assert_eq!(Repr::<2>::one().digits(), 1);
assert_eq!(Repr::<10>::one().digits(), 1);
assert_eq!(Repr::<10>::new(100.into(), 0).digits(), 1); // 1e2
assert_eq!(Repr::<10>::new(101.into(), 0).digits(), 3);
sourcepub fn new(significand: IBig, exponent: isize) -> Self
pub fn new(significand: IBig, exponent: isize) -> Self
Create a Repr from the significand and exponent. This constructor will normalize the representation.
Examples
let a = Repr::<2>::new(400.into(), -2);
assert_eq!(a.significand(), &25);
assert_eq!(a.exponent(), 2);
let b = Repr::<10>::new(400.into(), -2);
assert_eq!(b.significand(), &4);
assert_eq!(b.exponent(), 0);
sourcepub fn significand(&self) -> &IBig
pub fn significand(&self) -> &IBig
Get the significand of the representation
sourcepub fn into_parts(self) -> (IBig, isize)
pub fn into_parts(self) -> (IBig, isize)
Convert the float number into raw (signficand, exponent)
parts
Examples
use dashu_int::IBig;
let a = Repr::<2>::new(400.into(), -2);
assert_eq!(a.into_parts(), (IBig::from(25), 2));
let b = Repr::<10>::new(400.into(), -2);
assert_eq!(b.into_parts(), (IBig::from(4), 0));
Trait Implementations
sourceimpl<const B: Word> EstimatedLog2 for Repr<B>
impl<const B: Word> EstimatedLog2 for Repr<B>
sourcefn log2_bounds(&self) -> (f32, f32)
fn log2_bounds(&self) -> (f32, f32)
sourcefn log2_est(&self) -> f32
fn log2_est(&self) -> f32
sourceimpl<const B: Word> Ord for Repr<B>
impl<const B: Word> Ord for Repr<B>
1.21.0 · sourceconst fn max(self, other: Self) -> Self
const fn max(self, other: Self) -> Self
1.21.0 · sourceconst fn min(self, other: Self) -> Self
const fn min(self, other: Self) -> Self
1.50.0 · sourceconst fn clamp(self, min: Self, max: Self) -> Selfwhere
Self: PartialOrd<Self>,
const fn clamp(self, min: Self, max: Self) -> Selfwhere
Self: PartialOrd<Self>,
sourceimpl<const BASE: Word> PartialEq<Repr<BASE>> for Repr<BASE>
impl<const BASE: Word> PartialEq<Repr<BASE>> for Repr<BASE>
sourceimpl<const B: Word> PartialOrd<Repr<B>> for Repr<B>
impl<const B: Word> PartialOrd<Repr<B>> for Repr<B>
sourcefn partial_cmp(&self, other: &Self) -> Option<Ordering>
fn partial_cmp(&self, other: &Self) -> Option<Ordering>
1.0.0 · sourceconst fn le(&self, other: &Rhs) -> bool
const fn le(&self, other: &Rhs) -> bool
self
and other
) and is used by the <=
operator. Read more