logo
pub struct NonZeroScalar<C> where
    C: Curve + ScalarArithmetic
{ /* private fields */ }
This is supported on crate feature arithmetic only.
Expand description

Non-zero scalar type.

This type ensures that its value is not zero, ala core::num::NonZero*. To do this, the generic S type must impl both Default and ConstantTimeEq, with the requirement that S::default() returns 0.

In the context of ECC, it’s useful for ensuring that scalar multiplication cannot result in the point at infinity.

Implementations

Generate a random NonZeroScalar.

Create a NonZeroScalar from a scalar.

Decode a NonZeroScalar from a big endian-serialized field element.

Create a NonZeroScalar from a C::UInt.

Trait Implementations

Performs the conversion.

Returns a copy of the value. Read more

Performs copy-assignment from source. Read more

Select a or b according to choice. Read more

Conditionally assign other to self, according to choice. Read more

Conditionally swap self and other if choice == 1; otherwise, reassign both unto themselves. Read more

Determine if two items are equal. Read more

The resulting type after dereferencing.

Dereferences the value.

Formats the value using the given formatter. Read more

Performs the conversion.

Performs the conversion.

Performs the conversion.

Performs the conversion.

Performs the conversion.

Performs the conversion.

Performs the conversion.

Performs the conversion.

The associated error which can be returned from parsing.

Parses a string s to return a value of this type. Read more

Perform a scalar inversion

Field element type

Is this scalar greater than or equal to n / 2?

Formats the value using the given formatter.

The resulting type after applying the * operator.

Performs the * operation. Read more

The resulting type after applying the * operator.

Performs the * operation. Read more

The resulting type after applying the - operator.

Performs the unary - operation. Read more

Note: implementation is the same as ReduceNonZero

Perform a modular reduction, returning a field element.

Interpret the given byte array as a big endian integer and perform a modular reduction. Read more

Interpret the given byte array as a little endian integer and perform a modular reduction. Read more

This is supported on crate feature digest only.

Interpret a digest as a big endian integer and perform a modular reduction. Read more

This is supported on crate feature digest only.

Interpret a digest as a little endian integer and perform a modular reduction. Read more

Perform a modular reduction, returning a field element.

The type returned in the event of a conversion error.

Performs the conversion.

Formats the value using the given formatter.

Zero out this object from memory using Rust intrinsics which ensure the zeroization operation is not “optimized away” by the compiler. Read more

Auto Trait Implementations

Blanket Implementations

Gets the TypeId of self. Read more

Immutably borrows from an owned value. Read more

Mutably borrows from an owned value. Read more

Performs the conversion.

Performs the conversion.

Should always be Self

The resulting type after obtaining ownership.

Creates owned data from borrowed data, usually by cloning. Read more

🔬 This is a nightly-only experimental API. (toowned_clone_into)

Uses borrowed data to replace owned data, usually by cloning. Read more

Converts the given value to a String. Read more

The type returned in the event of a conversion error.

Performs the conversion.

The type returned in the event of a conversion error.

Performs the conversion.