1.0.0[][src]Trait af_lib::prelude::af_core::test::prelude::Rem

#[lang = "rem"]pub trait Rem<Rhs = Self> {
    type Output;
#[must_use]    pub fn rem(self, rhs: Rhs) -> Self::Output;
}

The remainder operator %.

Note that Rhs is Self by default, but this is not mandatory.

Examples

This example implements Rem on a SplitSlice object. After Rem is implemented, one can use the % operator to find out what the remaining elements of the slice would be after splitting it into equal slices of a given length.

use std::ops::Rem;

#[derive(PartialEq, Debug)]
struct SplitSlice<'a, T: 'a> {
    slice: &'a [T],
}

impl<'a, T> Rem<usize> for SplitSlice<'a, T> {
    type Output = Self;

    fn rem(self, modulus: usize) -> Self::Output {
        let len = self.slice.len();
        let rem = len % modulus;
        let start = len - rem;
        Self {slice: &self.slice[start..]}
    }
}

// If we were to divide &[0, 1, 2, 3, 4, 5, 6, 7] into slices of size 3,
// the remainder would be &[6, 7].
assert_eq!(SplitSlice { slice: &[0, 1, 2, 3, 4, 5, 6, 7] } % 3,
           SplitSlice { slice: &[6, 7] });

Associated Types

type Output[src]

The resulting type after applying the % operator.

Loading content...

Required methods

#[must_use]pub fn rem(self, rhs: Rhs) -> Self::Output[src]

Performs the % operation.

Example

assert_eq!(12 % 10, 2);
Loading content...

Implementations on Foreign Types

impl<'_> Rem<&'_ Wrapping<i8>> for Wrapping<i8>[src]

type Output = <Wrapping<i8> as Rem<Wrapping<i8>>>::Output

impl Rem<Wrapping<i32>> for Wrapping<i32>[src]

type Output = Wrapping<i32>

impl<'a> Rem<i128> for &'a i128[src]

type Output = <i128 as Rem<i128>>::Output

impl<'_> Rem<&'_ Wrapping<u32>> for Wrapping<u32>[src]

type Output = <Wrapping<u32> as Rem<Wrapping<u32>>>::Output

impl<'a> Rem<Wrapping<i32>> for &'a Wrapping<i32>[src]

type Output = <Wrapping<i32> as Rem<Wrapping<i32>>>::Output

impl<'a> Rem<f32> for &'a f32[src]

type Output = <f32 as Rem<f32>>::Output

impl<'a> Rem<Wrapping<isize>> for &'a Wrapping<isize>[src]

type Output = <Wrapping<isize> as Rem<Wrapping<isize>>>::Output

impl<'_> Rem<&'_ Wrapping<i16>> for Wrapping<i16>[src]

type Output = <Wrapping<i16> as Rem<Wrapping<i16>>>::Output

impl Rem<u8> for u8[src]

This operation satisfies n % d == n - (n / d) * d. The result has the same sign as the left operand.

type Output = u8

impl<'_, '_> Rem<&'_ isize> for &'_ isize[src]

type Output = <isize as Rem<isize>>::Output

impl Rem<Wrapping<u32>> for Wrapping<u32>[src]

type Output = Wrapping<u32>

impl<'_, '_> Rem<&'_ u16> for &'_ u16[src]

type Output = <u16 as Rem<u16>>::Output

impl Rem<Wrapping<i128>> for Wrapping<i128>[src]

type Output = Wrapping<i128>

impl<'a> Rem<Wrapping<i64>> for &'a Wrapping<i64>[src]

type Output = <Wrapping<i64> as Rem<Wrapping<i64>>>::Output

impl<'a> Rem<i8> for &'a i8[src]

type Output = <i8 as Rem<i8>>::Output

impl Rem<u16> for u16[src]

This operation satisfies n % d == n - (n / d) * d. The result has the same sign as the left operand.

type Output = u16

impl<'a> Rem<f64> for &'a f64[src]

type Output = <f64 as Rem<f64>>::Output

impl<'_> Rem<&'_ isize> for isize[src]

type Output = <isize as Rem<isize>>::Output

impl<'_> Rem<&'_ f32> for f32[src]

type Output = <f32 as Rem<f32>>::Output

impl Rem<usize> for usize[src]

This operation satisfies n % d == n - (n / d) * d. The result has the same sign as the left operand.

type Output = usize

impl<'_, '_> Rem<&'_ Wrapping<u64>> for &'_ Wrapping<u64>[src]

type Output = <Wrapping<u64> as Rem<Wrapping<u64>>>::Output

impl<'a> Rem<Wrapping<u8>> for &'a Wrapping<u8>[src]

type Output = <Wrapping<u8> as Rem<Wrapping<u8>>>::Output

impl Rem<u32> for u32[src]

This operation satisfies n % d == n - (n / d) * d. The result has the same sign as the left operand.

type Output = u32

impl<'_, '_> Rem<&'_ i16> for &'_ i16[src]

type Output = <i16 as Rem<i16>>::Output

impl<'_> Rem<&'_ u32> for u32[src]

type Output = <u32 as Rem<u32>>::Output

impl<'_, '_> Rem<&'_ i8> for &'_ i8[src]

type Output = <i8 as Rem<i8>>::Output

impl<'_> Rem<&'_ i16> for i16[src]

type Output = <i16 as Rem<i16>>::Output

