Trait rug::ops::SubAssignRound
source · pub trait SubAssignRound<Rhs = Self> {
type Round;
type Ordering;
fn sub_assign_round(&mut self, rhs: Rhs, round: Self::Round) -> Self::Ordering;
}
Expand description
Compound subtraction and assignment with a specified rounding method.
Examples
use core::cmp::Ordering;
use rug::float::Round;
use rug::ops::SubAssignRound;
use rug::Float;
struct F(f64);
impl SubAssignRound<f64> for F {
type Round = Round;
type Ordering = Ordering;
fn sub_assign_round(&mut self, rhs: f64, round: Round) -> Ordering {
let mut f = Float::with_val(53, self.0);
let dir = f.sub_assign_round(rhs, round);
self.0 = f.to_f64();
dir
}
}
let mut f = F(3.0);
let dir = f.sub_assign_round(5.0, Round::Nearest);
// 3.0 - 5.0 = -2.0
assert_eq!(f.0, -2.0);
assert_eq!(dir, Ordering::Equal);
Required Associated Types
Required Methods
sourcefn sub_assign_round(&mut self, rhs: Rhs, round: Self::Round) -> Self::Ordering
fn sub_assign_round(&mut self, rhs: Rhs, round: Self::Round) -> Self::Ordering
Performs the subtraction.
Examples
use core::cmp::Ordering;
use rug::float::Round;
use rug::ops::SubAssignRound;
use rug::Float;
// only four significant bits
let mut f = Float::with_val(4, -3);
let dir = f.sub_assign_round(0.3, Round::Nearest);
// -3.3 rounded up to -3.25
assert_eq!(f, -3.25);
assert_eq!(dir, Ordering::Greater);