pub trait PrimeCurveAffine: GroupEncoding + Copy + Clone + Sized + Send + Sync + Debug + PartialEq + Eq + 'static + Neg<Output = Self> + Mul<Self::Scalar, Output = Self::Curve> + for<'r> Mul<&'r Self::Scalar, Output = Self::Curve> {
    type Scalar: PrimeField;
    type Curve: PrimeCurve<Affine = Self, Scalar = Self::Scalar>;

    // Required methods
    fn identity() -> Self;
    fn generator() -> Self;
    fn is_identity(&self) -> Choice;
    fn to_curve(&self) -> Self::Curve;
}
Expand description

Affine representation of an elliptic curve point guaranteed to be in the correct prime order subgroup.

Required Associated Types§

source

type Scalar: PrimeField

source

type Curve: PrimeCurve<Affine = Self, Scalar = Self::Scalar>

Required Methods§

source

fn identity() -> Self

Returns the additive identity.

source

fn generator() -> Self

Returns a fixed generator of unknown exponent.

source

fn is_identity(&self) -> Choice

Determines if this point represents the point at infinity; the additive identity.

source

fn to_curve(&self) -> Self::Curve

Converts this element to its curve representation.

Implementors§