impl<'_> Rem<&'_ Wrapping<i32>> for Wrapping<i32>[src]

type Output = <Wrapping<i32> as Rem<Wrapping<i32>>>::Output

impl<'a> Rem<Wrapping<usize>> for &'a Wrapping<usize>[src]

type Output = <Wrapping<usize> as Rem<Wrapping<usize>>>::Output

impl<'a> Rem<Wrapping<u16>> for &'a Wrapping<u16>[src]

type Output = <Wrapping<u16> as Rem<Wrapping<u16>>>::Output

impl<'_, '_> Rem<&'_ f32> for &'_ f32[src]

type Output = <f32 as Rem<f32>>::Output

impl<'_, '_> Rem<&'_ Wrapping<u32>> for &'_ Wrapping<u32>[src]

type Output = <Wrapping<u32> as Rem<Wrapping<u32>>>::Output

impl Rem<NonZeroUsize> for usize[src]

type Output = usize

pub fn rem(self, other: NonZeroUsize) -> usize[src]

This operation satisfies n % d == n - (n / d) * d, and cannot panic.

impl<'_> Rem<&'_ u64> for u64[src]

type Output = <u64 as Rem<u64>>::Output

impl<'_, '_> Rem<&'_ usize> for &'_ usize[src]

type Output = <usize as Rem<usize>>::Output

impl Rem<Wrapping<u128>> for Wrapping<u128>[src]

type Output = Wrapping<u128>

impl Rem<Wrapping<u16>> for Wrapping<u16>[src]

type Output = Wrapping<u16>

impl<'_> Rem<&'_ i8> for i8[src]

type Output = <i8 as Rem<i8>>::Output

impl<'_> Rem<&'_ i32> for i32[src]

type Output = <i32 as Rem<i32>>::Output

impl<'a> Rem<i32> for &'a i32[src]

type Output = <i32 as Rem<i32>>::Output

impl<'_> Rem<&'_ Wrapping<i128>> for Wrapping<i128>[src]

type Output = <Wrapping<i128> as Rem<Wrapping<i128>>>::Output

impl Rem<NonZeroU16> for u16[src]

type Output = u16

pub fn rem(self, other: NonZeroU16) -> u16[src]

This operation satisfies n % d == n - (n / d) * d, and cannot panic.

impl<'_> Rem<&'_ Wrapping<u64>> for Wrapping<u64>[src]

type Output = <Wrapping<u64> as Rem<Wrapping<u64>>>::Output

impl<'_, '_> Rem<&'_ Wrapping<i8>> for &'_ Wrapping<i8>[src]

type Output = <Wrapping<i8> as Rem<Wrapping<i8>>>::Output

impl<'_, '_> Rem<&'_ u32> for &'_ u32[src]

type Output = <u32 as Rem<u32>>::Output

impl<'a> Rem<Wrapping<u64>> for &'a Wrapping<u64>[src]

type Output = <Wrapping<u64> as Rem<Wrapping<u64>>>::Output

impl<'_, '_> Rem<&'_ u128> for &'_ u128[src]

type Output = <u128 as Rem<u128>>::Output

impl<'_> Rem<&'_ Wrapping<u8>> for Wrapping<u8>[src]

type Output = <Wrapping<u8> as Rem<Wrapping<u8>>>::Output

impl<'a> Rem<Wrapping<u32>> for &'a Wrapping<u32>[src]

type Output = <Wrapping<u32> as Rem<Wrapping<u32>>>::Output

impl Rem<Wrapping<i8>> for Wrapping<i8>[src]

type Output = Wrapping<i8>

impl<'_> Rem<&'_ u8> for u8[src]

type Output = <u8 as Rem<u8>>::Output

impl<'_> Rem<&'_ Wrapping<isize>> for Wrapping<isize>[src]

type Output = <Wrapping<isize> as Rem<Wrapping<isize>>>::Output

impl<'_> Rem<&'_ u128> for u128[src]

type Output = <u128 as Rem<u128>>::Output

impl Rem<Wrapping<u8>> for Wrapping<u8>[src]

type Output = Wrapping<u8>

impl<'_> Rem<&'_ i128> for i128[src]

type Output = <i128 as Rem<i128>>::Output

impl Rem<u128> for u128[src]

This operation satisfies n % d == n - (n / d) * d. The result has the same sign as the left operand.

type Output = u128

impl<'a> Rem<u32> for &'a u32[src]

type Output = <u32 as Rem<u32>>::Output

impl<'_> Rem<&'_ Wrapping<u16>> for Wrapping<u16>[src]

type Output = <Wrapping<u16> as Rem<Wrapping<u16>>>::Output

impl<'_, '_> Rem<&'_ Wrapping<u128>> for &'_ Wrapping<u128>[src]

type Output = <Wrapping<u128> as Rem<Wrapping<u128>>>::Output

impl<'_, '_> Rem<&'_ Wrapping<usize>> for &'_ Wrapping<usize>[src]

type Output = <Wrapping<usize> as Rem<Wrapping<usize>>>::Output

impl<'a> Rem<usize> for &'a usize[src]

type Output = <usize as Rem<usize>>::Output

impl<'_> Rem<&'_ f64> for f64[src]

type Output = <f64 as Rem<f64>>::Output

impl<'_> Rem<&'_ i64> for i64[src]

type Output = <i64 as Rem<i64>>::Output

impl Rem<i32> for i32[src]

