Trait libp2p::multiaddr::multihash::typenum::Pow [−][src]
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
Loading content...Required methods
pub fn powi(self, exp: Exp) -> Self::Output
[src]
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);
Implementations on Foreign Types
impl Pow<UTerm> for u16
[src]
impl Pow<UTerm> for u16
[src]impl<U, B> Pow<UInt<U, B>> for u32 where
B: Bit,
U: Unsigned,
[src]
impl<U, B> Pow<UInt<U, B>> for u32 where
B: Bit,
U: Unsigned,
[src]impl<U, B> Pow<UInt<U, B>> for i16 where
B: Bit,
U: Unsigned,
[src]
impl<U, B> Pow<UInt<U, B>> for i16 where
B: Bit,
U: Unsigned,
[src]impl Pow<UTerm> for isize
[src]
impl Pow<UTerm> for isize
[src]impl<U> Pow<NInt<U>> for f32 where
U: Unsigned + NonZero,
[src]
impl<U> Pow<NInt<U>> for f32 where
U: Unsigned + NonZero,
[src]impl<U> Pow<PInt<U>> for f32 where
U: Unsigned + NonZero,
[src]
impl<U> Pow<PInt<U>> for f32 where
U: Unsigned + NonZero,
[src]impl Pow<UTerm> for i8
[src]
impl Pow<UTerm> for i8
[src]impl<U, B> Pow<UInt<U, B>> for i32 where
B: Bit,
U: Unsigned,
[src]
impl<U, B> Pow<UInt<U, B>> for i32 where
B: Bit,
U: Unsigned,
[src]impl<U, B> Pow<UInt<U, B>> for f32 where
B: Bit,
U: Unsigned,
[src]
impl<U, B> Pow<UInt<U, B>> for f32 where
B: Bit,
U: Unsigned,
[src]impl Pow<UTerm> for i16
[src]
impl Pow<UTerm> for i16
[src]impl<U, B> Pow<UInt<U, B>> for f64 where
B: Bit,
U: Unsigned,
[src]
impl<U, B> Pow<UInt<U, B>> for f64 where
B: Bit,
U: Unsigned,
[src]impl<U> Pow<NInt<U>> for f64 where
U: Unsigned + NonZero,
[src]
impl<U> Pow<NInt<U>> for f64 where
U: Unsigned + NonZero,
[src]impl<U> Pow<PInt<U>> for u64 where
U: Unsigned + NonZero,
[src]
impl<U> Pow<PInt<U>> for u64 where
U: Unsigned + NonZero,
[src]impl<U> Pow<PInt<U>> for f64 where
U: Unsigned + NonZero,
[src]
impl<U> Pow<PInt<U>> for f64 where
U: Unsigned + NonZero,
[src]impl<U> Pow<PInt<U>> for u8 where
U: Unsigned + NonZero,
[src]
impl<U> Pow<PInt<U>> for u8 where
U: Unsigned + NonZero,
[src]impl<U> Pow<PInt<U>> for isize where
U: Unsigned + NonZero,
[src]
impl<U> Pow<PInt<U>> for isize where
U: Unsigned + NonZero,
[src]impl Pow<UTerm> for f64
[src]
impl Pow<UTerm> for f64
[src]impl<U> Pow<PInt<U>> for u32 where
U: Unsigned + NonZero,
[src]
impl<U> Pow<PInt<U>> for u32 where
U: Unsigned + NonZero,
[src]impl Pow<UTerm> for i64
[src]
impl Pow<UTerm> for i64
[src]impl Pow<UTerm> for u8
[src]
impl Pow<UTerm> for u8
[src]impl<U, B> Pow<UInt<U, B>> for i8 where
B: Bit,
U: Unsigned,
[src]
impl<U, B> Pow<UInt<U, B>> for i8 where
B: Bit,
U: Unsigned,
[src]impl Pow<UTerm> for u64
[src]
impl Pow<UTerm> for u64
[src]impl<U> Pow<PInt<U>> for i32 where
U: Unsigned + NonZero,
[src]
impl<U> Pow<PInt<U>> for i32 where
U: Unsigned + NonZero,
[src]impl<U> Pow<PInt<U>> for i16 where
U: Unsigned + NonZero,
[src]
impl<U> Pow<PInt<U>> for i16 where
U: Unsigned + NonZero,
[src]impl Pow<UTerm> for f32
[src]
impl Pow<UTerm> for f32
[src]impl<U, B> Pow<UInt<U, B>> for u64 where
B: Bit,
U: Unsigned,
[src]
impl<U, B> Pow<UInt<U, B>> for u64 where
B: Bit,
U: Unsigned,
[src]impl<U, B> Pow<UInt<U, B>> for u16 where
B: Bit,
U: Unsigned,
[src]
impl<U, B> Pow<UInt<U, B>> for u16 where
B: Bit,
U: Unsigned,
[src]impl<U> Pow<PInt<U>> for usize where
U: Unsigned + NonZero,
[src]
impl<U> Pow<PInt<U>> for usize where
U: Unsigned + NonZero,
[src]impl Pow<UTerm> for i32
[src]
impl Pow<UTerm> for i32
[src]impl Pow<UTerm> for u32
[src]
impl Pow<UTerm> for u32
[src]impl<U, B> Pow<UInt<U, B>> for usize where
B: Bit,
U: Unsigned,
[src]
impl<U, B> Pow<UInt<U, B>> for usize where
B: Bit,
U: Unsigned,
[src]impl<U> Pow<PInt<U>> for i8 where
U: Unsigned + NonZero,
[src]
impl<U> Pow<PInt<U>> for i8 where
U: Unsigned + NonZero,
[src]impl<U, B> Pow<UInt<U, B>> for u8 where
B: Bit,
U: Unsigned,
[src]
impl<U, B> Pow<UInt<U, B>> for u8 where
B: Bit,
U: Unsigned,
[src]impl<U> Pow<PInt<U>> for u16 where
U: Unsigned + NonZero,
[src]
impl<U> Pow<PInt<U>> for u16 where
U: Unsigned + NonZero,
[src]impl Pow<Z0> for isize
[src]
impl Pow<Z0> for isize
[src]impl<U, B> Pow<UInt<U, B>> for i64 where
B: Bit,
U: Unsigned,
[src]
impl<U, B> Pow<UInt<U, B>> for i64 where
B: Bit,
U: Unsigned,
[src]impl<U> Pow<PInt<U>> for i64 where
U: Unsigned + NonZero,
[src]
impl<U> Pow<PInt<U>> for i64 where
U: Unsigned + NonZero,
[src]impl<U, B> Pow<UInt<U, B>> for isize where
B: Bit,
U: Unsigned,
[src]
impl<U, B> Pow<UInt<U, B>> for isize where
B: Bit,
U: Unsigned,
[src]impl Pow<Z0> for usize
[src]
impl Pow<Z0> for usize
[src]impl Pow<UTerm> for usize
[src]
impl Pow<UTerm> for usize
[src]Implementors
impl<U> Pow<NInt<UInt<U, B0>>> for NInt<UInt<UTerm, B1>> where
U: Unsigned,
[src]
impl<U> Pow<NInt<UInt<U, B0>>> for NInt<UInt<UTerm, B1>> where
U: Unsigned,
[src](-1)^N = 1 if N is even
impl<U> Pow<NInt<UInt<U, B1>>> for NInt<UInt<UTerm, B1>> where
U: Unsigned,
[src]
impl<U> Pow<NInt<UInt<U, B1>>> for NInt<UInt<UTerm, B1>> where
U: Unsigned,
[src](-1)^N = -1 if N is odd
impl<Ul, Ur> Pow<PInt<UInt<Ur, B0>>> for NInt<Ul> where
Ul: Unsigned + NonZero + Pow<UInt<Ur, B0>>,
Ur: Unsigned,
<Ul as Pow<UInt<Ur, B0>>>::Output: Unsigned,
<Ul as Pow<UInt<Ur, B0>>>::Output: NonZero,
[src]
impl<Ul, Ur> Pow<PInt<UInt<Ur, B0>>> for NInt<Ul> where
Ul: Unsigned + NonZero + Pow<UInt<Ur, B0>>,
Ur: Unsigned,
<Ul as Pow<UInt<Ur, B0>>>::Output: Unsigned,
<Ul as Pow<UInt<Ur, B0>>>::Output: NonZero,
[src]N(Ul)^P(Ur) = P(Ul^Ur) if Ur is even
impl<Ul, Ur> Pow<PInt<UInt<Ur, B1>>> for NInt<Ul> where
Ul: Unsigned + NonZero + Pow<UInt<Ur, B1>>,
Ur: Unsigned,
<Ul as Pow<UInt<Ur, B1>>>::Output: Unsigned,
<Ul as Pow<UInt<Ur, B1>>>::Output: NonZero,
[src]
impl<Ul, Ur> Pow<PInt<UInt<Ur, B1>>> for NInt<Ul> where
Ul: Unsigned + NonZero + Pow<UInt<Ur, B1>>,
Ur: Unsigned,
<Ul as Pow<UInt<Ur, B1>>>::Output: Unsigned,
<Ul as Pow<UInt<Ur, B1>>>::Output: NonZero,
[src]N(Ul)^P(Ur) = N(Ul^Ur) if Ur is odd