[][src]Trait rug::ops::SubFromRound

pub trait SubFromRound<Lhs = Self> {
    type Round;
    type Ordering;
    fn sub_from_round(&mut self, lhs: Lhs, round: Self::Round) -> Self::Ordering;
}

Compound subtraction and assignment to the rhs operand with a specified rounding method.

Examples

use core::cmp::Ordering;
use rug::{
    float::Round,
    ops::{SubAssignRound, SubFromRound},
    Float,
};
struct F(f64);
impl SubFromRound<f64> for F {
    type Round = Round;
    type Ordering = Ordering;
    fn sub_from_round(&mut self, lhs: f64, round: Round) -> Ordering {
        let mut f = Float::with_val(53, lhs);
        let dir = f.sub_assign_round(self.0, round);
        self.0 = f.to_f64();
        dir
    }
}
let mut f = F(5.0);
let dir = f.sub_from_round(3.0, Round::Nearest);
// 3.0 - 5.0 = -2.0
assert_eq!(f.0, -2.0);
assert_eq!(dir, Ordering::Equal);

Associated Types

type Round

The rounding method.

type Ordering

The direction from rounding.

Loading content...

Required methods

fn sub_from_round(&mut self, lhs: Lhs, round: Self::Round) -> Self::Ordering

Performs the subtraction.

Examples

use core::cmp::Ordering;
use rug::{float::Round, ops::SubFromRound, Float};
// only four significant bits
let mut f = Float::with_val(4, 0.3);
let dir = f.sub_from_round(-3, Round::Nearest);
// −3.3 rounded up to −3.25
assert_eq!(f, -3.25);
assert_eq!(dir, Ordering::Greater);
Loading content...

Implementors

impl SubFromRound<f32> for Float[src]

type Round = Round

type Ordering = Ordering

impl SubFromRound<f32> for Complex[src]

type Round = (Round, Round)

type Ordering = (Ordering, Ordering)

impl SubFromRound<f64> for Float[src]

type Round = Round

type Ordering = Ordering

impl SubFromRound<f64> for Complex[src]

type Round = (Round, Round)

type Ordering = (Ordering, Ordering)

impl SubFromRound<i128> for Float[src]

type Round = Round

type Ordering = Ordering

impl SubFromRound<i128> for Complex[src]

type Round = (Round, Round)

type Ordering = (Ordering, Ordering)

impl SubFromRound<i16> for Float[src]

type Round = Round

type Ordering = Ordering

impl SubFromRound<i16> for Complex[src]

type Round = (Round, Round)

type Ordering = (Ordering, Ordering)

impl SubFromRound<i32> for Float[src]

type Round = Round

type Ordering = Ordering

impl SubFromRound<i32> for Complex[src]

type Round = (Round, Round)

type Ordering = (Ordering, Ordering)

impl SubFromRound<i64> for Float[src]

type Round = Round

type Ordering = Ordering

impl SubFromRound<i64> for Complex[src]

type Round = (Round, Round)

type Ordering = (Ordering, Ordering)

impl SubFromRound<i8> for Float[src]

type Round = Round

type Ordering = Ordering

impl SubFromRound<i8> for Complex[src]

type Round = (Round, Round)

type Ordering = (Ordering, Ordering)

impl SubFromRound<u128> for Float[src]

type Round = Round

type Ordering = Ordering

impl SubFromRound<u128> for Complex[src]

type Round = (Round, Round)

type Ordering = (Ordering, Ordering)

impl SubFromRound<u16> for Float[src]

type Round = Round

type Ordering = Ordering

impl SubFromRound<u16> for Complex[src]

type Round = (Round, Round)

type Ordering = (Ordering, Ordering)

impl SubFromRound<u32> for Float[src]

type Round = Round

type Ordering = Ordering

impl SubFromRound<u32> for Complex[src]

type Round = (Round, Round)

type Ordering = (Ordering, Ordering)

impl SubFromRound<u64> for Float[src]

type Round = Round

type Ordering = Ordering

impl SubFromRound<u64> for Complex[src]

type Round = (Round, Round)

type Ordering = (Ordering, Ordering)

impl SubFromRound<u8> for Float[src]

type Round = Round

type Ordering = Ordering

impl SubFromRound<u8> for Complex[src]

type Round = (Round, Round)

type Ordering = (Ordering, Ordering)

impl SubFromRound<Complex> for Complex[src]

type Round = (Round, Round)

type Ordering = (Ordering, Ordering)

impl SubFromRound<Float> for Complex[src]

type Round = (Round, Round)

type Ordering = (Ordering, Ordering)

