Skip to content

Commit

Permalink
Merge pull request #226 from ebfull/faster-equality
Browse files Browse the repository at this point in the history
Check the equality of `EdwardsPoint`s in the projective coordinates
  • Loading branch information
hdevalence committed May 21, 2019
2 parents 076f326 + d71b665 commit 23ca520
Showing 1 changed file with 8 additions and 1 deletion.
9 changes: 8 additions & 1 deletion src/edwards.rs
Expand Up @@ -394,7 +394,14 @@ impl ConditionallySelectable for EdwardsPoint {

impl ConstantTimeEq for EdwardsPoint {
fn ct_eq(&self, other: &EdwardsPoint) -> Choice {
self.compress().ct_eq(&other.compress())
// We would like to check that the point (X/Z, Y/Z) is equal to
// the point (X'/Z', Y'/Z') without converting into affine
// coordinates (x, y) and (x', y'), which requires two inversions.
// We have that X = xZ and X' = x'Z'. Thus, x = x' is equivalent to
// (xZ)Z' = (x'Z')Z, and similarly for the y-coordinate.

(&self.X * &other.Z).ct_eq(&(&other.X * &self.Z))
& (&self.Y * &other.Z).ct_eq(&(&other.Y * &self.Z))
}
}

Expand Down

0 comments on commit 23ca520

Please sign in to comment.