This operation satisfies n % d == n - (n / d) * d. The result has the same sign as the left operand.

type Output = i32

impl<'_, '_> Rem<&'_ f64> for &'_ f64[src]

type Output = <f64 as Rem<f64>>::Output

impl<'_> Rem<&'_ Wrapping<i64>> for Wrapping<i64>[src]

type Output = <Wrapping<i64> as Rem<Wrapping<i64>>>::Output

impl Rem<NonZeroU64> for u64[src]

type Output = u64

pub fn rem(self, other: NonZeroU64) -> u64[src]

This operation satisfies n % d == n - (n / d) * d, and cannot panic.

impl<'a> Rem<Wrapping<i16>> for &'a Wrapping<i16>[src]

type Output = <Wrapping<i16> as Rem<Wrapping<i16>>>::Output

impl<'_, '_> Rem<&'_ Wrapping<i16>> for &'_ Wrapping<i16>[src]

type Output = <Wrapping<i16> as Rem<Wrapping<i16>>>::Output

impl<'a> Rem<u16> for &'a u16[src]

type Output = <u16 as Rem<u16>>::Output

impl<'_, '_> Rem<&'_ i128> for &'_ i128[src]

type Output = <i128 as Rem<i128>>::Output

impl Rem<Wrapping<i16>> for Wrapping<i16>[src]

type Output = Wrapping<i16>

impl<'_, '_> Rem<&'_ Wrapping<u8>> for &'_ Wrapping<u8>[src]

type Output = <Wrapping<u8> as Rem<Wrapping<u8>>>::Output

impl<'_, '_> Rem<&'_ Wrapping<isize>> for &'_ Wrapping<isize>[src]

type Output = <Wrapping<isize> as Rem<Wrapping<isize>>>::Output

impl Rem<NonZeroU128> for u128[src]

type Output = u128

pub fn rem(self, other: NonZeroU128) -> u128[src]

This operation satisfies n % d == n - (n / d) * d, and cannot panic.

impl<'a> Rem<u8> for &'a u8[src]

type Output = <u8 as Rem<u8>>::Output

impl<'_, '_> Rem<&'_ Wrapping<u16>> for &'_ Wrapping<u16>[src]

type Output = <Wrapping<u16> as Rem<Wrapping<u16>>>::Output

impl Rem<NonZeroU32> for u32[src]

type Output = u32

pub fn rem(self, other: NonZeroU32) -> u32[src]

This operation satisfies n % d == n - (n / d) * d, and cannot panic.

impl Rem<f64> for f64[src]

The remainder from the division of two floats.

The remainder has the same sign as the dividend and is computed as: x - (x / y).trunc() * y.

Examples

let x: f32 = 50.50;
let y: f32 = 8.125;
let remainder = x - (x / y).trunc() * y;

// The answer to both operations is 1.75
assert_eq!(x % y, remainder);

type Output = f64

impl Rem<i64> for i64[src]

This operation satisfies n % d == n - (n / d) * d. The result has the same sign as the left operand.

type Output = i64

impl<'a> Rem<Wrapping<u128>> for &'a Wrapping<u128>[src]

type Output = <Wrapping<u128> as Rem<Wrapping<u128>>>::Output

impl Rem<Wrapping<u64>> for Wrapping<u64>[src]

type Output = Wrapping<u64>

impl<'a> Rem<Wrapping<i128>> for &'a Wrapping<i128>[src]

type Output = <Wrapping<i128> as Rem<Wrapping<i128>>>::Output

impl Rem<NonZeroU8> for u8[src]

type Output = u8

pub fn rem(self, other: NonZeroU8) -> u8[src]

This operation satisfies n % d == n - (n / d) * d, and cannot panic.

impl<'_> Rem<&'_ u16> for u16[src]

type Output = <u16 as Rem<u16>>::Output

impl Rem<f32> for f32[src]

The remainder from the division of two floats.

The remainder has the same sign as the dividend and is computed as: x - (x / y).trunc() * y.

Examples

let x: f32 = 50.50;
let y: f32 = 8.125;
let remainder = x - (x / y).trunc() * y;

// The answer to both operations is 1.75
assert_eq!(x % y, remainder);

type Output = f32

impl Rem<i128> for i128[src]

This operation satisfies n % d == n - (n / d) * d. The result has the same sign as the left operand.

type Output = i128

impl<'a> Rem<Wrapping<i8>> for &'a Wrapping<i8>[src]

type Output = <Wrapping<i8> as Rem<Wrapping<i8>>>::Output

impl Rem<Wrapping<isize>> for Wrapping<isize>[src]

type Output = Wrapping<isize>

impl<'a> Rem<i16> for &'a i16[src]

type Output = <i16 as Rem<i16>>::Output

impl<'_, '_> Rem<&'_ Wrapping<i64>> for &'_ Wrapping<i64>[src]

type Output = <Wrapping<i64> as Rem<Wrapping<i64>>>::Output

impl<'_> Rem<&'_ Wrapping<usize>> for Wrapping<usize>[src]

type Output = <Wrapping<usize> as Rem<Wrapping<usize>>>::Output

impl<'_, '_> Rem<&'_ u64> for &'_ u64[src]

type Output = <u64 as Rem<u64>>::Output

impl<'_> Rem<&'_ Wrapping<u128>> for Wrapping<u128>[src]

type Output = <Wrapping<u128> as Rem<Wrapping<u128>>>::Output

