pairing_plus::bls12_381

Struct G2

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

Trait Implementations§

Source§

impl Clone for G2

Source§

fn clone(&self) -> G2

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 G2

Source§

type Engine = Bls12

Source§

type Scalar = Fr

Source§

type Base = Fq2

Source§

type Affine = G2Affine

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) -> G2Affine

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) -> (&Fq2, &Fq2, &Fq2)

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

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

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 G2

Source§

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

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

impl Default for G2

Source§

fn default() -> Self

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

impl Display for G2

Source§

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

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

impl From<G2> for G2Affine

Source§

fn from(p: G2) -> G2Affine

Converts to this type from the input type.
Source§

impl From<G2Affine> for G2

Source§

fn from(p: G2Affine) -> G2

Converts to this type from the input type.
Source§

impl PartialEq for G2

Source§

fn eq(&self, other: &G2) -> 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 G2

Source§

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

Convert a G2 point to a blob.

Source§

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

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

Source§

impl Zeroize for G2

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 G2

Source§

impl Eq for G2

Auto Trait Implementations§

§

impl Freeze for G2

§

impl RefUnwindSafe for G2

§

impl Send for G2

§

impl Sync for G2

§

impl Unpin for G2

§

impl UnwindSafe for G2

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.