Trait rug::ops::SubAssignRound [−][src]
Compound subtraction and assignment with a specified rounding method.
Examples
use core::cmp::Ordering; use rug::{float::Round, ops::SubAssignRound, 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);
Associated Types
Loading content...Required methods
fn sub_assign_round(&mut self, rhs: Rhs, round: Self::Round) -> Self::Ordering
[src]
Performs the subtraction.
Examples
use core::cmp::Ordering; use rug::{float::Round, ops::SubAssignRound, 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);