impl SubFromRound<Float> for Float[src]

type Round = Round

type Ordering = Ordering

impl SubFromRound<Integer> for Complex[src]

type Round = (Round, Round)

type Ordering = (Ordering, Ordering)

impl SubFromRound<Integer> for Float[src]

type Round = Round

type Ordering = Ordering

impl SubFromRound<Rational> for Complex[src]

type Round = (Round, Round)

type Ordering = (Ordering, Ordering)

impl SubFromRound<Rational> for Float[src]

type Round = Round

type Ordering = Ordering

impl<'_> SubFromRound<&'_ f32> for Float[src]

type Round = Round

type Ordering = Ordering

impl<'_> SubFromRound<&'_ f32> for Complex[src]

type Round = (Round, Round)

type Ordering = (Ordering, Ordering)

impl<'_> SubFromRound<&'_ f64> for Float[src]

type Round = Round

type Ordering = Ordering

impl<'_> SubFromRound<&'_ f64> for Complex[src]

type Round = (Round, Round)

type Ordering = (Ordering, Ordering)

impl<'_> SubFromRound<&'_ i128> for Float[src]

type Round = Round

type Ordering = Ordering

impl<'_> SubFromRound<&'_ i128> for Complex[src]

type Round = (Round, Round)

type Ordering = (Ordering, Ordering)

impl<'_> SubFromRound<&'_ i16> for Float[src]

type Round = Round

type Ordering = Ordering

impl<'_> SubFromRound<&'_ i16> for Complex[src]

type Round = (Round, Round)

type Ordering = (Ordering, Ordering)

impl<'_> SubFromRound<&'_ i32> for Float[src]

type Round = Round

type Ordering = Ordering

impl<'_> SubFromRound<&'_ i32> for Complex[src]

type Round = (Round, Round)

type Ordering = (Ordering, Ordering)

impl<'_> SubFromRound<&'_ i64> for Float[src]

type Round = Round

type Ordering = Ordering

impl<'_> SubFromRound<&'_ i64> for Complex[src]

type Round = (Round, Round)

type Ordering = (Ordering, Ordering)

impl<'_> SubFromRound<&'_ i8> for Float[src]

type Round = Round

type Ordering = Ordering

impl<'_> SubFromRound<&'_ i8> for Complex[src]

type Round = (Round, Round)

type Ordering = (Ordering, Ordering)

impl<'_> SubFromRound<&'_ u128> for Float[src]

type Round = Round

type Ordering = Ordering

impl<'_> SubFromRound<&'_ u128> for Complex[src]

type Round = (Round, Round)

type Ordering = (Ordering, Ordering)

impl<'_> SubFromRound<&'_ u16> for Float[src]

type Round = Round

type Ordering = Ordering

impl<'_> SubFromRound<&'_ u16> for Complex[src]

type Round = (Round, Round)

type Ordering = (Ordering, Ordering)

impl<'_> SubFromRound<&'_ u32> for Float[src]

type Round = Round

type Ordering = Ordering

impl<'_> SubFromRound<&'_ u32> for Complex[src]

type Round = (Round, Round)

type Ordering = (Ordering, Ordering)

impl<'_> SubFromRound<&'_ u64> for Float[src]

type Round = Round

type Ordering = Ordering

impl<'_> SubFromRound<&'_ u64> for Complex[src]

type Round = (Round, Round)

type Ordering = (Ordering, Ordering)

impl<'_> SubFromRound<&'_ u8> for Float[src]

type Round = Round

type Ordering = Ordering

impl<'_> SubFromRound<&'_ u8> for Complex[src]

type Round = (Round, Round)

type Ordering = (Ordering, Ordering)

impl<'_> SubFromRound<&'_ Complex> for Complex[src]

type Round = (Round, Round)

type Ordering = (Ordering, Ordering)

impl<'_> SubFromRound<&'_ Float> for Complex[src]

type Round = (Round, Round)

type Ordering = (Ordering, Ordering)

impl<'_> SubFromRound<&'_ Float> for Float[src]

type Round = Round

type Ordering = Ordering

impl<'_> SubFromRound<&'_ Integer> for Complex[src]

type Round = (Round, Round)

type Ordering = (Ordering, Ordering)

impl<'_> SubFromRound<&'_ Integer> for Float[src]

type Round = Round

type Ordering = Ordering

impl<'_> SubFromRound<&'_ Rational> for Complex[src]

type Round = (Round, Round)

type Ordering = (Ordering, Ordering)

impl<'_> SubFromRound<&'_ Rational> for Float[src]

type Round = Round

type Ordering = Ordering

Loading content...