impl<'_, '_> Rem<&'_ i32> for &'_ i32[src]

type Output = <i32 as Rem<i32>>::Output

impl Rem<u64> for u64[src]

This operation satisfies n % d == n - (n / d) * d. The result has the same sign as the left operand.

type Output = u64

impl<'_> Rem<&'_ usize> for usize[src]

type Output = <usize as Rem<usize>>::Output

impl Rem<Wrapping<usize>> for Wrapping<usize>[src]

type Output = Wrapping<usize>

impl<'a> Rem<u128> for &'a u128[src]

type Output = <u128 as Rem<u128>>::Output

impl Rem<i8> for i8[src]

This operation satisfies n % d == n - (n / d) * d. The result has the same sign as the left operand.

type Output = i8

impl<'_, '_> Rem<&'_ i64> for &'_ i64[src]

type Output = <i64 as Rem<i64>>::Output

impl<'_, '_> Rem<&'_ Wrapping<i32>> for &'_ Wrapping<i32>[src]

type Output = <Wrapping<i32> as Rem<Wrapping<i32>>>::Output

impl Rem<Wrapping<i64>> for Wrapping<i64>[src]

type Output = Wrapping<i64>

impl<'a> Rem<i64> for &'a i64[src]

type Output = <i64 as Rem<i64>>::Output

impl<'a> Rem<isize> for &'a isize[src]

type Output = <isize as Rem<isize>>::Output

impl Rem<i16> for i16[src]

This operation satisfies n % d == n - (n / d) * d. The result has the same sign as the left operand.

type Output = i16

impl<'a> Rem<u64> for &'a u64[src]

type Output = <u64 as Rem<u64>>::Output

impl Rem<isize> for isize[src]

This operation satisfies n % d == n - (n / d) * d. The result has the same sign as the left operand.

type Output = isize

impl<'_, '_> Rem<&'_ Wrapping<i128>> for &'_ Wrapping<i128>[src]

type Output = <Wrapping<i128> as Rem<Wrapping<i128>>>::Output

impl<'_, '_> Rem<&'_ u8> for &'_ u8[src]

type Output = <u8 as Rem<u8>>::Output

impl<'a> Rem<i128> for &'a BigInt[src]

type Output = BigInt

impl<'a, 'b> Rem<&'b isize> for &'a BigInt[src]

type Output = BigInt

impl<'a, 'b> Rem<&'b u64> for &'a BigInt[src]

type Output = BigInt

impl<'a> Rem<BigUint> for &'a u32[src]

type Output = BigUint

impl<'a> Rem<u16> for &'a BigUint[src]

type Output = BigUint

impl<'a, 'b> Rem<&'b usize> for &'a BigUint[src]

type Output = BigUint

impl<'a> Rem<&'a u128> for BigInt[src]

type Output = BigInt

impl<'a> Rem<BigInt> for &'a BigInt[src]

type Output = BigInt

impl<'a> Rem<BigInt> for &'a isize[src]

type Output = BigInt

impl<'a> Rem<i16> for &'a BigInt[src]

type Output = BigInt

impl Rem<u128> for BigUint[src]

type Output = BigUint

impl<'a> Rem<usize> for &'a BigInt[src]

type Output = BigInt

impl<'a> Rem<BigInt> for &'a u128[src]

type Output = BigInt

impl<'a, 'b> Rem<&'a BigInt> for &'b i32[src]

type Output = BigInt

impl<'a> Rem<u32> for &'a BigUint[src]

type Output = BigUint

impl<'a> Rem<&'a BigInt> for i64[src]

type Output = BigInt

impl<'a, 'b> Rem<&'a BigUint> for &'b u16[src]

type Output = BigUint

impl<'a, 'b> Rem<&'a BigUint> for &'b u8[src]

type Output = BigUint

impl<'a> Rem<BigInt> for &'a i32[src]

type Output = BigInt

impl<'a> Rem<&'a BigInt> for i8[src]

type Output = BigInt

impl<'a> Rem<u8> for &'a BigInt[src]

type Output = BigInt

impl<'a> Rem<BigUint> for &'a u128[src]

type Output = BigUint

impl<'a> Rem<&'a i64> for BigInt[src]

type Output = BigInt

impl Rem<BigUint> for u8[src]

type Output = BigUint

impl<'a> Rem<&'a BigInt> for u32[src]

type Output = BigInt

impl<'a, 'b> Rem<&'b u8> for &'a BigUint[src]

type Output = BigUint

impl<'a, 'b> Rem<&'a BigInt> for &'b u128[src]

type Output = BigInt

impl<'a, 'b> Rem<&'a BigInt> for &'b u8[src]

type Output = BigInt

impl<'a> Rem<BigInt> for &'a i64[src]

type Output = BigInt

impl Rem<BigUint> for usize[src]

type Output = BigUint

impl<'a> Rem<&'a BigInt> for i16[src]

type Output = BigInt

impl Rem<BigInt> for u128[src]

type Output = BigInt

impl Rem<usize> for BigInt[src]

type Output = BigInt

impl<'a> Rem<&'a i32> for BigInt[src]

type Output = BigInt

impl<'a> Rem<&'a BigUint> for usize[src]

type Output = BigUint

impl<'a> Rem<&'a i8> for BigInt[src]

type Output = BigInt

impl<'a, 'b> Rem<&'a BigInt> for &'b u16[src]

type Output = BigInt

impl<'a> Rem<&'a BigInt> for usize[src]

