[−][src]Trait typenum::type_operators::Pow
A type operator that provides exponentiation by repeated squaring.
Example
use typenum::{Integer, Pow, N3, P3}; assert_eq!(<N3 as Pow<P3>>::Output::to_i32(), -27);
Associated Types
type Output
The result of the exponentiation.
Required methods
fn powi(self, exp: Exp) -> Self::Output
This function isn't used in this crate, but may be useful for others. It is implemented for primitives.
Example
use typenum::{Pow, U3}; let a = 7u32.powi(U3::new()); let b = 7u32.pow(3); assert_eq!(a, b); let x = 3.0.powi(U3::new()); let y = 27.0; assert_eq!(x, y);
Implementors
impl Pow<Z0> for Z0
[src]
0^0 = 1
impl Pow<Z0> for f32
[src]
impl Pow<Z0> for f64
[src]
impl Pow<Z0> for i8
[src]
impl Pow<Z0> for i16
[src]
impl Pow<Z0> for i32
[src]
impl Pow<Z0> for i64
[src]
impl Pow<Z0> for isize
[src]
impl Pow<Z0> for u8
[src]
impl Pow<Z0> for u16
[src]
impl Pow<Z0> for u32
[src]
impl Pow<Z0> for u64
[src]
impl Pow<Z0> for usize
[src]
impl Pow<UTerm> for f32
[src]
impl Pow<UTerm> for f64
[src]
impl Pow<UTerm> for i8
[src]
impl Pow<UTerm> for i16
[src]
impl Pow<UTerm> for i32
[src]
impl Pow<UTerm> for i64
[src]
impl Pow<UTerm> for isize
[src]
impl Pow<UTerm> for u8
[src]
impl Pow<UTerm> for u16
[src]
impl Pow<UTerm> for u32
[src]
impl Pow<UTerm> for u64
[src]
impl Pow<UTerm> for usize
[src]
impl<U: Unsigned + NonZero> Pow<NInt<U>> for Z0
[src]
0^N = 0
impl<U: Unsigned + NonZero> Pow<NInt<U>> for P1
[src]
1^N = 1
impl<U: Unsigned + NonZero> Pow<NInt<U>> for f32
[src]
impl<U: Unsigned + NonZero> Pow<NInt<U>> for f64
[src]
impl<U: Unsigned + NonZero> Pow<PInt<U>> for Z0
[src]
0^P = 0
impl<U: Unsigned + NonZero> Pow<PInt<U>> for f32
[src]
impl<U: Unsigned + NonZero> Pow<PInt<U>> for f64
[src]
impl<U: Unsigned + NonZero> Pow<PInt<U>> for i8
[src]
impl<U: Unsigned + NonZero> Pow<PInt<U>> for i16
[src]
impl<U: Unsigned + NonZero> Pow<PInt<U>> for i32
[src]
impl<U: Unsigned + NonZero> Pow<PInt<U>> for i64
[src]
impl<U: Unsigned + NonZero> Pow<PInt<U>> for isize
[src]
impl<U: Unsigned + NonZero> Pow<PInt<U>> for u8
[src]
impl<U: Unsigned + NonZero> Pow<PInt<U>> for u16
[src]
impl<U: Unsigned + NonZero> Pow<PInt<U>> for u32
[src]
impl<U: Unsigned + NonZero> Pow<PInt<U>> for u64
[src]
impl<U: Unsigned + NonZero> Pow<PInt<U>> for usize
[src]
impl<U: Unsigned + NonZero> Pow<Z0> for NInt<U>
[src]
N^0 = 1
impl<U: Unsigned + NonZero> Pow<Z0> for PInt<U>
[src]
P^0 = 1
impl<U: Unsigned> Pow<NInt<UInt<U, B0>>> for N1
[src]
(-1)^N = 1 if N is even
impl<U: Unsigned> Pow<NInt<UInt<U, B1>>> for N1
[src]
(-1)^N = -1 if N is odd
impl<U: Unsigned, B: Bit> Pow<UInt<U, B>> for f32
[src]
impl<U: Unsigned, B: Bit> Pow<UInt<U, B>> for f64
[src]
impl<U: Unsigned, B: Bit> Pow<UInt<U, B>> for i8
[src]
impl<U: Unsigned, B: Bit> Pow<UInt<U, B>> for i16
[src]
impl<U: Unsigned, B: Bit> Pow<UInt<U, B>> for i32
[src]
impl<U: Unsigned, B: Bit> Pow<UInt<U, B>> for i64
[src]
impl<U: Unsigned, B: Bit> Pow<UInt<U, B>> for isize
[src]
impl<U: Unsigned, B: Bit> Pow<UInt<U, B>> for u8
[src]
impl<U: Unsigned, B: Bit> Pow<UInt<U, B>> for u16
[src]
impl<U: Unsigned, B: Bit> Pow<UInt<U, B>> for u32
[src]
impl<U: Unsigned, B: Bit> Pow<UInt<U, B>> for u64
[src]
impl<U: Unsigned, B: Bit> Pow<UInt<U, B>> for usize
[src]
impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Pow<PInt<Ur>> for PInt<Ul> where
Ul: Pow<Ur>,
<Ul as Pow<Ur>>::Output: Unsigned + NonZero,
[src]
Ul: Pow<Ur>,
<Ul as Pow<Ur>>::Output: Unsigned + NonZero,
P(Ul)^P(Ur) = P(Ul^Ur)
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]
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>
fn powi(self, _: PInt<UInt<Ur, B0>>) -> Self::Output
[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,
[src]
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>
fn powi(self, _: PInt<UInt<Ur, B1>>) -> Self::Output
[src]
impl<X: Unsigned, N: Unsigned> Pow<N> for X where
X: PrivatePow<U1, N>,
[src]
X: PrivatePow<U1, N>,
X^N