pairing_plus::bls12_381

Struct G1

Source
pub struct G1 { /* private fields */ }

Trait Implementations§

Source§

impl Clone for G1

Source§

fn clone(&self) -> G1

Returns a copy of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl CurveProjective for G1

Source§

type Engine = Bls12

Source§

type Scalar = Fr

Source§

type Base = Fq

Source§

type Affine = G1Affine

Source§

fn random<R: RngCore>(rng: &mut R) -> Self

Generate a random curve point.
Source§

fn zero() -> Self

Returns the additive identity.
Source§

fn one() -> Self

Returns a fixed generator of unknown exponent.
Source§

fn is_zero(&self) -> bool

Determines if this point is the point at infinity.
Source§

fn is_normalized(&self) -> bool

Checks if the point is already “normalized” so that cheap affine conversion is possible.
Source§

fn batch_normalization(v: &mut [Self])

Normalizes a slice of projective elements so that conversion to affine is cheap.
Source§

fn double(&mut self)

Doubles this element.
Source§

fn add_assign(&mut self, other: &Self)

Adds another element to this element.
Source§

fn add_assign_mixed(&mut self, other: &Self::Affine)

Adds an affine element to this element.
Source§

fn negate(&mut self)

Negates this element.
Source§

fn mul_assign<S: Into<<Self::Scalar as PrimeField>::Repr>>(&mut self, other: S)

Performs scalar multiplication of this element.
Source§

fn into_affine(&self) -> G1Affine

Converts this element into its affine representation.
Source§

fn recommended_wnaf_for_scalar( scalar: <Self::Scalar as PrimeField>::Repr, ) -> usize

Recommends a wNAF window table size given a scalar. Always returns a number between 2 and 22, inclusive.
Source§

fn recommended_wnaf_for_num_scalars(num_scalars: usize) -> usize

Recommends a wNAF window size given the number of scalars you intend to multiply a base by. Always returns a number between 2 and 22, inclusive.
Source§

fn as_tuple(&self) -> (&Fq, &Fq, &Fq)

Borrow references to the X, Y, and Z coordinates of this point.
Source§

unsafe fn as_tuple_mut(&mut self) -> (&mut Fq, &mut Fq, &mut Fq)

Borrow mutable references to the X, Y, and Z coordinates of this point. Unsafe, because incorrectly modifying the coordinates violates the guarantee that the point must be on the curve and in the correct subgroup.
Source§

fn sub_assign(&mut self, other: &Self)

Subtracts another element from this element.
Source§

fn sub_assign_mixed(&mut self, other: &Self::Affine)

Subtracts an affine element from this element
Source§

impl Debug for G1

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Default for G1

Source§

fn default() -> Self

Returns the “default value” for a type. Read more
Source§

impl Display for G1

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl From<G1> for G1Affine

Source§

fn from(p: G1) -> G1Affine

Converts to this type from the input type.
Source§

impl From<G1Affine> for G1

Source§

fn from(p: G1Affine) -> G1

Converts to this type from the input type.
Source§

impl PartialEq for G1

Source§

fn eq(&self, other: &G1) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl SerDes for G1

Source§

fn serialize<W: Write>(&self, writer: &mut W, compressed: bool) -> Result<()>

Convert a G1 point to a blob.

Source§

fn deserialize<R: Read>(reader: &mut R, compressed: bool) -> Result<Self>

Deserialize a G1 element from a blob. Returns an error if deserialization fails.

Source§

impl Zeroize for G1

Source§

fn zeroize(&mut self)

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

impl Copy for G1

Source§

impl Eq for G1

Auto Trait Implementations§

§

impl Freeze for G1

§

impl RefUnwindSafe for G1

§

impl Send for G1

§

impl Sync for G1

§

impl Unpin for G1

§

impl UnwindSafe for G1

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<PtT, X> HashToCurve<X> for PtT
where PtT: ClearH + IsogenyMap + OSSWUMap, <PtT as CurveProjective>::Base: FromRO, X: ExpandMsg,

Source§

fn hash_to_curve<Mt, Dt>(msg: Mt, dst: Dt) -> PtT
where Mt: AsRef<[u8]>, Dt: AsRef<[u8]>,

Random oracle
Source§

fn encode_to_curve<Mt, Dt>(msg: Mt, dst: Dt) -> PtT
where Mt: AsRef<[u8]>, Dt: AsRef<[u8]>,

Injective encoding
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

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

fn clone_into(&self, target: &mut T)

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

impl<T> ToString for T
where T: Display + ?Sized,

Source§

default fn to_string(&self) -> String

Converts the given value to a String. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.