type Output = BigInt

impl Rem<u8> for BigInt[src]

type Output = BigInt

impl<'a> Rem<&'a BigUint> for u32[src]

type Output = BigUint

impl Rem<BigUint> for u128[src]

type Output = BigUint

impl<'a> Rem<u16> for &'a BigInt[src]

type Output = BigInt

impl Rem<u64> for BigUint[src]

type Output = BigUint

impl Rem<i64> for BigInt[src]

type Output = BigInt

impl Rem<BigUint> for u16[src]

type Output = BigUint

impl<'a, 'b> Rem<&'b BigInt> for &'a BigInt[src]

type Output = BigInt

impl<'a, 'b> Rem<&'b u64> for &'a BigUint[src]

type Output = BigUint

impl Rem<BigInt> for i32[src]

type Output = BigInt

impl Rem<u8> for BigUint[src]

type Output = BigUint

impl Rem<u64> for BigInt[src]

type Output = BigInt

impl Rem<i32> for BigInt[src]

type Output = BigInt

impl Rem<BigUint> for BigUint[src]

type Output = BigUint

impl<'a, 'b> Rem<&'a BigInt> for &'b i64[src]

type Output = BigInt

impl Rem<BigInt> for u64[src]

type Output = BigInt

impl<'a> Rem<&'a u64> for BigUint[src]

type Output = BigUint

impl<'a> Rem<&'a BigInt> for i128[src]

type Output = BigInt

impl<'a, 'b> Rem<&'b u128> for &'a BigInt[src]

type Output = BigInt

impl<'a> Rem<BigInt> for &'a usize[src]

type Output = BigInt

impl<'a, 'b> Rem<&'a BigInt> for &'b i128[src]

type Output = BigInt

impl<'a> Rem<i32> for &'a BigInt[src]

type Output = BigInt

impl<'a> Rem<&'a BigUint> for u16[src]

type Output = BigUint

impl<'a> Rem<&'a u128> for BigUint[src]

type Output = BigUint

impl<'a> Rem<usize> for &'a BigUint[src]

type Output = BigUint

impl Rem<u32> for BigInt[src]

type Output = BigInt

impl Rem<i128> for BigInt[src]

type Output = BigInt

impl<'a> Rem<BigInt> for &'a u8[src]

type Output = BigInt

impl Rem<BigInt> for i16[src]

type Output = BigInt

impl<'a, 'b> Rem<&'b i8> for &'a BigInt[src]

type Output = BigInt

impl<'a> Rem<BigInt> for &'a i16[src]

type Output = BigInt

impl Rem<BigUint> for u32[src]

type Output = BigUint

impl<'a, 'b> Rem<&'b i128> for &'a BigInt[src]

type Output = BigInt

impl<'a> Rem<&'a BigInt> for BigInt[src]

type Output = BigInt

impl<'a, 'b> Rem<&'b BigUint> for &'a BigUint[src]

type Output = BigUint

impl<'a> Rem<&'a u16> for BigInt[src]

type Output = BigInt

impl<'a> Rem<BigUint> for &'a BigUint[src]

type Output = BigUint

impl<'a, 'b> Rem<&'b i16> for &'a BigInt[src]

type Output = BigInt

impl<'a> Rem<u128> for &'a BigInt[src]

type Output = BigInt

impl Rem<u128> for BigInt[src]

type Output = BigInt

impl Rem<usize> for BigUint[src]

type Output = BigUint

impl Rem<BigInt> for i64[src]

type Output = BigInt

impl<'a> Rem<&'a BigInt> for u16[src]

type Output = BigInt

impl<'a, 'b> Rem<&'a BigInt> for &'b isize[src]

type Output = BigInt

impl<'a> Rem<&'a u8> for BigUint[src]

type Output = BigUint

impl<'a> Rem<&'a u32> for BigUint[src]

type Output = BigUint

impl<'a> Rem<BigInt> for &'a i128[src]

type Output = BigInt

impl<'a, 'b> Rem<&'b u32> for &'a BigInt[src]

type Output = BigInt

impl<'a> Rem<&'a u8> for BigInt[src]

type Output = BigInt

impl<'a> Rem<&'a i16> for BigInt[src]

type Output = BigInt

impl<'a, 'b> Rem<&'a BigInt> for &'b i16[src]

type Output = BigInt

impl<'a, 'b> Rem<&'a BigUint> for &'b usize[src]

type Output = BigUint

impl Rem<BigInt> for i128[src]

type Output = BigInt

impl<'a> Rem<&'a BigUint> for BigUint[src]

type Output = BigUint

impl<'a, 'b> Rem<&'b i32> for &'a BigInt[src]

type Output = BigInt

impl Rem<u16> for BigUint[src]

type Output = BigUint

impl<'a> Rem<u8> for &'a BigUint[src]

type Output = BigUint

impl<'a> Rem<BigInt> for &'a i8[src]

type Output = BigInt

impl<'a> Rem<BigUint> for &'a u16[src]

type Output = BigUint

impl<'a> Rem<BigUint> for &'a u8[src]

type Output = BigUint

impl<'a> Rem<BigInt> for &'a u32[src]

type Output = BigInt

impl<'a, 'b> Rem<&'b i64> for &'a BigInt[src]

type Output = BigInt

impl<'a> Rem<u32> for &'a BigInt[src]

type Output = BigInt

