[][src]Struct dusk_bls12_381::G2Affine

pub struct G2Affine { /* fields omitted */ }

This is an element of $\mathbb{G}_2$ represented in the affine coordinate space. It is ideal to keep elements in this representation to reduce memory usage and improve performance through the use of mixed curve model arithmetic.

Values of G2Affine are guaranteed to be in the $q$-order subgroup unless an "unchecked" API was misused.

Methods

impl G2Affine[src]

pub fn identity() -> G2Affine[src]

Returns the identity of the group: the point at infinity.

pub fn generator() -> G2Affine[src]

Returns a fixed generator of the group. See notes::design for how this generator is chosen.

pub fn to_compressed(&self) -> [u8; 96][src]

Serializes this element into compressed form. See notes::serialization for details about how group elements are serialized.

pub fn to_uncompressed(&self) -> [u8; 192][src]

Serializes this element into uncompressed form. See notes::serialization for details about how group elements are serialized.

pub fn from_uncompressed(bytes: &[u8; 192]) -> CtOption<Self>[src]

Attempts to deserialize an uncompressed element. See notes::serialization for details about how group elements are serialized.

pub fn from_uncompressed_unchecked(bytes: &[u8; 192]) -> CtOption<Self>[src]

Attempts to deserialize an uncompressed element, not checking if the element is on the curve and not checking if it is in the correct subgroup. This is dangerous to call unless you trust the bytes you are reading; otherwise, API invariants may be broken. Please consider using from_uncompressed() instead.

pub fn from_compressed(bytes: &[u8; 96]) -> CtOption<Self>[src]

Attempts to deserialize a compressed element. See notes::serialization for details about how group elements are serialized.

pub fn from_compressed_unchecked(bytes: &[u8; 96]) -> CtOption<Self>[src]

Attempts to deserialize an uncompressed element, not checking if the element is in the correct subgroup. This is dangerous to call unless you trust the bytes you are reading; otherwise, API invariants may be broken. Please consider using from_compressed() instead.

pub fn is_identity(&self) -> Choice[src]

Returns true if this element is the identity (the point at infinity).

pub fn is_torsion_free(&self) -> Choice[src]

Returns true if this point is free of an $h$-torsion component, and so it exists within the $q$-order subgroup $\mathbb{G}_2$. This should always return true unless an "unchecked" API was used.

pub fn is_on_curve(&self) -> Choice[src]

Returns true if this point is on the curve. This should always return true unless an "unchecked" API was used.

Trait Implementations

impl<'a, 'b> Add<&'b G2Affine> for &'a G2Projective[src]

type Output = G2Projective

The resulting type after applying the + operator.

impl<'b> Add<&'b G2Affine> for G2Projective[src]

type Output = G2Projective

The resulting type after applying the + operator.

impl<'a, 'b> Add<&'b G2Projective> for &'a G2Affine[src]

type Output = G2Projective

The resulting type after applying the + operator.

impl<'b> Add<&'b G2Projective> for G2Affine[src]

type Output = G2Projective

The resulting type after applying the + operator.

impl<'a> Add<G2Affine> for &'a G2Projective[src]

type Output = G2Projective

The resulting type after applying the + operator.

impl Add<G2Affine> for G2Projective[src]

type Output = G2Projective

The resulting type after applying the + operator.

impl<'a> Add<G2Projective> for &'a G2Affine[src]

type Output = G2Projective

The resulting type after applying the + operator.

impl Add<G2Projective> for G2Affine[src]

type Output = G2Projective

The resulting type after applying the + operator.

impl<'b> AddAssign<&'b G2Affine> for G2Projective[src]

impl AddAssign<G2Affine> for G2Projective[src]

impl Clone for G2Affine[src]

impl ConditionallySelectable for G2Affine[src]

impl ConstantTimeEq for G2Affine[src]

impl Copy for G2Affine[src]

impl Debug for G2Affine[src]

impl Default for G2Affine[src]

impl<'de> Deserialize<'de> for G2Affine[src]

impl Eq for G2Affine[src]

impl<'a> From<&'a G2Affine> for G2Projective[src]

impl<'a> From<&'a G2Projective> for G2Affine[src]

impl From<G2Affine> for G2Projective[src]

impl From<G2Affine> for G2Prepared[src]

impl From<G2Projective> for G2Affine[src]

impl<'a, 'b> Mul<&'b Scalar> for &'a G2Affine[src]

type Output = G2Projective

The resulting type after applying the * operator.

impl<'b> Mul<&'b Scalar> for G2Affine[src]

type Output = G2Projective

The resulting type after applying the * operator.

impl<'a> Mul<Scalar> for &'a G2Affine[src]

type Output = G2Projective

The resulting type after applying the * operator.

impl Mul<Scalar> for G2Affine[src]

type Output = G2Projective

The resulting type after applying the * operator.

impl<'a> Neg for &'a G2Affine[src]

type Output = G2Affine

The resulting type after applying the - operator.

impl Neg for G2Affine[src]

type Output = G2Affine

The resulting type after applying the - operator.

impl PartialEq<G2Affine> for G2Affine[src]

impl Serialize for G2Affine[src]

impl<'a, 'b> Sub<&'b G2Affine> for &'a G2Projective[src]

type Output = G2Projective

The resulting type after applying the - operator.

impl<'b> Sub<&'b G2Affine> for G2Projective[src]

type Output = G2Projective

The resulting type after applying the - operator.

impl<'a, 'b> Sub<&'b G2Projective> for &'a G2Affine[src]

type Output = G2Projective

The resulting type after applying the - operator.

impl<'b> Sub<&'b G2Projective> for G2Affine[src]

type Output = G2Projective

The resulting type after applying the - operator.

impl<'a> Sub<G2Affine> for &'a G2Projective[src]

type Output = G2Projective

The resulting type after applying the - operator.

impl Sub<G2Affine> for G2Projective[src]

type Output = G2Projective

The resulting type after applying the - operator.

impl<'a> Sub<G2Projective> for &'a G2Affine[src]

type Output = G2Projective

The resulting type after applying the - operator.

impl Sub<G2Projective> for G2Affine[src]

type Output = G2Projective

The resulting type after applying the - operator.

impl<'b> SubAssign<&'b G2Affine> for G2Projective[src]

impl SubAssign<G2Affine> for G2Projective[src]

Auto Trait Implementations

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

impl<T> ConditionallyNegatable for T where
    T: ConditionallySelectable,
    &'a T: for<'a> Neg,
    <&'a T as Neg>::Output == T, 
[src]

impl<T> DeserializeOwned for T where
    T: for<'de> Deserialize<'de>, 
[src]

impl<T> From<T> for T[src]

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

impl<T> ToOwned for T where
    T: Clone
[src]

type Owned = T

The resulting type after obtaining ownership.

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

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

The type returned in the event of a conversion error.

impl<V, T> VZip<V> for T where
    V: MultiLane<T>,