Struct ProjectivePoint
pub struct ProjectivePoint { /* private fields */ }Expand description
A point on the secp256k1 curve in projective coordinates.
Implementations§
§impl ProjectivePoint
impl ProjectivePoint
pub const IDENTITY: ProjectivePoint
pub const IDENTITY: ProjectivePoint
Additive identity of the group: the point at infinity.
pub const GENERATOR: ProjectivePoint
pub const GENERATOR: ProjectivePoint
Base point of secp256k1.
pub const fn identity() -> ProjectivePoint
👎Deprecated since 0.10.2: use ProjectivePoint::IDENTITY instead
pub const fn identity() -> ProjectivePoint
ProjectivePoint::IDENTITY insteadReturns the additive identity of SECP256k1, also known as the “neutral element” or “point at infinity”.
pub fn generator() -> ProjectivePoint
👎Deprecated since 0.10.2: use ProjectivePoint::GENERATOR instead
pub fn generator() -> ProjectivePoint
ProjectivePoint::GENERATOR insteadReturns the base point of SECP256k1.
pub fn to_affine(&self) -> AffinePoint
pub fn to_affine(&self) -> AffinePoint
Returns the affine representation of this point.
pub fn double(&self) -> ProjectivePoint
pub fn double(&self) -> ProjectivePoint
Doubles this point.
pub fn endomorphism(&self) -> ProjectivePoint
pub fn endomorphism(&self) -> ProjectivePoint
Calculates SECP256k1 endomorphism: self * lambda.
pub fn eq_affine(&self, other: &AffinePoint) -> Choice
pub fn eq_affine(&self, other: &AffinePoint) -> Choice
Check whether self is equal to an affine point.
This is a lot faster than first converting self to an AffinePoint and then doing the
comparison. It is a little bit faster than converting other to a ProjectivePoint first.
Trait Implementations§
§impl Add<&AffinePoint> for &ProjectivePoint
impl Add<&AffinePoint> for &ProjectivePoint
§type Output = ProjectivePoint
type Output = ProjectivePoint
The resulting type after applying the
+ operator.§fn add(self, other: &AffinePoint) -> ProjectivePoint
fn add(self, other: &AffinePoint) -> ProjectivePoint
Performs the
+ operation. Read more§impl Add<&AffinePoint> for ProjectivePoint
impl Add<&AffinePoint> for ProjectivePoint
§type Output = ProjectivePoint
type Output = ProjectivePoint
The resulting type after applying the
+ operator.§fn add(self, other: &AffinePoint) -> ProjectivePoint
fn add(self, other: &AffinePoint) -> ProjectivePoint
Performs the
+ operation. Read more§impl Add<&ProjectivePoint> for &ProjectivePoint
impl Add<&ProjectivePoint> for &ProjectivePoint
§type Output = ProjectivePoint
type Output = ProjectivePoint
The resulting type after applying the
+ operator.§fn add(self, other: &ProjectivePoint) -> ProjectivePoint
fn add(self, other: &ProjectivePoint) -> ProjectivePoint
Performs the
+ operation. Read more§impl Add<&ProjectivePoint> for ProjectivePoint
impl Add<&ProjectivePoint> for ProjectivePoint
§type Output = ProjectivePoint
type Output = ProjectivePoint
The resulting type after applying the
+ operator.§fn add(self, other: &ProjectivePoint) -> ProjectivePoint
fn add(self, other: &ProjectivePoint) -> ProjectivePoint
Performs the
+ operation. Read more§impl Add<AffinePoint> for ProjectivePoint
impl Add<AffinePoint> for ProjectivePoint
§type Output = ProjectivePoint
type Output = ProjectivePoint
The resulting type after applying the
+ operator.§fn add(self, other: AffinePoint) -> ProjectivePoint
fn add(self, other: AffinePoint) -> ProjectivePoint
Performs the
+ operation. Read more§impl Add for ProjectivePoint
impl Add for ProjectivePoint
§type Output = ProjectivePoint
type Output = ProjectivePoint
The resulting type after applying the
+ operator.§fn add(self, other: ProjectivePoint) -> ProjectivePoint
fn add(self, other: ProjectivePoint) -> ProjectivePoint
Performs the
+ operation. Read more§impl AddAssign<&AffinePoint> for ProjectivePoint
impl AddAssign<&AffinePoint> for ProjectivePoint
§fn add_assign(&mut self, rhs: &AffinePoint)
fn add_assign(&mut self, rhs: &AffinePoint)
Performs the
+= operation. Read more§impl AddAssign<&ProjectivePoint> for ProjectivePoint
impl AddAssign<&ProjectivePoint> for ProjectivePoint
§fn add_assign(&mut self, rhs: &ProjectivePoint)
fn add_assign(&mut self, rhs: &ProjectivePoint)
Performs the
+= operation. Read more§impl AddAssign<AffinePoint> for ProjectivePoint
impl AddAssign<AffinePoint> for ProjectivePoint
§fn add_assign(&mut self, rhs: AffinePoint)
fn add_assign(&mut self, rhs: AffinePoint)
Performs the
+= operation. Read more§impl AddAssign for ProjectivePoint
impl AddAssign for ProjectivePoint
§fn add_assign(&mut self, rhs: ProjectivePoint)
fn add_assign(&mut self, rhs: ProjectivePoint)
Performs the
+= operation. Read more§impl<const N: usize> BatchNormalize<[ProjectivePoint; N]> for ProjectivePoint
impl<const N: usize> BatchNormalize<[ProjectivePoint; N]> for ProjectivePoint
§type Output = [<ProjectivePoint as Curve>::AffineRepr; N]
type Output = [<ProjectivePoint as Curve>::AffineRepr; N]
The output of the batch normalization; a container of affine points.
§fn batch_normalize(
points: &[ProjectivePoint; N],
) -> [<ProjectivePoint as Curve>::AffineRepr; N]
fn batch_normalize( points: &[ProjectivePoint; N], ) -> [<ProjectivePoint as Curve>::AffineRepr; N]
Perform a batched conversion to affine representation on a sequence of projective points
at an amortized cost that should be practically as efficient as a single conversion.
Internally, implementors should rely upon
InvertBatch.§impl Clone for ProjectivePoint
impl Clone for ProjectivePoint
§fn clone(&self) -> ProjectivePoint
fn clone(&self) -> ProjectivePoint
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 more§impl ConditionallySelectable for ProjectivePoint
impl ConditionallySelectable for ProjectivePoint
§fn conditional_select(
a: &ProjectivePoint,
b: &ProjectivePoint,
choice: Choice,
) -> ProjectivePoint
fn conditional_select( a: &ProjectivePoint, b: &ProjectivePoint, choice: Choice, ) -> ProjectivePoint
Source§fn conditional_assign(&mut self, other: &Self, choice: Choice)
fn conditional_assign(&mut self, other: &Self, choice: Choice)
Source§fn conditional_swap(a: &mut Self, b: &mut Self, choice: Choice)
fn conditional_swap(a: &mut Self, b: &mut Self, choice: Choice)
Conditionally swap
self and other if choice == 1; otherwise,
reassign both unto themselves. Read more§impl ConstantTimeEq for ProjectivePoint
impl ConstantTimeEq for ProjectivePoint
§impl Curve for ProjectivePoint
impl Curve for ProjectivePoint
§type AffineRepr = AffinePoint
type AffineRepr = AffinePoint
The affine representation for this elliptic curve.
§fn to_affine(&self) -> AffinePoint
fn to_affine(&self) -> AffinePoint
Converts this element into its affine representation.
§fn batch_normalize(p: &[Self], q: &mut [Self::AffineRepr])
fn batch_normalize(p: &[Self], q: &mut [Self::AffineRepr])
Converts a batch of projective elements into affine elements. This function will
panic if
p.len() != q.len().§impl Debug for ProjectivePoint
impl Debug for ProjectivePoint
§impl Default for ProjectivePoint
impl Default for ProjectivePoint
§fn default() -> ProjectivePoint
fn default() -> ProjectivePoint
Returns the “default value” for a type. Read more
§impl From<&AffinePoint> for ProjectivePoint
impl From<&AffinePoint> for ProjectivePoint
§fn from(p: &AffinePoint) -> ProjectivePoint
fn from(p: &AffinePoint) -> ProjectivePoint
Converts to this type from the input type.
§impl From<&ProjectivePoint> for AffinePoint
impl From<&ProjectivePoint> for AffinePoint
§fn from(p: &ProjectivePoint) -> AffinePoint
fn from(p: &ProjectivePoint) -> AffinePoint
Converts to this type from the input type.
§impl From<&PublicKey<Secp256k1>> for ProjectivePoint
impl From<&PublicKey<Secp256k1>> for ProjectivePoint
§fn from(public_key: &PublicKey<Secp256k1>) -> ProjectivePoint
fn from(public_key: &PublicKey<Secp256k1>) -> ProjectivePoint
Converts to this type from the input type.
§impl From<AffinePoint> for ProjectivePoint
impl From<AffinePoint> for ProjectivePoint
§fn from(p: AffinePoint) -> ProjectivePoint
fn from(p: AffinePoint) -> ProjectivePoint
Converts to this type from the input type.
§impl From<ProjectivePoint> for AffinePoint
impl From<ProjectivePoint> for AffinePoint
§fn from(p: ProjectivePoint) -> AffinePoint
fn from(p: ProjectivePoint) -> AffinePoint
Converts to this type from the input type.
§impl From<PublicKey<Secp256k1>> for ProjectivePoint
impl From<PublicKey<Secp256k1>> for ProjectivePoint
§fn from(public_key: PublicKey<Secp256k1>) -> ProjectivePoint
fn from(public_key: PublicKey<Secp256k1>) -> ProjectivePoint
Converts to this type from the input type.
§impl FromEncodedPoint<Secp256k1> for ProjectivePoint
impl FromEncodedPoint<Secp256k1> for ProjectivePoint
§fn from_encoded_point(
p: &EncodedPoint<<Secp256k1 as Curve>::FieldBytesSize>,
) -> CtOption<ProjectivePoint>
fn from_encoded_point( p: &EncodedPoint<<Secp256k1 as Curve>::FieldBytesSize>, ) -> CtOption<ProjectivePoint>
Deserialize the type this trait is impl’d on from an
EncodedPoint.§impl Group for ProjectivePoint
impl Group for ProjectivePoint
§fn random(rng: impl RngCore) -> ProjectivePoint
fn random(rng: impl RngCore) -> ProjectivePoint
Returns an element chosen uniformly at random from the non-identity elements of
this group. Read more
§fn identity() -> ProjectivePoint
fn identity() -> ProjectivePoint
Returns the additive identity, also known as the “neutral element”.
§fn generator() -> ProjectivePoint
fn generator() -> ProjectivePoint
Returns a fixed generator of the prime-order subgroup.
§fn is_identity(&self) -> Choice
fn is_identity(&self) -> Choice
Determines if this point is the identity.
§fn double(&self) -> ProjectivePoint
fn double(&self) -> ProjectivePoint
Doubles this element.
§impl GroupEncoding for ProjectivePoint
impl GroupEncoding for ProjectivePoint
§type Repr = GenericArray<u8, UInt<UInt<UInt<UInt<UInt<UInt<UTerm, B1>, B0>, B0>, B0>, B0>, B1>>
type Repr = GenericArray<u8, UInt<UInt<UInt<UInt<UInt<UInt<UTerm, B1>, B0>, B0>, B0>, B0>, B1>>
The encoding of group elements. Read more
§fn from_bytes(
bytes: &<ProjectivePoint as GroupEncoding>::Repr,
) -> CtOption<ProjectivePoint>
fn from_bytes( bytes: &<ProjectivePoint as GroupEncoding>::Repr, ) -> CtOption<ProjectivePoint>
Attempts to deserialize a group element from its encoding.
§fn from_bytes_unchecked(
bytes: &<ProjectivePoint as GroupEncoding>::Repr,
) -> CtOption<ProjectivePoint>
fn from_bytes_unchecked( bytes: &<ProjectivePoint as GroupEncoding>::Repr, ) -> CtOption<ProjectivePoint>
Attempts to deserialize a group element, not checking if the element is valid. Read more
§fn to_bytes(&self) -> <ProjectivePoint as GroupEncoding>::Repr
fn to_bytes(&self) -> <ProjectivePoint as GroupEncoding>::Repr
Converts this element into its byte encoding. This may or may not support
encoding the identity.
§impl<const N: usize> LinearCombinationExt<[(ProjectivePoint, Scalar); N]> for ProjectivePoint
impl<const N: usize> LinearCombinationExt<[(ProjectivePoint, Scalar); N]> for ProjectivePoint
§fn lincomb_ext(
points_and_scalars: &[(ProjectivePoint, Scalar); N],
) -> ProjectivePoint
fn lincomb_ext( points_and_scalars: &[(ProjectivePoint, Scalar); N], ) -> ProjectivePoint
Calculates
x1 * k1 + ... + xn * kn.§impl Mul<&Scalar> for &ProjectivePoint
impl Mul<&Scalar> for &ProjectivePoint
§type Output = ProjectivePoint
type Output = ProjectivePoint
The resulting type after applying the
* operator.§fn mul(self, other: &Scalar) -> ProjectivePoint
fn mul(self, other: &Scalar) -> ProjectivePoint
Performs the
* operation. Read more§impl Mul<&Scalar> for ProjectivePoint
impl Mul<&Scalar> for ProjectivePoint
§type Output = ProjectivePoint
type Output = ProjectivePoint
The resulting type after applying the
* operator.§fn mul(self, other: &Scalar) -> ProjectivePoint
fn mul(self, other: &Scalar) -> ProjectivePoint
Performs the
* operation. Read more§impl Mul<Scalar> for ProjectivePoint
impl Mul<Scalar> for ProjectivePoint
§type Output = ProjectivePoint
type Output = ProjectivePoint
The resulting type after applying the
* operator.§fn mul(self, other: Scalar) -> ProjectivePoint
fn mul(self, other: Scalar) -> ProjectivePoint
Performs the
* operation. Read more§impl MulAssign<&Scalar> for ProjectivePoint
impl MulAssign<&Scalar> for ProjectivePoint
§fn mul_assign(&mut self, rhs: &Scalar)
fn mul_assign(&mut self, rhs: &Scalar)
Performs the
*= operation. Read more§impl MulAssign<Scalar> for ProjectivePoint
impl MulAssign<Scalar> for ProjectivePoint
§fn mul_assign(&mut self, rhs: Scalar)
fn mul_assign(&mut self, rhs: Scalar)
Performs the
*= operation. Read more§impl MulByGenerator for ProjectivePoint
impl MulByGenerator for ProjectivePoint
§fn mul_by_generator(k: &Scalar) -> ProjectivePoint
fn mul_by_generator(k: &Scalar) -> ProjectivePoint
Calculates k * G, where G is the generator.
§impl<'a> Neg for &'a ProjectivePoint
impl<'a> Neg for &'a ProjectivePoint
§type Output = ProjectivePoint
type Output = ProjectivePoint
The resulting type after applying the
- operator.§fn neg(self) -> ProjectivePoint
fn neg(self) -> ProjectivePoint
Performs the unary
- operation. Read more§impl Neg for ProjectivePoint
impl Neg for ProjectivePoint
§type Output = ProjectivePoint
type Output = ProjectivePoint
The resulting type after applying the
- operator.§fn neg(self) -> ProjectivePoint
fn neg(self) -> ProjectivePoint
Performs the unary
- operation. Read more§impl PartialEq<AffinePoint> for ProjectivePoint
impl PartialEq<AffinePoint> for ProjectivePoint
§impl PartialEq<ProjectivePoint> for AffinePoint
impl PartialEq<ProjectivePoint> for AffinePoint
§impl PartialEq for ProjectivePoint
impl PartialEq for ProjectivePoint
§impl PrimeCurve for ProjectivePoint
impl PrimeCurve for ProjectivePoint
type Affine = AffinePoint
§impl Sub<&AffinePoint> for &ProjectivePoint
impl Sub<&AffinePoint> for &ProjectivePoint
§type Output = ProjectivePoint
type Output = ProjectivePoint
The resulting type after applying the
- operator.§fn sub(self, other: &AffinePoint) -> ProjectivePoint
fn sub(self, other: &AffinePoint) -> ProjectivePoint
Performs the
- operation. Read more§impl Sub<&AffinePoint> for ProjectivePoint
impl Sub<&AffinePoint> for ProjectivePoint
§type Output = ProjectivePoint
type Output = ProjectivePoint
The resulting type after applying the
- operator.§fn sub(self, other: &AffinePoint) -> ProjectivePoint
fn sub(self, other: &AffinePoint) -> ProjectivePoint
Performs the
- operation. Read more§impl Sub<&ProjectivePoint> for &ProjectivePoint
impl Sub<&ProjectivePoint> for &ProjectivePoint
§type Output = ProjectivePoint
type Output = ProjectivePoint
The resulting type after applying the
- operator.§fn sub(self, other: &ProjectivePoint) -> ProjectivePoint
fn sub(self, other: &ProjectivePoint) -> ProjectivePoint
Performs the
- operation. Read more§impl Sub<&ProjectivePoint> for ProjectivePoint
impl Sub<&ProjectivePoint> for ProjectivePoint
§type Output = ProjectivePoint
type Output = ProjectivePoint
The resulting type after applying the
- operator.§fn sub(self, other: &ProjectivePoint) -> ProjectivePoint
fn sub(self, other: &ProjectivePoint) -> ProjectivePoint
Performs the
- operation. Read more§impl Sub<AffinePoint> for ProjectivePoint
impl Sub<AffinePoint> for ProjectivePoint
§type Output = ProjectivePoint
type Output = ProjectivePoint
The resulting type after applying the
- operator.§fn sub(self, other: AffinePoint) -> ProjectivePoint
fn sub(self, other: AffinePoint) -> ProjectivePoint
Performs the
- operation. Read more§impl Sub for ProjectivePoint
impl Sub for ProjectivePoint
§type Output = ProjectivePoint
type Output = ProjectivePoint
The resulting type after applying the
- operator.§fn sub(self, other: ProjectivePoint) -> ProjectivePoint
fn sub(self, other: ProjectivePoint) -> ProjectivePoint
Performs the
- operation. Read more§impl SubAssign<&AffinePoint> for ProjectivePoint
impl SubAssign<&AffinePoint> for ProjectivePoint
§fn sub_assign(&mut self, rhs: &AffinePoint)
fn sub_assign(&mut self, rhs: &AffinePoint)
Performs the
-= operation. Read more§impl SubAssign<&ProjectivePoint> for ProjectivePoint
impl SubAssign<&ProjectivePoint> for ProjectivePoint
§fn sub_assign(&mut self, rhs: &ProjectivePoint)
fn sub_assign(&mut self, rhs: &ProjectivePoint)
Performs the
-= operation. Read more§impl SubAssign<AffinePoint> for ProjectivePoint
impl SubAssign<AffinePoint> for ProjectivePoint
§fn sub_assign(&mut self, rhs: AffinePoint)
fn sub_assign(&mut self, rhs: AffinePoint)
Performs the
-= operation. Read more§impl SubAssign for ProjectivePoint
impl SubAssign for ProjectivePoint
§fn sub_assign(&mut self, rhs: ProjectivePoint)
fn sub_assign(&mut self, rhs: ProjectivePoint)
Performs the
-= operation. Read more§impl<'a> Sum<&'a ProjectivePoint> for ProjectivePoint
impl<'a> Sum<&'a ProjectivePoint> for ProjectivePoint
§fn sum<I>(iter: I) -> ProjectivePointwhere
I: Iterator<Item = &'a ProjectivePoint>,
fn sum<I>(iter: I) -> ProjectivePointwhere
I: Iterator<Item = &'a ProjectivePoint>,
Takes an iterator and generates
Self from the elements by “summing up”
the items.§impl Sum for ProjectivePoint
impl Sum for ProjectivePoint
§fn sum<I>(iter: I) -> ProjectivePointwhere
I: Iterator<Item = ProjectivePoint>,
fn sum<I>(iter: I) -> ProjectivePointwhere
I: Iterator<Item = ProjectivePoint>,
Takes an iterator and generates
Self from the elements by “summing up”
the items.§impl ToEncodedPoint<Secp256k1> for ProjectivePoint
impl ToEncodedPoint<Secp256k1> for ProjectivePoint
§fn to_encoded_point(
&self,
compress: bool,
) -> EncodedPoint<<Secp256k1 as Curve>::FieldBytesSize>
fn to_encoded_point( &self, compress: bool, ) -> EncodedPoint<<Secp256k1 as Curve>::FieldBytesSize>
Serialize this value as a SEC1
EncodedPoint, optionally applying
point compression.§impl TryFrom<&ProjectivePoint> for PublicKey<Secp256k1>
impl TryFrom<&ProjectivePoint> for PublicKey<Secp256k1>
§impl TryFrom<ProjectivePoint> for PublicKey<Secp256k1>
impl TryFrom<ProjectivePoint> for PublicKey<Secp256k1>
impl Copy for ProjectivePoint
impl DefaultIsZeroes for ProjectivePoint
impl Eq for ProjectivePoint
impl PrimeGroup for ProjectivePoint
Auto Trait Implementations§
impl Freeze for ProjectivePoint
impl RefUnwindSafe for ProjectivePoint
impl Send for ProjectivePoint
impl Sync for ProjectivePoint
impl Unpin for ProjectivePoint
impl UnwindSafe for ProjectivePoint
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> ConditionallyNegatable for T
impl<T> ConditionallyNegatable for T
Source§fn conditional_negate(&mut self, choice: Choice)
fn conditional_negate(&mut self, choice: Choice)
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Checks if this value is equivalent to the given key. Read more
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