Optimize doubling: secp256k1 has no y=0 point #120
pull sipa wants to merge 2 commits into bitcoin-core:master from sipa:optimdbl changing 1 files +7 −12-
sipa commented at 2:33 pm on November 28, 2014: contributorThis gives a 1.5% verification improvement when using the endomorphism, 2.3% improvement when not.
-
gmaxwell commented at 8:53 pm on November 28, 2014: contributor
Add a comment that the assigment in the if is intentional or otherwise we’re going to get bug reports for it. (or leave the original handling for that branch, … doesn’t it generate the same code?)
And yes, our curve has no point of order 2, so this must be safe.
My chat backscroll suggests you used a somewhat different argument, about -7 having a cube root mod p. I guess the whole argument goes something like:
“For some group element Q of curve E, if 2Q = Infinity, thus Q+Q = Q + -Q, thus Q = -Q, which means that Q.{x,y} = Q.{x,-y}, so this could only be true if there is some point on the curve with y=0, which is only true there exists a cube root of […]”.
Might be useful to include the argument lest someone reviewing the code think it was just forgotten. :)
-
Optimize doubling: secp256k1 has no y=0 point f7dc1c6513
-
Explain why no y=0 check is necessary for doubling
Explanation suggested by Greg Maxwell.
-
sipa force-pushed on Nov 28, 2014
-
sipa commented at 9:20 pm on November 28, 2014: contributorFixed.
-
sipa cross-referenced this on Nov 28, 2014 from issue Avoid field inverse for r == x comparison by sipa
-
gmaxwell commented at 9:17 am on December 1, 2014: contributorACK. As semi-aside: Technically, do we even need the branch and return on infinity? just copy it over. Doen’t matter what the rest is… the common case is uh, not trying to double infinities. :P The branch should be perfectly predicted, so it may not matter at all though.
-
sipa commented at 9:48 am on December 1, 2014: contributorI tried not branching and just setting infinity correctly, which seemed slower. I can’t explain why, as this should not be a common case.
-
gmaxwell commented at 10:18 am on December 1, 2014: contributorSome test doing something dumb? Might just be a matter of stirring the alignment. No big deal in any case.
-
sipa merged this on Dec 1, 2014
-
sipa closed this on Dec 1, 2014
-
sipa referenced this in commit 0af5b47133 on Dec 1, 2014
This is a metadata mirror of the GitHub repository bitcoin-core/secp256k1. This site is not affiliated with GitHub. Content is generated from a GitHub metadata backup.
generated: 2025-01-24 13:15 UTC
More mirrored repositories can be found on mirror.b10c.me