Trait rug::ops::AddFromRound

source ·
pub trait AddFromRound<Lhs = Self> {
    type Round;
    type Ordering;

    // Required method
    fn add_from_round(&mut self, lhs: Lhs, round: Self::Round) -> Self::Ordering;
}
Expand description

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

Examples

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

Required Associated Types§

source

type Round

The rounding method.

source

type Ordering

The direction from rounding.

Required Methods§

source

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

Performs the addition.

Examples
use core::cmp::Ordering;
use rug::float::Round;
use rug::ops::AddFromRound;
use rug::Float;
// only four significant bits
let mut f = Float::with_val(4, -0.3);
let dir = f.add_from_round(-3, Round::Nearest);
// -3.3 rounded up to -3.25
assert_eq!(f, -3.25);
assert_eq!(dir, Ordering::Greater);

Implementors§

source§

impl AddFromRound for Complex

source§

impl AddFromRound for Float

source§

impl AddFromRound<&f32> for Complex

source§

impl AddFromRound<&f32> for Float

source§

impl AddFromRound<&f64> for Complex

source§

impl AddFromRound<&f64> for Float

source§

impl AddFromRound<&i8> for Complex

source§

impl AddFromRound<&i8> for Float

source§

impl AddFromRound<&i16> for Complex

source§

impl AddFromRound<&i16> for Float

source§

impl AddFromRound<&i32> for Complex

source§

impl AddFromRound<&i32> for Float

source§

impl AddFromRound<&i64> for Complex

source§

impl AddFromRound<&i64> for Float

source§

impl AddFromRound<&i128> for Complex

source§

impl AddFromRound<&i128> for Float

source§

impl AddFromRound<&isize> for Complex

source§

impl AddFromRound<&isize> for Float

source§

impl AddFromRound<&u8> for Complex

source§

impl AddFromRound<&u8> for Float

source§

impl AddFromRound<&u16> for Complex

source§

impl AddFromRound<&u16> for Float

source§

impl AddFromRound<&u32> for Complex

source§

impl AddFromRound<&u32> for Float

source§

impl AddFromRound<&u64> for Complex

source§

impl AddFromRound<&u64> for Float

source§

impl AddFromRound<&u128> for Complex

source§

impl AddFromRound<&u128> for Float

source§

impl AddFromRound<&usize> for Complex

source§

impl AddFromRound<&usize> for Float

source§

impl AddFromRound<&Complex> for Complex

source§

impl AddFromRound<&Float> for Complex

source§

impl AddFromRound<&Float> for Float

source§

impl AddFromRound<&Integer> for Complex

source§

impl AddFromRound<&Integer> for Float

source§

impl AddFromRound<&Rational> for Complex

source§

impl AddFromRound<&Rational> for Float

source§

impl AddFromRound<f32> for Complex

source§

impl AddFromRound<f32> for Float

source§

impl AddFromRound<f64> for Complex

source§

impl AddFromRound<f64> for Float

source§

impl AddFromRound<i8> for Complex

source§

impl AddFromRound<i8> for Float

source§

impl AddFromRound<i16> for Complex

source§

impl AddFromRound<i16> for Float

source§

impl AddFromRound<i32> for Complex

source§

impl AddFromRound<i32> for Float

source§

impl AddFromRound<i64> for Complex

source§

impl AddFromRound<i64> for Float

source§

impl AddFromRound<i128> for Complex

source§

impl AddFromRound<i128> for Float

source§

impl AddFromRound<isize> for Complex

source§

impl AddFromRound<isize> for Float

source§

impl AddFromRound<u8> for Complex

source§

impl AddFromRound<u8> for Float

source§

impl AddFromRound<u16> for Complex

source§

impl AddFromRound<u16> for Float

source§

impl AddFromRound<u32> for Complex

source§

impl AddFromRound<u32> for Float

source§

impl AddFromRound<u64> for Complex

source§

impl AddFromRound<u64> for Float

source§

impl AddFromRound<u128> for Complex

source§

impl AddFromRound<u128> for Float

source§

impl AddFromRound<usize> for Complex

source§

impl AddFromRound<usize> for Float

source§

impl AddFromRound<Float> for Complex

source§

impl AddFromRound<Integer> for Complex

source§

impl AddFromRound<Integer> for Float

source§

impl AddFromRound<Rational> for Complex

source§

impl AddFromRound<Rational> for Float