[][src]Trait typenum::type_operators::Pow

pub trait Pow<Exp> {
    type Output;
    fn powi(self, exp: Exp) -> Self::Output;
}

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.

Loading content...

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);
Loading content...

Implementors

impl Pow<Z0> for Z0[src]

0^0 = 1

type Output = P1

impl Pow<Z0> for f32[src]

type Output = f32

impl Pow<Z0> for f64[src]

type Output = f64

impl Pow<Z0> for i8[src]

type Output = i8

impl Pow<Z0> for i16[src]

type Output = i16

impl Pow<Z0> for i32[src]

type Output = i32

impl Pow<Z0> for i64[src]

type Output = i64

impl Pow<Z0> for isize[src]

type Output = isize

impl Pow<Z0> for u8[src]

type Output = u8

impl Pow<Z0> for u16[src]

type Output = u16

impl Pow<Z0> for u32[src]

type Output = u32

impl Pow<Z0> for u64[src]

type Output = u64

impl Pow<Z0> for usize[src]

type Output = usize

impl Pow<UTerm> for f32[src]

type Output = f32

impl Pow<UTerm> for f64[src]

type Output = f64

impl Pow<UTerm> for i8[src]

type Output = i8

impl Pow<UTerm> for i16[src]

type Output = i16

impl Pow<UTerm> for i32[src]

type Output = i32

impl Pow<UTerm> for i64[src]

type Output = i64

impl Pow<UTerm> for isize[src]

type Output = isize

impl Pow<UTerm> for u8[src]

type Output = u8

impl Pow<UTerm> for u16[src]

type Output = u16

impl Pow<UTerm> for u32[src]

type Output = u32

impl Pow<UTerm> for u64[src]

type Output = u64

impl Pow<UTerm> for usize[src]

type Output = usize

impl<U: Unsigned + NonZero> Pow<NInt<U>> for Z0[src]

0^N = 0

type Output = Z0

impl<U: Unsigned + NonZero> Pow<NInt<U>> for P1[src]

1^N = 1

type Output = P1

impl<U: Unsigned + NonZero> Pow<NInt<U>> for f32[src]

type Output = f32

impl<U: Unsigned + NonZero> Pow<NInt<U>> for f64[src]

type Output = f64

impl<U: Unsigned + NonZero> Pow<PInt<U>> for Z0[src]

0^P = 0

type Output = Z0

impl<U: Unsigned + NonZero> Pow<PInt<U>> for f32[src]

type Output = f32

impl<U: Unsigned + NonZero> Pow<PInt<U>> for f64[src]

type Output = f64

impl<U: Unsigned + NonZero> Pow<PInt<U>> for i8[src]

type Output = i8

impl<U: Unsigned + NonZero> Pow<PInt<U>> for i16[src]

type Output = i16

impl<U: Unsigned + NonZero> Pow<PInt<U>> for i32[src]

type Output = i32

impl<U: Unsigned + NonZero> Pow<PInt<U>> for i64[src]

type Output = i64

impl<U: Unsigned + NonZero> Pow<PInt<U>> for isize[src]

type Output = isize

impl<U: Unsigned + NonZero> Pow<PInt<U>> for u8[src]

type Output = u8

impl<U: Unsigned + NonZero> Pow<PInt<U>> for u16[src]

type Output = u16

impl<U: Unsigned + NonZero> Pow<PInt<U>> for u32[src]

type Output = u32

impl<U: Unsigned + NonZero> Pow<PInt<U>> for u64[src]

type Output = u64

impl<U: Unsigned + NonZero> Pow<PInt<U>> for usize[src]

type Output = usize

impl<U: Unsigned + NonZero> Pow<Z0> for NInt<U>[src]

N^0 = 1

type Output = P1

impl<U: Unsigned + NonZero> Pow<Z0> for PInt<U>[src]

P^0 = 1

type Output = P1

impl<U: Unsigned> Pow<NInt<UInt<U, B0>>> for N1[src]

(-1)^N = 1 if N is even

type Output = P1

impl<U: Unsigned> Pow<NInt<UInt<U, B1>>> for N1[src]

(-1)^N = -1 if N is odd

type Output = N1

impl<U: Unsigned, B: Bit> Pow<UInt<U, B>> for f32[src]

type Output = f32

impl<U: Unsigned, B: Bit> Pow<UInt<U, B>> for f64[src]

type Output = f64

impl<U: Unsigned, B: Bit> Pow<UInt<U, B>> for i8[src]

type Output = i8

impl<U: Unsigned, B: Bit> Pow<UInt<U, B>> for i16[src]

type Output = i16

impl<U: Unsigned, B: Bit> Pow<UInt<U, B>> for i32[src]

type Output = i32

impl<U: Unsigned, B: Bit> Pow<UInt<U, B>> for i64[src]

type Output = i64

impl<U: Unsigned, B: Bit> Pow<UInt<U, B>> for isize[src]

type Output = isize

impl<U: Unsigned, B: Bit> Pow<UInt<U, B>> for u8[src]

type Output = u8

impl<U: Unsigned, B: Bit> Pow<UInt<U, B>> for u16[src]

type Output = u16

impl<U: Unsigned, B: Bit> Pow<UInt<U, B>> for u32[src]

type Output = u32

impl<U: Unsigned, B: Bit> Pow<UInt<U, B>> for u64[src]

type Output = u64

impl<U: Unsigned, B: Bit> Pow<UInt<U, B>> for usize[src]

type Output = usize

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]

P(Ul)^P(Ur) = P(Ul^Ur)

type Output = PInt<<Ul as Pow<Ur>>::Output>

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]

N(Ul)^P(Ur) = P(Ul^Ur) if Ur is even

type Output = PInt<<Ul as Pow<UInt<Ur, B0>>>::Output>

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]

N(Ul)^P(Ur) = N(Ul^Ur) if Ur is odd

type Output = NInt<<Ul as Pow<UInt<Ur, B1>>>::Output>

impl<X: Unsigned, N: Unsigned> Pow<N> for X where
    X: PrivatePow<U1, N>, 
[src]

X^N

type Output = PrivatePowOut<X, U1, N>

Loading content...