aboutsummaryrefslogtreecommitdiffstats
path: root/src/math/gfpmath/point_gfp.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/math/gfpmath/point_gfp.cpp')
-rw-r--r--src/math/gfpmath/point_gfp.cpp69
1 files changed, 24 insertions, 45 deletions
diff --git a/src/math/gfpmath/point_gfp.cpp b/src/math/gfpmath/point_gfp.cpp
index cf1e8a882..034289190 100644
--- a/src/math/gfpmath/point_gfp.cpp
+++ b/src/math/gfpmath/point_gfp.cpp
@@ -181,10 +181,31 @@ PointGFp& PointGFp::operator*=(const BigInt& scalar)
}
if(!H.is_zero()) // cannot convert if H == O
- *this = H.get_z_to_one();
- else
- *this = H;
+ {
+ /**
+ * Convert H to an equivalent point with z == 1, thus x and y
+ * correspond to their affine coordinates
+ */
+ if(H.coord_z != 1)
+ {
+ GFpElement point_x(curve.get_p(), H.coord_x);
+ GFpElement point_y(curve.get_p(), H.coord_y);
+ GFpElement point_z(curve.get_p(), H.coord_z);
+
+ // Converts to affine coordinates
+ GFpElement z = inverse(point_z);
+ GFpElement z2 = z * z;
+ z *= z2;
+ GFpElement x = point_x * z2;
+ GFpElement y = point_y * z;
+
+ H.coord_x = x.get_value();
+ H.coord_y = y.get_value();
+ H.coord_z = 1;
+ }
+ }
+ *this = H;
return *this;
}
@@ -237,48 +258,6 @@ PointGFp& PointGFp::mult2_in_place()
return *this;
}
-/**
-* returns a point equivalent to *this but were
-* Z has value one, i.e. x and y correspond to
-* their values in affine coordinates
-*/
-PointGFp PointGFp::get_z_to_one()
- {
- return PointGFp(*this).set_z_to_one();
- }
-
-/**
-* changes the representation of *this so that
-* Z has value one, i.e. x and y correspond to
-* their values in affine coordinates.
-* returns *this.
-*/
-const PointGFp& PointGFp::set_z_to_one()
- {
- if(coord_z.is_zero())
- throw Illegal_Transformation("cannot convert Z to one");
-
- if(coord_z != 1)
- {
- GFpElement point_x(curve.get_p(), coord_x);
- GFpElement point_y(curve.get_p(), coord_y);
- GFpElement point_z(curve.get_p(), coord_z);
-
- // Converts to affine coordinates
- GFpElement z = inverse(point_z);
- GFpElement z2 = z * z;
- z *= z2;
- GFpElement x = point_x * z2;
- GFpElement y = point_y * z;
-
- coord_x = x.get_value();
- coord_y = y.get_value();
- coord_z = 1;
- }
-
- return *this;
- }
-
BigInt PointGFp::get_affine_x() const
{
if(is_zero())