diff options
author | lloyd <[email protected]> | 2010-12-07 21:54:50 +0000 |
---|---|---|
committer | lloyd <[email protected]> | 2010-12-07 21:54:50 +0000 |
commit | faf49459b7ba571c79c1d80ee6fcd43a91290438 (patch) | |
tree | 8a05b1d41a961ca72159a389444d1e61f5364ced | |
parent | ded7c106f5ea7c12aa81c4d286eaecc7dc6564ae (diff) |
Avoid a conditional in point multiplication
-rw-r--r-- | src/math/numbertheory/point_gfp.cpp | 18 |
1 files changed, 7 insertions, 11 deletions
diff --git a/src/math/numbertheory/point_gfp.cpp b/src/math/numbertheory/point_gfp.cpp index 04fde03df..5e42e37a5 100644 --- a/src/math/numbertheory/point_gfp.cpp +++ b/src/math/numbertheory/point_gfp.cpp @@ -306,17 +306,14 @@ PointGFp operator*(const BigInt& scalar, const PointGFp& point) const size_t window_size = 4; - std::vector<PointGFp> Ps((1 << window_size) - 1); - Ps[0] = point; + std::vector<PointGFp> Ps(1 << window_size); + Ps[0] = PointGFp(curve); + Ps[1] = point; - for(size_t i = 1; i != Ps.size(); ++i) + for(size_t i = 2; i != Ps.size(); ++i) { Ps[i] = Ps[i-1]; - - if(i % 1 == 1) - Ps[i].mult2(ws); - else - Ps[i].add(Ps[0], ws); + Ps[i].add(point, ws); } PointGFp H(curve); // create as zero @@ -330,8 +327,7 @@ PointGFp operator*(const BigInt& scalar, const PointGFp& point) const u32bit nibble = scalar.get_substring(bits_left - window_size, window_size); - if(nibble) - H.add(Ps[nibble-1], ws); + H.add(Ps[nibble], ws); bits_left -= window_size; } @@ -340,7 +336,7 @@ PointGFp operator*(const BigInt& scalar, const PointGFp& point) { H.mult2(ws); if(scalar.get_bit(bits_left-1)) - H.add(Ps[0], ws); + H.add(point, ws); --bits_left; } |