Trait rug::ops::RemFromRound

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

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

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

§Examples

use core::cmp::Ordering;
use rug::float::Round;
use rug::ops::{RemAssignRound, RemFromRound};
use rug::Float;
struct F(f64);
impl RemFromRound<f64> for F {
    type Round = Round;
    type Ordering = Ordering;
    fn rem_from_round(&mut self, lhs: f64, round: Round) -> Ordering {
        let mut f = Float::with_val(53, lhs);
        let dir = f.rem_assign_round(self.0, round);
        self.0 = f.to_f64();
        dir
    }
}
let mut f = F(1.25);
let dir = f.rem_from_round(3.25, Round::Nearest);
// 3.25 % 1.25 = 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 rem_from_round(&mut self, lhs: Lhs, round: Self::Round) -> Self::Ordering

Performs the remainder operation.

§Examples
use core::cmp::Ordering;
use rug::float::Round;
use rug::ops::RemFromRound;
use rug::Float;
// only four significant bits
let mut f = Float::with_val(4, 32);
let dir = f.rem_from_round(17, Round::Nearest);
// 17 rounded down to 16
assert_eq!(f, 16);
assert_eq!(dir, Ordering::Less);

Implementors§

source§

impl RemFromRound for Float

source§

impl RemFromRound<&f32> for Float

source§

impl RemFromRound<&f64> for Float

source§

impl RemFromRound<&i8> for Float

source§

impl RemFromRound<&i16> for Float

source§

impl RemFromRound<&i32> for Float

source§

impl RemFromRound<&i64> for Float

source§

impl RemFromRound<&i128> for Float

source§

impl RemFromRound<&isize> for Float

source§

impl RemFromRound<&u8> for Float

source§

impl RemFromRound<&u16> for Float

source§

impl RemFromRound<&u32> for Float

source§

impl RemFromRound<&u64> for Float

source§

impl RemFromRound<&u128> for Float

source§

impl RemFromRound<&usize> for Float

source§

impl RemFromRound<&Float> for Float

source§

impl RemFromRound<f32> for Float

source§

impl RemFromRound<f64> for Float

source§

impl RemFromRound<i8> for Float

source§

impl RemFromRound<i16> for Float

source§

impl RemFromRound<i32> for Float

source§

impl RemFromRound<i64> for Float

source§

impl RemFromRound<i128> for Float

source§

impl RemFromRound<isize> for Float

source§

impl RemFromRound<u8> for Float

source§

impl RemFromRound<u16> for Float

source§

impl RemFromRound<u32> for Float

source§

impl RemFromRound<u64> for Float

source§

impl RemFromRound<u128> for Float

source§

impl RemFromRound<usize> for Float