impl<'a, 'b> Rem<&'a BigUint> for &'b u128[src]

type Output = BigUint

impl Rem<BigUint> for u64[src]

type Output = BigUint

impl<'a, 'b> Rem<&'a BigInt> for &'b usize[src]

type Output = BigInt

impl Rem<BigInt> for u32[src]

type Output = BigInt

impl Rem<BigInt> for usize[src]

type Output = BigInt

impl<'a> Rem<&'a u16> for BigUint[src]

type Output = BigUint

impl<'a> Rem<&'a usize> for BigInt[src]

type Output = BigInt

impl<'a, 'b> Rem<&'a BigUint> for &'b u32[src]

type Output = BigUint

impl<'a> Rem<&'a BigInt> for u8[src]

type Output = BigInt

impl Rem<BigInt> for u16[src]

type Output = BigInt

impl<'a> Rem<BigUint> for &'a u64[src]

type Output = BigUint

impl Rem<BigInt> for i8[src]

type Output = BigInt

impl<'a> Rem<u64> for &'a BigInt[src]

type Output = BigInt

impl Rem<isize> for BigInt[src]

type Output = BigInt

impl<'a> Rem<&'a u32> for BigInt[src]

type Output = BigInt

impl Rem<u16> for BigInt[src]

type Output = BigInt

impl Rem<u32> for BigUint[src]

type Output = BigUint

impl<'a, 'b> Rem<&'a BigInt> for &'b i8[src]

type Output = BigInt

impl<'a> Rem<u64> for &'a BigUint[src]

type Output = BigUint

impl<'a> Rem<&'a BigInt> for u128[src]

type Output = BigInt

impl<'a, 'b> Rem<&'b u16> for &'a BigInt[src]

type Output = BigInt

impl<'a, 'b> Rem<&'b u16> for &'a BigUint[src]

type Output = BigUint

impl<'a> Rem<&'a BigInt> for isize[src]

type Output = BigInt

impl<'a> Rem<&'a BigInt> for i32[src]

type Output = BigInt

impl<'a> Rem<&'a BigUint> for u128[src]

type Output = BigUint

impl<'a, 'b> Rem<&'b u8> for &'a BigInt[src]

type Output = BigInt

impl<'a, 'b> Rem<&'a BigUint> for &'b u64[src]

type Output = BigUint

impl<'a> Rem<isize> for &'a BigInt[src]

type Output = BigInt

impl Rem<BigInt> for isize[src]

type Output = BigInt

impl<'a, 'b> Rem<&'a BigInt> for &'b u64[src]

type Output = BigInt

impl<'a> Rem<&'a BigInt> for u64[src]

type Output = BigInt

impl<'a> Rem<&'a BigUint> for u64[src]

type Output = BigUint

impl Rem<BigInt> for u8[src]

type Output = BigInt

impl<'a> Rem<BigInt> for &'a u64[src]

type Output = BigInt

impl<'a, 'b> Rem<&'b u32> for &'a BigUint[src]

type Output = BigUint

impl<'a, 'b> Rem<&'b u128> for &'a BigUint[src]

type Output = BigUint

impl<'a> Rem<BigInt> for &'a u16[src]

type Output = BigInt

impl<'a> Rem<BigUint> for &'a usize[src]

type Output = BigUint

impl<'a> Rem<&'a u64> for BigInt[src]

type Output = BigInt

impl<'a> Rem<&'a BigUint> for u8[src]

type Output = BigUint

impl<'a> Rem<i8> for &'a BigInt[src]

type Output = BigInt

impl<'a> Rem<u128> for &'a BigUint[src]

type Output = BigUint

impl Rem<BigInt> for BigInt[src]

type Output = BigInt

impl<'a> Rem<i64> for &'a BigInt[src]

type Output = BigInt

impl<'a, 'b> Rem<&'b usize> for &'a BigInt[src]

type Output = BigInt

impl Rem<i16> for BigInt[src]

type Output = BigInt

impl<'a> Rem<&'a i128> for BigInt[src]

type Output = BigInt

impl Rem<i8> for BigInt[src]

type Output = BigInt

impl<'a, 'b> Rem<&'a BigInt> for &'b u32[src]

type Output = BigInt

impl<'a> Rem<&'a usize> for BigUint[src]

type Output = BigUint

impl<'a> Rem<&'a isize> for BigInt[src]

type Output = BigInt

impl<'a, 'b> Rem<&'a Complex<i8>> for &'b i8[src]

type Output = Complex<i8>

impl<'a, 'b> Rem<&'a Complex<isize>> for &'b isize[src]

type Output = Complex<isize>

impl<'a> Rem<&'a Complex<f32>> for f32[src]

type Output = Complex<f32>

impl<'a> Rem<&'a Complex<i16>> for i16[src]

type Output = Complex<i16>

impl<'a> Rem<&'a Complex<f64>> for f64[src]

type Output = Complex<f64>

impl<'a> Rem<&'a Complex<u16>> for u16[src]

type Output = Complex<u16>

impl<'a> Rem<Complex<u32>> for &'a u32[src]

type Output = Complex<u32>

impl Rem<Complex<u64>> for u64[src]

type Output = Complex<u64>

impl<T> Rem<Complex<T>> for Complex<T> where
    T: Clone + Num
[src]

type Output = Complex<T>

impl Rem<Complex<isize>> for isize[src]

type Output = Complex<isize>

impl<'a> Rem<&'a Complex<i8>> for i8[src]

