Trait muldiv::MulDiv[][src]

pub trait MulDiv<RHS = Self> {
    type Output;
    fn mul_div_floor(self, num: RHS, denom: RHS) -> Option<Self::Output>;
fn mul_div_round(self, num: RHS, denom: RHS) -> Option<Self::Output>;
fn mul_div_ceil(self, num: RHS, denom: RHS) -> Option<Self::Output>; }

Trait for calculating val * num / denom with different rounding modes and overflow protection.

Implementations of this trait have to ensure that even if the result of the multiplication does not fit into the type, as long as it would fit after the division the correct result has to be returned instead of None. None only should be returned if the overall result does not fit into the type.

This specifically means that e.g. the u64 implementation must, depending on the arguments, be able to do 128 bit integer multiplication.

Associated Types

Required Methods

Calculates floor(val * num / denom), i.e. the next integer to the result of the division with the smaller absolute value.

Example

extern crate muldiv;
use muldiv::MulDiv;

// Returns x==Some(6)
let x = 3i8.mul_div_floor(4, 2);

// Returns x==Some(3)
let x = 5i8.mul_div_floor(2, 3);

// Returns x==Some(-3)
let x = (-5i8).mul_div_floor(2, 3);

// Returns x==Some(4)
let x = 3i8.mul_div_floor(3, 2);

// Returns x==Some(-4)
let x = (-3i8).mul_div_floor(3, 2);

// Returns x==None
let x = 127i8.mul_div_floor(4, 3);

Calculates round(val * num / denom), i.e. the closest integer to the result of the division. If both surrounding integers are the same distance, the one with the bigger absolute value is returned.

Example

extern crate muldiv;
use muldiv::MulDiv;

// Returns x==Some(6)
let x = 3i8.mul_div_round(4, 2);

// Returns x==Some(3)
let x = 5i8.mul_div_round(2, 3);

// Returns x==Some(-3)
let x = (-5i8).mul_div_round(2, 3);

// Returns x==Some(5)
let x = 3i8.mul_div_round(3, 2);

// Returns x==Some(-5)
let x = (-3i8).mul_div_round(3, 2);

// Returns x==None
let x = 127i8.mul_div_floor(4, 3);

Calculates ceil(val * num / denom), i.e. the next integer to the result of the division with the bigger absolute value.

Example

extern crate muldiv;
use muldiv::MulDiv;

// Returns x==Some(6)
let x = 3i8.mul_div_ceil(4, 2);

// Returns x==Some(4)
let x = 5i8.mul_div_ceil(2, 3);

// Returns x==Some(-4)
let x = (-5i8).mul_div_ceil(2, 3);

// Returns x==Some(5)
let x = 3i8.mul_div_ceil(3, 2);

// Returns x==Some(-5)
let x = (-3i8).mul_div_ceil(3, 2);

// Returns x==None
let x = (127i8).mul_div_ceil(4, 3);

Implementations on Foreign Types

impl MulDiv for u64
[src]

impl MulDiv for u32
[src]

impl MulDiv for u16
[src]

impl MulDiv for u8
[src]

impl MulDiv for i64
[src]

impl MulDiv for i32
[src]

impl MulDiv for i16
[src]

impl MulDiv for i8
[src]

Implementors