pub trait ReduceNonZero<UInt: Integer + ArrayEncoding>: Sized {
    // Required method
    fn from_uint_reduced_nonzero(n: UInt) -> Self;
}
Expand description

Modular reduction to a non-zero output.

This trait is primarily intended for use by curve implementations such as the k256 and p256 crates.

End users should use the Reduce impl on NonZeroScalar instead.

Required Methods§

source

fn from_uint_reduced_nonzero(n: UInt) -> Self

Perform a modular reduction, returning a field element.

Implementors§

source§

impl<C, I> ReduceNonZero<I> for NonZeroScalar<C>where C: Curve + ScalarArithmetic, I: Integer + ArrayEncoding, Scalar<C>: ReduceNonZero<I>,

impl ReduceNonZero<UInt<crypto_bigint::::uint::U256::{constant#0}>> for Scalar

impl ReduceNonZero<UInt<crypto_bigint::::uint::U512::{constant#0}>> for Scalar