type Output = Complex<i8>

impl<'a, 'b> Rem<&'a Complex<i128>> for &'b i128[src]

type Output = Complex<i128>

impl<'a> Rem<Complex<i64>> for &'a i64[src]

type Output = Complex<i64>

impl<'a> Rem<&'a Complex<usize>> for usize[src]

type Output = Complex<usize>

impl<'a, T> Rem<&'a T> for Complex<T> where
    T: Clone + Num
[src]

type Output = Complex<T>

impl<'a> Rem<Complex<i32>> for &'a i32[src]

type Output = Complex<i32>

impl<'a> Rem<Complex<u16>> for &'a u16[src]

type Output = Complex<u16>

impl<'a> Rem<&'a Complex<i128>> for i128[src]

type Output = Complex<i128>

impl<'a, 'b> Rem<&'a Complex<f64>> for &'b f64[src]

type Output = Complex<f64>

impl<'a> Rem<Complex<i16>> for &'a i16[src]

type Output = Complex<i16>

impl Rem<Complex<i32>> for i32[src]

type Output = Complex<i32>

impl<'a> Rem<&'a Complex<i32>> for i32[src]

type Output = Complex<i32>

impl Rem<Complex<u8>> for u8[src]

type Output = Complex<u8>

impl<'a> Rem<Complex<u64>> for &'a u64[src]

type Output = Complex<u64>

impl<'a> Rem<Complex<usize>> for &'a usize[src]

type Output = Complex<usize>

impl<'a, 'b> Rem<&'a Complex<f32>> for &'b f32[src]

type Output = Complex<f32>

impl<'a, 'b> Rem<&'a Complex<u32>> for &'b u32[src]

type Output = Complex<u32>

impl<'a, 'b, T> Rem<&'b Complex<T>> for &'a Complex<T> where
    T: Clone + Num
[src]

type Output = Complex<T>

impl<'a, 'b> Rem<&'a Complex<usize>> for &'b usize[src]

type Output = Complex<usize>

impl<'a, 'b> Rem<&'a Complex<i32>> for &'b i32[src]

type Output = Complex<i32>

impl<'a> Rem<Complex<isize>> for &'a isize[src]

type Output = Complex<isize>

impl<'a> Rem<&'a Complex<u8>> for u8[src]

type Output = Complex<u8>

impl Rem<Complex<f64>> for f64[src]

type Output = Complex<f64>

impl Rem<Complex<u32>> for u32[src]

type Output = Complex<u32>

impl<'a, T> Rem<&'a Complex<T>> for Complex<T> where
    T: Clone + Num
[src]

type Output = Complex<T>

impl<'a, 'b> Rem<&'a Complex<i16>> for &'b i16[src]

type Output = Complex<i16>

impl<'a, 'b, T> Rem<&'a T> for &'b Complex<T> where
    T: Clone + Num
[src]

type Output = Complex<T>

impl<'a> Rem<Complex<f64>> for &'a f64[src]

type Output = Complex<f64>

impl<'a> Rem<&'a Complex<u64>> for u64[src]

type Output = Complex<u64>

impl Rem<Complex<i128>> for i128[src]

type Output = Complex<i128>

impl Rem<Complex<u128>> for u128[src]

type Output = Complex<u128>

impl<'a, 'b> Rem<&'a Complex<i64>> for &'b i64[src]

type Output = Complex<i64>

impl<'a> Rem<Complex<f32>> for &'a f32[src]

type Output = Complex<f32>

impl<'a, 'b> Rem<&'a Complex<u16>> for &'b u16[src]

type Output = Complex<u16>

impl<'a> Rem<&'a Complex<u32>> for u32[src]

type Output = Complex<u32>

impl<'a> Rem<Complex<i128>> for &'a i128[src]

type Output = Complex<i128>

impl<'a> Rem<Complex<u8>> for &'a u8[src]

type Output = Complex<u8>

impl<'a, T> Rem<Complex<T>> for &'a Complex<T> where
    T: Clone + Num
[src]

type Output = Complex<T>

impl<'a, T> Rem<T> for &'a Complex<T> where
    T: Clone + Num
[src]

type Output = Complex<T>

impl<'a> Rem<&'a Complex<isize>> for isize[src]

type Output = Complex<isize>

impl<'a, 'b> Rem<&'a Complex<u8>> for &'b u8[src]

type Output = Complex<u8>

impl Rem<Complex<i8>> for i8[src]

type Output = Complex<i8>

impl Rem<Complex<u16>> for u16[src]

type Output = Complex<u16>

impl<'a> Rem<Complex<u128>> for &'a u128[src]

type Output = Complex<u128>

impl Rem<Complex<f32>> for f32[src]

type Output = Complex<f32>

impl<'a> Rem<&'a Complex<i64>> for i64[src]

type Output = Complex<i64>

impl Rem<Complex<i16>> for i16[src]

type Output = Complex<i16>

impl<'a, 'b> Rem<&'a Complex<u128>> for &'b u128[src]

type Output = Complex<u128>

impl<'a> Rem<&'a Complex<u128>> for u128[src]

type Output = Complex<u128>

impl<'a> Rem<Complex<i8>> for &'a i8[src]

type Output = Complex<i8>

impl<T> Rem<T> for Complex<T> where
    T: Clone + Num
[src]

type Output = Complex<T>

impl Rem<Complex<i64>> for i64[src]

