[−][src]Struct typenum::int::NInt
Type-level signed integers with negative sign.
Methods
impl<U: Unsigned + NonZero> NInt<U>[src]
impl<U: Unsigned + NonZero> NInt<U>Trait Implementations
impl<U: Unsigned + NonZero> NonZero for NInt<U>[src]
impl<U: Unsigned + NonZero> NonZero for NInt<U>impl<U: Unsigned + NonZero> Integer for NInt<U>[src]
impl<U: Unsigned + NonZero> Integer for NInt<U>const I8: i8[src]
const I16: i16[src]
const I32: i32[src]
const I64: i64[src]
const ISIZE: isize[src]
fn to_i8() -> i8[src]
fn to_i8() -> i8fn to_i16() -> i16[src]
fn to_i16() -> i16fn to_i32() -> i32[src]
fn to_i32() -> i32fn to_i64() -> i64[src]
fn to_i64() -> i64fn to_isize() -> isize[src]
fn to_isize() -> isizeimpl<U: Unsigned + NonZero> Abs for NInt<U>[src]
impl<U: Unsigned + NonZero> Abs for NInt<U>impl<U: Unsigned + NonZero> Pow<NInt<U>> for Z0[src]
impl<U: Unsigned + NonZero> Pow<NInt<U>> for Z00^N = 0
type Output = Z0
The result of the exponentiation.
fn powi(self, _: NInt<U>) -> Self::Output[src]
fn powi(self, _: NInt<U>) -> Self::OutputThis function isn't used in this crate, but may be useful for others. It is implemented for primitives. Read more
impl<U: Unsigned + NonZero> Pow<NInt<U>> for P1[src]
impl<U: Unsigned + NonZero> Pow<NInt<U>> for P11^N = 1
type Output = P1
The result of the exponentiation.
fn powi(self, _: NInt<U>) -> Self::Output[src]
fn powi(self, _: NInt<U>) -> Self::OutputThis function isn't used in this crate, but may be useful for others. It is implemented for primitives. Read more
impl<U: Unsigned> Pow<NInt<UInt<U, B0>>> for N1[src]
impl<U: Unsigned> Pow<NInt<UInt<U, B0>>> for N1(-1)^N = 1 if N is even
type Output = P1
The result of the exponentiation.
fn powi(self, _: NInt<UInt<U, B0>>) -> Self::Output[src]
fn powi(self, _: NInt<UInt<U, B0>>) -> Self::OutputThis function isn't used in this crate, but may be useful for others. It is implemented for primitives. Read more
impl<U: Unsigned> Pow<NInt<UInt<U, B1>>> for N1[src]
impl<U: Unsigned> Pow<NInt<UInt<U, B1>>> for N1(-1)^N = -1 if N is odd
type Output = N1
The result of the exponentiation.
fn powi(self, _: NInt<UInt<U, B1>>) -> Self::Output[src]
fn powi(self, _: NInt<UInt<U, B1>>) -> Self::OutputThis function isn't used in this crate, but may be useful for others. It is implemented for primitives. Read more
impl<U: Unsigned + NonZero> Pow<Z0> for NInt<U>[src]
impl<U: Unsigned + NonZero> Pow<Z0> for NInt<U>N^0 = 1
type Output = P1
The result of the exponentiation.
fn powi(self, _: Z0) -> Self::Output[src]
fn powi(self, _: Z0) -> Self::OutputThis function isn't used in this crate, but may be useful for others. It is implemented for primitives. Read more
impl<Ul: Unsigned + NonZero, Ur: Unsigned> Pow<PInt<UInt<Ur, B0>>> for NInt<Ul> where
Ul: Pow<UInt<Ur, B0>>,
<Ul as Pow<UInt<Ur, B0>>>::Output: Unsigned + NonZero, [src]
impl<Ul: Unsigned + NonZero, Ur: Unsigned> Pow<PInt<UInt<Ur, B0>>> for NInt<Ul> where
Ul: Pow<UInt<Ur, B0>>,
<Ul as Pow<UInt<Ur, B0>>>::Output: Unsigned + NonZero, N(Ul)^P(Ur) = P(Ul^Ur) if Ur is even
type Output = PInt<<Ul as Pow<UInt<Ur, B0>>>::Output>
The result of the exponentiation.
fn powi(self, _: PInt<UInt<Ur, B0>>) -> Self::Output[src]
fn powi(self, _: PInt<UInt<Ur, B0>>) -> Self::OutputThis function isn't used in this crate, but may be useful for others. It is implemented for primitives. Read more
impl<Ul: Unsigned + NonZero, Ur: Unsigned> Pow<PInt<UInt<Ur, B1>>> for NInt<Ul> where
Ul: Pow<UInt<Ur, B1>>,
<Ul as Pow<UInt<Ur, B1>>>::Output: Unsigned + NonZero, [src]
impl<Ul: Unsigned + NonZero, Ur: Unsigned> Pow<PInt<UInt<Ur, B1>>> for NInt<Ul> where
Ul: Pow<UInt<Ur, B1>>,
<Ul as Pow<UInt<Ur, B1>>>::Output: Unsigned + NonZero, N(Ul)^P(Ur) = N(Ul^Ur) if Ur is odd
type Output = NInt<<Ul as Pow<UInt<Ur, B1>>>::Output>
The result of the exponentiation.
fn powi(self, _: PInt<UInt<Ur, B1>>) -> Self::Output[src]
fn powi(self, _: PInt<UInt<Ur, B1>>) -> Self::OutputThis function isn't used in this crate, but may be useful for others. It is implemented for primitives. Read more
impl<U: Unsigned + NonZero> Cmp<NInt<U>> for Z0[src]
impl<U: Unsigned + NonZero> Cmp<NInt<U>> for Z00 > -X
type Output = Greater
The result of the comparison. It should only ever be one of Greater, Less, or Equal.
impl<U: Unsigned + NonZero> Cmp<Z0> for NInt<U>[src]
impl<U: Unsigned + NonZero> Cmp<Z0> for NInt<U>-X < 0
type Output = Less
The result of the comparison. It should only ever be one of Greater, Less, or Equal.
impl<P: Unsigned + NonZero, N: Unsigned + NonZero> Cmp<PInt<P>> for NInt<N>[src]
impl<P: Unsigned + NonZero, N: Unsigned + NonZero> Cmp<PInt<P>> for NInt<N>-X < Y
type Output = Less
The result of the comparison. It should only ever be one of Greater, Less, or Equal.
impl<P: Unsigned + NonZero, N: Unsigned + NonZero> Cmp<NInt<N>> for PInt<P>[src]
impl<P: Unsigned + NonZero, N: Unsigned + NonZero> Cmp<NInt<N>> for PInt<P>X > - Y
type Output = Greater
The result of the comparison. It should only ever be one of Greater, Less, or Equal.
impl<Nl: Unsigned + NonZero, Nr: Cmp<Nl> + Unsigned + NonZero> Cmp<NInt<Nr>> for NInt<Nl>[src]
impl<Nl: Unsigned + NonZero, Nr: Cmp<Nl> + Unsigned + NonZero> Cmp<NInt<Nr>> for NInt<Nl>-X <==> -Y
type Output = <Nr as Cmp<Nl>>::Output
The result of the comparison. It should only ever be one of Greater, Less, or Equal.
impl<U> Min<NInt<U>> for Z0 where
U: Unsigned + NonZero, [src]
impl<U> Min<NInt<U>> for Z0 where
U: Unsigned + NonZero, type Output = NInt<U>
The type of the minimum of Self and Rhs
fn min(self, rhs: NInt<U>) -> Self::Output[src]
fn min(self, rhs: NInt<U>) -> Self::OutputMethod returning the minimum
impl<U> Min<Z0> for NInt<U> where
U: Unsigned + NonZero, [src]
impl<U> Min<Z0> for NInt<U> where
U: Unsigned + NonZero, type Output = NInt<U>
The type of the minimum of Self and Rhs
fn min(self, _: Z0) -> Self::Output[src]
fn min(self, _: Z0) -> Self::OutputMethod returning the minimum
impl<Ul, Ur> Min<PInt<Ur>> for NInt<Ul> where
Ul: Unsigned + NonZero,
Ur: Unsigned + NonZero, [src]
impl<Ul, Ur> Min<PInt<Ur>> for NInt<Ul> where
Ul: Unsigned + NonZero,
Ur: Unsigned + NonZero, type Output = NInt<Ul>
The type of the minimum of Self and Rhs
fn min(self, _: PInt<Ur>) -> Self::Output[src]
fn min(self, _: PInt<Ur>) -> Self::OutputMethod returning the minimum
impl<Ul, Ur> Min<NInt<Ur>> for PInt<Ul> where
Ul: Unsigned + NonZero,
Ur: Unsigned + NonZero, [src]
impl<Ul, Ur> Min<NInt<Ur>> for PInt<Ul> where
Ul: Unsigned + NonZero,
Ur: Unsigned + NonZero, type Output = NInt<Ur>
The type of the minimum of Self and Rhs
fn min(self, rhs: NInt<Ur>) -> Self::Output[src]
fn min(self, rhs: NInt<Ur>) -> Self::OutputMethod returning the minimum
impl<Ul, Ur> Min<NInt<Ur>> for NInt<Ul> where
Ul: Unsigned + NonZero + Max<Ur>,
Ur: Unsigned + NonZero,
Maximum<Ul, Ur>: Unsigned + NonZero, [src]
impl<Ul, Ur> Min<NInt<Ur>> for NInt<Ul> where
Ul: Unsigned + NonZero + Max<Ur>,
Ur: Unsigned + NonZero,
Maximum<Ul, Ur>: Unsigned + NonZero, type Output = NInt<Maximum<Ul, Ur>>
The type of the minimum of Self and Rhs
fn min(self, _: NInt<Ur>) -> Self::Output[src]
fn min(self, _: NInt<Ur>) -> Self::OutputMethod returning the minimum
impl<U> Max<NInt<U>> for Z0 where
U: Unsigned + NonZero, [src]
impl<U> Max<NInt<U>> for Z0 where
U: Unsigned + NonZero, type Output = Z0
The type of the maximum of Self and Rhs
fn max(self, _: NInt<U>) -> Self::Output[src]
fn max(self, _: NInt<U>) -> Self::OutputMethod returning the maximum
impl<U> Max<Z0> for NInt<U> where
U: Unsigned + NonZero, [src]
impl<U> Max<Z0> for NInt<U> where
U: Unsigned + NonZero, type Output = Z0
The type of the maximum of Self and Rhs
fn max(self, rhs: Z0) -> Self::Output[src]
fn max(self, rhs: Z0) -> Self::OutputMethod returning the maximum
impl<Ul, Ur> Max<PInt<Ur>> for NInt<Ul> where
Ul: Unsigned + NonZero,
Ur: Unsigned + NonZero, [src]
impl<Ul, Ur> Max<PInt<Ur>> for NInt<Ul> where
Ul: Unsigned + NonZero,
Ur: Unsigned + NonZero, type Output = PInt<Ur>
The type of the maximum of Self and Rhs
fn max(self, rhs: PInt<Ur>) -> Self::Output[src]
fn max(self, rhs: PInt<Ur>) -> Self::OutputMethod returning the maximum
impl<Ul, Ur> Max<NInt<Ur>> for PInt<Ul> where
Ul: Unsigned + NonZero,
Ur: Unsigned + NonZero, [src]
impl<Ul, Ur> Max<NInt<Ur>> for PInt<Ul> where
Ul: Unsigned + NonZero,
Ur: Unsigned + NonZero, type Output = PInt<Ul>
The type of the maximum of Self and Rhs
fn max(self, _: NInt<Ur>) -> Self::Output[src]
fn max(self, _: NInt<Ur>) -> Self::OutputMethod returning the maximum
impl<Ul, Ur> Max<NInt<Ur>> for NInt<Ul> where
Ul: Unsigned + NonZero + Min<Ur>,
Ur: Unsigned + NonZero,
Minimum<Ul, Ur>: Unsigned + NonZero, [src]
impl<Ul, Ur> Max<NInt<Ur>> for NInt<Ul> where
Ul: Unsigned + NonZero + Min<Ur>,
Ur: Unsigned + NonZero,
Minimum<Ul, Ur>: Unsigned + NonZero, type Output = NInt<Minimum<Ul, Ur>>
The type of the maximum of Self and Rhs
fn max(self, _: NInt<Ur>) -> Self::Output[src]
fn max(self, _: NInt<Ur>) -> Self::OutputMethod returning the maximum
impl<U: PartialEq + Unsigned + NonZero> PartialEq<NInt<U>> for NInt<U>[src]
impl<U: PartialEq + Unsigned + NonZero> PartialEq<NInt<U>> for NInt<U>fn eq(&self, other: &NInt<U>) -> bool[src]
fn eq(&self, other: &NInt<U>) -> boolThis method tests for self and other values to be equal, and is used by ==. Read more
fn ne(&self, other: &NInt<U>) -> bool[src]
fn ne(&self, other: &NInt<U>) -> boolThis method tests for !=.
impl<U: Eq + Unsigned + NonZero> Eq for NInt<U>[src]
impl<U: Eq + Unsigned + NonZero> Eq for NInt<U>impl<U: Ord + Unsigned + NonZero> Ord for NInt<U>[src]
impl<U: Ord + Unsigned + NonZero> Ord for NInt<U>fn cmp(&self, other: &NInt<U>) -> Ordering[src]
fn cmp(&self, other: &NInt<U>) -> OrderingThis method returns an Ordering between self and other. Read more
fn max(self, other: Self) -> Self1.21.0[src]
fn max(self, other: Self) -> SelfCompares and returns the maximum of two values. Read more
fn min(self, other: Self) -> Self1.21.0[src]
fn min(self, other: Self) -> SelfCompares and returns the minimum of two values. Read more
impl<U: PartialOrd + Unsigned + NonZero> PartialOrd<NInt<U>> for NInt<U>[src]
impl<U: PartialOrd + Unsigned + NonZero> PartialOrd<NInt<U>> for NInt<U>fn partial_cmp(&self, other: &NInt<U>) -> Option<Ordering>[src]
fn partial_cmp(&self, other: &NInt<U>) -> Option<Ordering>This method returns an ordering between self and other values if one exists. Read more
fn lt(&self, other: &NInt<U>) -> bool[src]
fn lt(&self, other: &NInt<U>) -> boolThis method tests less than (for self and other) and is used by the < operator. Read more
fn le(&self, other: &NInt<U>) -> bool[src]
fn le(&self, other: &NInt<U>) -> boolThis method tests less than or equal to (for self and other) and is used by the <= operator. Read more
fn gt(&self, other: &NInt<U>) -> bool[src]
fn gt(&self, other: &NInt<U>) -> boolThis method tests greater than (for self and other) and is used by the > operator. Read more
fn ge(&self, other: &NInt<U>) -> bool[src]
fn ge(&self, other: &NInt<U>) -> boolThis method tests greater than or equal to (for self and other) and is used by the >= operator. Read more
impl<U: Debug + Unsigned + NonZero> Debug for NInt<U>[src]
impl<U: Debug + Unsigned + NonZero> Debug for NInt<U>fn fmt(&self, f: &mut Formatter) -> Result[src]
fn fmt(&self, f: &mut Formatter) -> ResultFormats the value using the given formatter. Read more
impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Div<NInt<Ur>> for PInt<Ul> where
Ul: Cmp<Ur>,
PInt<Ul>: PrivateDivInt<<Ul as Cmp<Ur>>::Output, NInt<Ur>>, [src]
impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Div<NInt<Ur>> for PInt<Ul> where
Ul: Cmp<Ur>,
PInt<Ul>: PrivateDivInt<<Ul as Cmp<Ur>>::Output, NInt<Ur>>, $A<Ul> / $B<Ur> = $R<Ul / Ur>
type Output = <PInt<Ul> as PrivateDivInt<<Ul as Cmp<Ur>>::Output, NInt<Ur>>>::Output
The resulting type after applying the / operator.
fn div(self, _: NInt<Ur>) -> Self::Output[src]
fn div(self, _: NInt<Ur>) -> Self::OutputPerforms the / operation.
impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Div<PInt<Ur>> for NInt<Ul> where
Ul: Cmp<Ur>,
NInt<Ul>: PrivateDivInt<<Ul as Cmp<Ur>>::Output, PInt<Ur>>, [src]
impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Div<PInt<Ur>> for NInt<Ul> where
Ul: Cmp<Ur>,
NInt<Ul>: PrivateDivInt<<Ul as Cmp<Ur>>::Output, PInt<Ur>>, $A<Ul> / $B<Ur> = $R<Ul / Ur>
type Output = <NInt<Ul> as PrivateDivInt<<Ul as Cmp<Ur>>::Output, PInt<Ur>>>::Output
The resulting type after applying the / operator.
fn div(self, _: PInt<Ur>) -> Self::Output[src]
fn div(self, _: PInt<Ur>) -> Self::OutputPerforms the / operation.
impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Div<NInt<Ur>> for NInt<Ul> where
Ul: Cmp<Ur>,
NInt<Ul>: PrivateDivInt<<Ul as Cmp<Ur>>::Output, NInt<Ur>>, [src]
impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Div<NInt<Ur>> for NInt<Ul> where
Ul: Cmp<Ur>,
NInt<Ul>: PrivateDivInt<<Ul as Cmp<Ur>>::Output, NInt<Ur>>, $A<Ul> / $B<Ur> = $R<Ul / Ur>
type Output = <NInt<Ul> as PrivateDivInt<<Ul as Cmp<Ur>>::Output, NInt<Ur>>>::Output
The resulting type after applying the / operator.
fn div(self, _: NInt<Ur>) -> Self::Output[src]
fn div(self, _: NInt<Ur>) -> Self::OutputPerforms the / operation.
impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Rem<NInt<Ur>> for PInt<Ul> where
Ul: Rem<Ur>,
PInt<Ul>: PrivateRem<<Ul as Rem<Ur>>::Output, NInt<Ur>>, [src]
impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Rem<NInt<Ur>> for PInt<Ul> where
Ul: Rem<Ur>,
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
The resulting type after applying the % operator.
fn rem(self, _: NInt<Ur>) -> Self::Output[src]
fn rem(self, _: NInt<Ur>) -> Self::OutputPerforms the % operation.
impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Rem<PInt<Ur>> for NInt<Ul> where
Ul: Rem<Ur>,
NInt<Ul>: PrivateRem<<Ul as Rem<Ur>>::Output, PInt<Ur>>, [src]
impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Rem<PInt<Ur>> for NInt<Ul> where
Ul: Rem<Ur>,
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
The resulting type after applying the % operator.
fn rem(self, _: PInt<Ur>) -> Self::Output[src]
fn rem(self, _: PInt<Ur>) -> Self::OutputPerforms the % operation.
impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Rem<NInt<Ur>> for NInt<Ul> where
Ul: Rem<Ur>,
NInt<Ul>: PrivateRem<<Ul as Rem<Ur>>::Output, NInt<Ur>>, [src]
impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Rem<NInt<Ur>> for NInt<Ul> where
Ul: Rem<Ur>,
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
The resulting type after applying the % operator.
fn rem(self, _: NInt<Ur>) -> Self::Output[src]
fn rem(self, _: NInt<Ur>) -> Self::OutputPerforms the % operation.
impl<U: Unsigned + NonZero> Add<Z0> for NInt<U>[src]
impl<U: Unsigned + NonZero> Add<Z0> for NInt<U>NInt + Z0 = NInt
type Output = NInt<U>
The resulting type after applying the + operator.
fn add(self, _: Z0) -> Self::Output[src]
fn add(self, _: Z0) -> Self::OutputPerforms the + operation.
impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Add<NInt<Ur>> for NInt<Ul> where
Ul: Add<Ur>,
<Ul as Add<Ur>>::Output: Unsigned + NonZero, [src]
impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Add<NInt<Ur>> for NInt<Ul> where
Ul: Add<Ur>,
<Ul as Add<Ur>>::Output: Unsigned + NonZero, N(Ul) + N(Ur) = N(Ul + Ur)
type Output = NInt<<Ul as Add<Ur>>::Output>
The resulting type after applying the + operator.
fn add(self, _: NInt<Ur>) -> Self::Output[src]
fn add(self, _: NInt<Ur>) -> Self::OutputPerforms the + operation.
impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Add<NInt<Ur>> for PInt<Ul> where
Ul: Cmp<Ur> + PrivateIntegerAdd<<Ul as Cmp<Ur>>::Output, Ur>, [src]
impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Add<NInt<Ur>> for PInt<Ul> where
Ul: Cmp<Ur> + PrivateIntegerAdd<<Ul as Cmp<Ur>>::Output, Ur>, P(Ul) + N(Ur): We resolve this with our PrivateAdd
type Output = <Ul as PrivateIntegerAdd<<Ul as Cmp<Ur>>::Output, Ur>>::Output
The resulting type after applying the + operator.
fn add(self, _: NInt<Ur>) -> Self::Output[src]
fn add(self, _: NInt<Ur>) -> Self::OutputPerforms the + operation.
impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Add<PInt<Ur>> for NInt<Ul> where
Ur: Cmp<Ul> + PrivateIntegerAdd<<Ur as Cmp<Ul>>::Output, Ul>, [src]
impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Add<PInt<Ur>> for NInt<Ul> where
Ur: Cmp<Ul> + PrivateIntegerAdd<<Ur as Cmp<Ul>>::Output, Ul>, N(Ul) + P(Ur): We resolve this with our PrivateAdd
type Output = <Ur as PrivateIntegerAdd<<Ur as Cmp<Ul>>::Output, Ul>>::Output
The resulting type after applying the + operator.
fn add(self, _: PInt<Ur>) -> Self::Output[src]
fn add(self, _: PInt<Ur>) -> Self::OutputPerforms the + operation.
impl<U: Unsigned + NonZero> Sub<NInt<U>> for Z0[src]
impl<U: Unsigned + NonZero> Sub<NInt<U>> for Z0Z0 - N = P
type Output = PInt<U>
The resulting type after applying the - operator.
fn sub(self, _: NInt<U>) -> Self::Output[src]
fn sub(self, _: NInt<U>) -> Self::OutputPerforms the - operation.
impl<U: Unsigned + NonZero> Sub<Z0> for NInt<U>[src]
impl<U: Unsigned + NonZero> Sub<Z0> for NInt<U>NInt - Z0 = NInt
type Output = NInt<U>
The resulting type after applying the - operator.
fn sub(self, _: Z0) -> Self::Output[src]
fn sub(self, _: Z0) -> Self::OutputPerforms the - operation.
impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Sub<NInt<Ur>> for PInt<Ul> where
Ul: Add<Ur>,
<Ul as Add<Ur>>::Output: Unsigned + NonZero, [src]
impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Sub<NInt<Ur>> for PInt<Ul> where
Ul: Add<Ur>,
<Ul as Add<Ur>>::Output: Unsigned + NonZero, P(Ul) - N(Ur) = P(Ul + Ur)
type Output = PInt<<Ul as Add<Ur>>::Output>
The resulting type after applying the - operator.
fn sub(self, _: NInt<Ur>) -> Self::Output[src]
fn sub(self, _: NInt<Ur>) -> Self::OutputPerforms the - operation.
impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Sub<PInt<Ur>> for NInt<Ul> where
Ul: Add<Ur>,
<Ul as Add<Ur>>::Output: Unsigned + NonZero, [src]
impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Sub<PInt<Ur>> for NInt<Ul> where
Ul: Add<Ur>,
<Ul as Add<Ur>>::Output: Unsigned + NonZero, N(Ul) - P(Ur) = N(Ul + Ur)
type Output = NInt<<Ul as Add<Ur>>::Output>
The resulting type after applying the - operator.
fn sub(self, _: PInt<Ur>) -> Self::Output[src]
fn sub(self, _: PInt<Ur>) -> Self::OutputPerforms the - operation.
impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Sub<NInt<Ur>> for NInt<Ul> where
Ur: Cmp<Ul> + PrivateIntegerAdd<<Ur as Cmp<Ul>>::Output, Ul>, [src]
impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Sub<NInt<Ur>> for NInt<Ul> where
Ur: Cmp<Ul> + PrivateIntegerAdd<<Ur as Cmp<Ul>>::Output, Ul>, N(Ul) - N(Ur): We resolve this with our PrivateAdd
type Output = <Ur as PrivateIntegerAdd<<Ur as Cmp<Ul>>::Output, Ul>>::Output
The resulting type after applying the - operator.
fn sub(self, _: NInt<Ur>) -> Self::Output[src]
fn sub(self, _: NInt<Ur>) -> Self::OutputPerforms the - operation.
impl<U: Unsigned + NonZero> Mul<Z0> for NInt<U>[src]
impl<U: Unsigned + NonZero> Mul<Z0> for NInt<U>N * Z0 = Z0
type Output = Z0
The resulting type after applying the * operator.
fn mul(self, _: Z0) -> Self::Output[src]
fn mul(self, _: Z0) -> Self::OutputPerforms the * operation.
impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Mul<NInt<Ur>> for NInt<Ul> where
Ul: Mul<Ur>,
<Ul as Mul<Ur>>::Output: Unsigned + NonZero, [src]
impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Mul<NInt<Ur>> for NInt<Ul> where
Ul: Mul<Ur>,
<Ul as Mul<Ur>>::Output: Unsigned + NonZero, N(Ul) * N(Ur) = P(Ul * Ur)
type Output = PInt<<Ul as Mul<Ur>>::Output>
The resulting type after applying the * operator.
fn mul(self, _: NInt<Ur>) -> Self::Output[src]
fn mul(self, _: NInt<Ur>) -> Self::OutputPerforms the * operation.
impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Mul<NInt<Ur>> for PInt<Ul> where
Ul: Mul<Ur>,
<Ul as Mul<Ur>>::Output: Unsigned + NonZero, [src]
impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Mul<NInt<Ur>> for PInt<Ul> where
Ul: Mul<Ur>,
<Ul as Mul<Ur>>::Output: Unsigned + NonZero, P(Ul) * N(Ur) = N(Ul * Ur)
type Output = NInt<<Ul as Mul<Ur>>::Output>
The resulting type after applying the * operator.
fn mul(self, _: NInt<Ur>) -> Self::Output[src]
fn mul(self, _: NInt<Ur>) -> Self::OutputPerforms the * operation.
impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Mul<PInt<Ur>> for NInt<Ul> where
Ul: Mul<Ur>,
<Ul as Mul<Ur>>::Output: Unsigned + NonZero, [src]
impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Mul<PInt<Ur>> for NInt<Ul> where
Ul: Mul<Ur>,
<Ul as Mul<Ur>>::Output: Unsigned + NonZero, N(Ul) * P(Ur) = N(Ul * Ur)
type Output = NInt<<Ul as Mul<Ur>>::Output>
The resulting type after applying the * operator.
fn mul(self, _: PInt<Ur>) -> Self::Output[src]
fn mul(self, _: PInt<Ur>) -> Self::OutputPerforms the * operation.
impl<U> Mul<ATerm> for NInt<U> where
U: Unsigned + NonZero, [src]
impl<U> Mul<ATerm> for NInt<U> where
U: Unsigned + NonZero, type Output = ATerm
The resulting type after applying the * operator.
fn mul(self, _: ATerm) -> Self::Output[src]
fn mul(self, _: ATerm) -> Self::OutputPerforms the * operation.
impl<V, A, U> Mul<TArr<V, A>> for NInt<U> where
U: Unsigned + NonZero,
NInt<U>: Mul<A> + Mul<V>, [src]
impl<V, A, U> Mul<TArr<V, A>> for NInt<U> where
U: Unsigned + NonZero,
NInt<U>: Mul<A> + Mul<V>, type Output = TArr<Prod<NInt<U>, V>, Prod<NInt<U>, A>>
The resulting type after applying the * operator.
fn mul(self, _: TArr<V, A>) -> Self::Output[src]
fn mul(self, _: TArr<V, A>) -> Self::OutputPerforms the * operation.
impl<U: Unsigned + NonZero> Neg for NInt<U>[src]
impl<U: Unsigned + NonZero> Neg for NInt<U>-NInt = PInt
type Output = PInt<U>
The resulting type after applying the - operator.
fn neg(self) -> Self::Output[src]
fn neg(self) -> Self::OutputPerforms the unary - operation.
impl<U: Hash + Unsigned + NonZero> Hash for NInt<U>[src]
impl<U: Hash + Unsigned + NonZero> Hash for NInt<U>fn hash<__HU: Hasher>(&self, state: &mut __HU)[src]
fn hash<__HU: Hasher>(&self, state: &mut __HU)Feeds this value into the given [Hasher]. Read more
fn hash_slice<H>(data: &[Self], state: &mut H) where
H: Hasher, 1.3.0[src]
fn hash_slice<H>(data: &[Self], state: &mut H) where
H: Hasher, Feeds a slice of this type into the given [Hasher]. Read more
impl<U: Copy + Unsigned + NonZero> Copy for NInt<U>[src]
impl<U: Copy + Unsigned + NonZero> Copy for NInt<U>impl<U: Clone + Unsigned + NonZero> Clone for NInt<U>[src]
impl<U: Clone + Unsigned + NonZero> Clone for NInt<U>fn clone(&self) -> NInt<U>[src]
fn clone(&self) -> NInt<U>Returns a copy of the value. Read more
fn clone_from(&mut self, source: &Self)1.0.0[src]
fn clone_from(&mut self, source: &Self)Performs copy-assignment from source. Read more
impl<U: Default + Unsigned + NonZero> Default for NInt<U>[src]
impl<U: Default + Unsigned + NonZero> Default for NInt<U>Auto Trait Implementations
Blanket Implementations
impl<T> Same for T[src]
impl<T> Same for Ttype Output = T
Should always be Self
impl<X, N> Pow for X where
N: Unsigned,
X: Unsigned + PrivatePow<UInt<UTerm, B1>, N>, [src]
impl<X, N> Pow for X where
N: Unsigned,
X: Unsigned + PrivatePow<UInt<UTerm, B1>, N>, type Output = <X as PrivatePow<UInt<UTerm, B1>, N>>::Output
The result of the exponentiation.
fn powi(Self, N) -> <X as Pow<N>>::Output[src]
fn powi(Self, N) -> <X as Pow<N>>::OutputThis function isn't used in this crate, but may be useful for others. It is implemented for primitives. Read more
impl<M, N> PartialDiv for M where
M: Integer + Div<N> + Rem<N, Output = Z0>, [src]
impl<M, N> PartialDiv for M where
M: Integer + Div<N> + Rem<N, Output = Z0>, type Output = <M as Div<N>>::Output
The type of the result of the division
fn partial_div(Self, N) -> <M as PartialDiv<N>>::Output[src]
fn partial_div(Self, N) -> <M as PartialDiv<N>>::OutputMethod for performing the division
impl<A, B> IsLess for A where
A: Cmp<B> + IsLessPrivate<B, <A as Cmp<B>>::Output>, [src]
impl<A, B> IsLess for A where
A: Cmp<B> + IsLessPrivate<B, <A as Cmp<B>>::Output>, type Output = <A as IsLessPrivate<B, <A as Cmp<B>>::Output>>::Output
The type representing either True or False
fn is_less(Self, B) -> <A as IsLess<B>>::Output[src]
fn is_less(Self, B) -> <A as IsLess<B>>::OutputMethod returning True or False.
impl<A, B> IsEqual for A where
A: Cmp<B> + IsEqualPrivate<B, <A as Cmp<B>>::Output>, [src]
impl<A, B> IsEqual for A where
A: Cmp<B> + IsEqualPrivate<B, <A as Cmp<B>>::Output>, type Output = <A as IsEqualPrivate<B, <A as Cmp<B>>::Output>>::Output
The type representing either True or False
fn is_equal(Self, B) -> <A as IsEqual<B>>::Output[src]
fn is_equal(Self, B) -> <A as IsEqual<B>>::OutputMethod returning True or False.
impl<A, B> IsGreater for A where
A: Cmp<B> + IsGreaterPrivate<B, <A as Cmp<B>>::Output>, [src]
impl<A, B> IsGreater for A where
A: Cmp<B> + IsGreaterPrivate<B, <A as Cmp<B>>::Output>, type Output = <A as IsGreaterPrivate<B, <A as Cmp<B>>::Output>>::Output
The type representing either True or False
fn is_greater(Self, B) -> <A as IsGreater<B>>::Output[src]
fn is_greater(Self, B) -> <A as IsGreater<B>>::OutputMethod returning True or False.
impl<A, B> IsLessOrEqual for A where
A: Cmp<B> + IsLessOrEqualPrivate<B, <A as Cmp<B>>::Output>, [src]
impl<A, B> IsLessOrEqual for A where
A: Cmp<B> + IsLessOrEqualPrivate<B, <A as Cmp<B>>::Output>, type Output = <A as IsLessOrEqualPrivate<B, <A as Cmp<B>>::Output>>::Output
The type representing either True or False
fn is_less_or_equal(Self, B) -> <A as IsLessOrEqual<B>>::Output[src]
fn is_less_or_equal(Self, B) -> <A as IsLessOrEqual<B>>::OutputMethod returning True or False.
impl<A, B> IsNotEqual for A where
A: Cmp<B> + IsNotEqualPrivate<B, <A as Cmp<B>>::Output>, [src]
impl<A, B> IsNotEqual for A where
A: Cmp<B> + IsNotEqualPrivate<B, <A as Cmp<B>>::Output>, type Output = <A as IsNotEqualPrivate<B, <A as Cmp<B>>::Output>>::Output
The type representing either True or False
fn is_not_equal(Self, B) -> <A as IsNotEqual<B>>::Output[src]
fn is_not_equal(Self, B) -> <A as IsNotEqual<B>>::OutputMethod returning True or False.
impl<A, B> IsGreaterOrEqual for A where
A: Cmp<B> + IsGreaterOrEqualPrivate<B, <A as Cmp<B>>::Output>, [src]
impl<A, B> IsGreaterOrEqual for A where
A: Cmp<B> + IsGreaterOrEqualPrivate<B, <A as Cmp<B>>::Output>, type Output = <A as IsGreaterOrEqualPrivate<B, <A as Cmp<B>>::Output>>::Output
The type representing either True or False
fn is_greater_or_equal(Self, B) -> <A as IsGreaterOrEqual<B>>::Output[src]
fn is_greater_or_equal(Self, B) -> <A as IsGreaterOrEqual<B>>::OutputMethod returning True or False.
impl<T, U> TryFrom for T where
T: From<U>, [src]
impl<T, U> TryFrom for T where
T: From<U>, type Error = !
try_from)The type returned in the event of a conversion error.
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>[src]
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>try_from)Performs the conversion.
impl<T> From for T[src]
impl<T> From for Timpl<T, U> TryInto for T where
U: TryFrom<T>, [src]
impl<T, U> TryInto for T where
U: TryFrom<T>, type Error = <U as TryFrom<T>>::Error
try_from)The type returned in the event of a conversion error.
fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>[src]
fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>try_from)Performs the conversion.
impl<T, U> Into for T where
U: From<T>, [src]
impl<T, U> Into for T where
U: From<T>, impl<T> Borrow for T where
T: ?Sized, [src]
impl<T> Borrow for T where
T: ?Sized, impl<T> BorrowMut for T where
T: ?Sized, [src]
impl<T> BorrowMut for T where
T: ?Sized, fn borrow_mut(&mut self) -> &mut T[src]
fn borrow_mut(&mut self) -> &mut TMutably borrows from an owned value. Read more
impl<T> Any for T where
T: 'static + ?Sized, [src]
impl<T> Any for T where
T: 'static + ?Sized, fn get_type_id(&self) -> TypeId[src]
fn get_type_id(&self) -> TypeId🔬 This is a nightly-only experimental API. (get_type_id)
this method will likely be replaced by an associated static
Gets the TypeId of self. Read more