pub struct EdwardsProjectivePoint<E: IsEllipticCurve>(/* private fields */);Implementations§
Source§impl<E: IsEllipticCurve + IsEdwards> EdwardsProjectivePoint<E>
impl<E: IsEllipticCurve + IsEdwards> EdwardsProjectivePoint<E>
Sourcepub fn new(
value: [FieldElement<E::BaseField>; 3],
) -> Result<Self, EllipticCurveError>
pub fn new( value: [FieldElement<E::BaseField>; 3], ) -> Result<Self, EllipticCurveError>
Creates an elliptic curve point giving the projective [x: y: z] coordinates.
Sourcepub fn x(&self) -> &FieldElement<E::BaseField>
pub fn x(&self) -> &FieldElement<E::BaseField>
Returns the x coordinate of the point.
Sourcepub fn y(&self) -> &FieldElement<E::BaseField>
pub fn y(&self) -> &FieldElement<E::BaseField>
Returns the y coordinate of the point.
Sourcepub fn z(&self) -> &FieldElement<E::BaseField>
pub fn z(&self) -> &FieldElement<E::BaseField>
Returns the z coordinate of the point.
Sourcepub fn coordinates(&self) -> &[FieldElement<E::BaseField>; 3]
pub fn coordinates(&self) -> &[FieldElement<E::BaseField>; 3]
Returns a tuple [x, y, z] with the coordinates of the point.
Trait Implementations§
Source§impl<E: Clone + IsEllipticCurve> Clone for EdwardsProjectivePoint<E>
impl<E: Clone + IsEllipticCurve> Clone for EdwardsProjectivePoint<E>
Source§fn clone(&self) -> EdwardsProjectivePoint<E>
fn clone(&self) -> EdwardsProjectivePoint<E>
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl<E: Debug + IsEllipticCurve> Debug for EdwardsProjectivePoint<E>
impl<E: Debug + IsEllipticCurve> Debug for EdwardsProjectivePoint<E>
Source§impl<E: IsEdwards> FromAffine<<E as IsEllipticCurve>::BaseField> for EdwardsProjectivePoint<E>
impl<E: IsEdwards> FromAffine<<E as IsEllipticCurve>::BaseField> for EdwardsProjectivePoint<E>
fn from_affine( x: FieldElement<E::BaseField>, y: FieldElement<E::BaseField>, ) -> Result<Self, EllipticCurveError>
Source§impl<E: IsEdwards> IsGroup for EdwardsProjectivePoint<E>
impl<E: IsEdwards> IsGroup for EdwardsProjectivePoint<E>
Source§fn neutral_element() -> Self
fn neutral_element() -> Self
Returns the point at infinity (neutral element) in projective coordinates.
§Safety
- The values
[0, 1, 1]are the canonical representation of the neutral element in the Edwards curve, meaning they are guaranteed to be a valid point. unwrap()is used because this point is known to be valid, so there is no need for additional runtime checks.
Source§fn operate_with(&self, other: &Self) -> Self
fn operate_with(&self, other: &Self) -> Self
Computes the addition of self and other using the Edwards curve addition formula.
This implementation follows Equation (5.38) from “Moonmath” (page 97).
§Safety
- The function assumes both
selfandotherare valid points on the curve. - The resulting coordinates are computed using a well-defined formula that maintains the elliptic curve invariants.
unwrap()is safe because the formula guarantees the result is valid.
Source§fn neg(&self) -> Self
fn neg(&self) -> Self
Returns the additive inverse of the projective point p
§Safety
- Negating the x-coordinate of a valid Edwards point results in another valid point.
unwrap()is safe because negation does not break the curve equation.
Source§fn is_neutral_element(&self) -> bool
fn is_neutral_element(&self) -> bool
Check if an element the neutral element.
Source§fn operate_with_self<T: IsUnsignedInteger>(&self, exponent: T) -> Self
fn operate_with_self<T: IsUnsignedInteger>(&self, exponent: T) -> Self
Applies the group operation
times times with itself
The operation can be addition or multiplication depending on
the notation of the particular group.Source§impl<E: IsEllipticCurve> PartialEq for EdwardsProjectivePoint<E>
impl<E: IsEllipticCurve> PartialEq for EdwardsProjectivePoint<E>
impl<E: IsEllipticCurve> Eq for EdwardsProjectivePoint<E>
Auto Trait Implementations§
impl<E> Freeze for EdwardsProjectivePoint<E>
impl<E> RefUnwindSafe for EdwardsProjectivePoint<E>
impl<E> Send for EdwardsProjectivePoint<E>
impl<E> Sync for EdwardsProjectivePoint<E>
impl<E> Unpin for EdwardsProjectivePoint<E>
impl<E> UnwindSafe for EdwardsProjectivePoint<E>
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more