type Output = Complex<i64>

impl Rem<Complex<usize>> for usize[src]

type Output = Complex<usize>

impl<'a, 'b> Rem<&'a Complex<u64>> for &'b u64[src]

type Output = Complex<u64>

impl<'a, T> Rem<&'a Ratio<T>> for Ratio<T> where
    T: Clone + Integer
[src]

type Output = Ratio<T>

impl<'a, 'b, T> Rem<&'b Ratio<T>> for &'a Ratio<T> where
    T: Clone + Integer
[src]

type Output = Ratio<T>

impl<'a, T> Rem<Ratio<T>> for &'a Ratio<T> where
    T: Clone + Integer
[src]

type Output = Ratio<T>

impl<'a, T> Rem<T> for &'a Ratio<T> where
    T: Clone + Integer
[src]

type Output = Ratio<T>

impl<T> Rem<Ratio<T>> for Ratio<T> where
    T: Clone + Integer
[src]

type Output = Ratio<T>

impl<T> Rem<T> for Ratio<T> where
    T: Clone + Integer
[src]

type Output = Ratio<T>

impl<'a, 'b, T> Rem<&'b T> for &'a Ratio<T> where
    T: Clone + Integer
[src]

type Output = Ratio<T>

impl<'a, T> Rem<&'a T> for Ratio<T> where
    T: Clone + Integer
[src]

type Output = Ratio<T>

impl<V, A, Rhs> Rem<Rhs> for TArr<V, A> where
    V: Rem<Rhs>,
    A: Rem<Rhs>,
    Rhs: Copy

type Output = TArr<<V as Rem<Rhs>>::Output, <A as Rem<Rhs>>::Output>

impl<Ul, Bl, Ur, Br> Rem<UInt<Ur, Br>> for UInt<Ul, Bl> where
    Ul: Unsigned,
    Ur: Unsigned,
    Bl: Bit,
    Br: Bit,
    UInt<Ul, Bl>: Len,
    <UInt<Ul, Bl> as Len>::Output: Sub<B1>,
    (): PrivateDiv<UInt<Ul, Bl>, UInt<Ur, Br>, UTerm, UTerm, <<UInt<Ul, Bl> as Len>::Output as Sub<B1>>::Output>, 

type Output = <() as PrivateDiv<UInt<Ul, Bl>, UInt<Ur, Br>, UTerm, UTerm, <<UInt<Ul, Bl> as Len>::Output as Sub<B1>>::Output>>::Remainder

impl<Rhs> Rem<Rhs> for ATerm

type Output = ATerm

impl<I> Rem<I> for Z0 where
    I: NonZero + Integer, 

Z0 % I = Z0 where I != 0

type Output = Z0

impl<Ul, Ur> Rem<NInt<Ur>> for NInt<Ul> where
    Ul: NonZero + Unsigned + Rem<Ur>,
    Ur: NonZero + Unsigned,
    NInt<Ul>: PrivateRem<<Ul as Rem<Ur>>::Output, NInt<Ur>>, 

$A<Ul> % $B<Ur> = $R<Ul % Ur>

type Output = <NInt<Ul> as PrivateRem<<Ul as Rem<Ur>>::Output, NInt<Ur>>>::Output

impl<Ul, Ur> Rem<PInt<Ur>> for PInt<Ul> where
    Ul: NonZero + Unsigned + Rem<Ur>,
    Ur: NonZero + Unsigned,
    PInt<Ul>: PrivateRem<<Ul as Rem<Ur>>::Output, PInt<Ur>>, 

$A<Ul> % $B<Ur> = $R<Ul % Ur>

type Output = <PInt<Ul> as PrivateRem<<Ul as Rem<Ur>>::Output, PInt<Ur>>>::Output

impl<Ul, Ur> Rem<PInt<Ur>> for NInt<Ul> where
    Ul: NonZero + Unsigned + Rem<Ur>,
    Ur: NonZero + Unsigned,
    NInt<Ul>: PrivateRem<<Ul as Rem<Ur>>::Output, PInt<Ur>>, 

$A<Ul> % $B<Ur> = $R<Ul % Ur>

type Output = <NInt<Ul> as PrivateRem<<Ul as Rem<Ur>>::Output, PInt<Ur>>>::Output

impl<Ul, Ur> Rem<NInt<Ur>> for PInt<Ul> where
    Ul: NonZero + Unsigned + Rem<Ur>,
    Ur: NonZero + Unsigned,
    PInt<Ul>: PrivateRem<<Ul as Rem<Ur>>::Output, NInt<Ur>>, 

$A<Ul> % $B<Ur> = $R<Ul % Ur>

type Output = <PInt<Ul> as PrivateRem<<Ul as Rem<Ur>>::Output, NInt<Ur>>>::Output

impl<Ur, Br> Rem<UInt<Ur, Br>> for UTerm where
    Ur: Unsigned,
    Br: Bit, 

type Output = UTerm

impl<'a, 'b> Rem<&'b BigNumRef> for &'a BigNumRef[src]

type Output = BigNum

impl<'a, 'b> Rem<&'b BigNum> for &'a BigNum[src]

type Output = BigNum

impl<'a, 'b> Rem<&'b BigNum> for &'a BigNumRef[src]

type Output = BigNum

impl<'a, 'b> Rem<&'b BigNumRef> for &'a BigNum[src]

type Output = BigNum

Loading content...

Implementors

Loading content...