Trait rug::ops::DivAssignRound

source ·
pub trait DivAssignRound<Rhs = Self> {
    type Round;
    type Ordering;

    // Required method
    fn div_assign_round(
        &mut self,
        rhs: Rhs,
        round: Self::Round
    ) -> Self::Ordering;
}
Expand description

Compound division and assignment with a specified rounding method.

§Examples

use core::cmp::Ordering;
use rug::float::Round;
use rug::ops::DivAssignRound;
use rug::Float;
struct F(f64);
impl DivAssignRound<f64> for F {
    type Round = Round;
    type Ordering = Ordering;
    fn div_assign_round(&mut self, rhs: f64, round: Round) -> Ordering {
        let mut f = Float::with_val(53, self.0);
        let dir = f.div_assign_round(rhs, round);
        self.0 = f.to_f64();
        dir
    }
}
let mut f = F(3.0);
let dir = f.div_assign_round(4.0, Round::Nearest);
// 3.0 / 4.0 = 0.75
assert_eq!(f.0, 0.75);
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 div_assign_round(&mut self, rhs: Rhs, round: Self::Round) -> Self::Ordering

Performs the division.

§Examples
use core::cmp::Ordering;
use rug::float::Round;
use rug::ops::DivAssignRound;
use rug::Float;
// only four significant bits
let mut f = Float::with_val(4, -3);
let dir = f.div_assign_round(5, Round::Nearest);
// -0.6 rounded down to -0.625
assert_eq!(f, -0.625);
assert_eq!(dir, Ordering::Less);

Implementors§

source§

impl DivAssignRound for Complex

source§

impl DivAssignRound for Float

source§

impl DivAssignRound<&f32> for Complex

source§

impl DivAssignRound<&f32> for Float

source§

impl DivAssignRound<&f64> for Complex

source§

impl DivAssignRound<&f64> for Float

source§

impl DivAssignRound<&i8> for Complex

source§

impl DivAssignRound<&i8> for Float

source§

impl DivAssignRound<&i16> for Complex

source§

impl DivAssignRound<&i16> for Float

source§

impl DivAssignRound<&i32> for Complex

source§

impl DivAssignRound<&i32> for Float

source§

impl DivAssignRound<&i64> for Complex

source§

impl DivAssignRound<&i64> for Float

source§

impl DivAssignRound<&i128> for Complex

source§

impl DivAssignRound<&i128> for Float

source§

impl DivAssignRound<&isize> for Complex

source§

impl DivAssignRound<&isize> for Float

source§

impl DivAssignRound<&u8> for Complex

source§

impl DivAssignRound<&u8> for Float

source§

impl DivAssignRound<&u16> for Complex

source§

impl DivAssignRound<&u16> for Float

source§

impl DivAssignRound<&u32> for Complex

source§

impl DivAssignRound<&u32> for Float

source§

impl DivAssignRound<&u64> for Complex

source§

impl DivAssignRound<&u64> for Float

source§

impl DivAssignRound<&u128> for Complex

source§

impl DivAssignRound<&u128> for Float

source§

impl DivAssignRound<&usize> for Complex

source§

impl DivAssignRound<&usize> for Float

source§

impl DivAssignRound<&Complex> for Complex

source§

impl DivAssignRound<&Float> for Complex

source§

impl DivAssignRound<&Float> for Float

source§

impl DivAssignRound<&Integer> for Complex

source§

impl DivAssignRound<&Integer> for Float

source§

impl DivAssignRound<&Rational> for Complex

source§

impl DivAssignRound<&Rational> for Float

source§

impl DivAssignRound<f32> for Complex

source§

impl DivAssignRound<f32> for Float

source§

impl DivAssignRound<f64> for Complex

source§

impl DivAssignRound<f64> for Float

source§

impl DivAssignRound<i8> for Complex

source§

impl DivAssignRound<i8> for Float

source§

impl DivAssignRound<i16> for Complex

source§

impl DivAssignRound<i16> for Float

source§

impl DivAssignRound<i32> for Complex

source§

impl DivAssignRound<i32> for Float

source§

impl DivAssignRound<i64> for Complex

source§

impl DivAssignRound<i64> for Float

source§

impl DivAssignRound<i128> for Complex

source§

impl DivAssignRound<i128> for Float

source§

impl DivAssignRound<isize> for Complex

source§

impl DivAssignRound<isize> for Float

source§

impl DivAssignRound<u8> for Complex

source§

impl DivAssignRound<u8> for Float

source§

impl DivAssignRound<u16> for Complex

source§

impl DivAssignRound<u16> for Float

source§

impl DivAssignRound<u32> for Complex

source§

impl DivAssignRound<u32> for Float

source§

impl DivAssignRound<u64> for Complex

source§

impl DivAssignRound<u64> for Float

source§

impl DivAssignRound<u128> for Complex

source§

impl DivAssignRound<u128> for Float

source§

impl DivAssignRound<usize> for Complex

source§

impl DivAssignRound<usize> for Float

source§

impl DivAssignRound<Float> for Complex

source§

impl DivAssignRound<Integer> for Complex

source§

impl DivAssignRound<Integer> for Float

source§

impl DivAssignRound<Rational> for Complex

source§

impl DivAssignRound<Rational> for Float