Go to file
Daira Hopwood a35294b64f Updates for Pallas/Vesta.
Use `sage amicable.sage --sequential --requireisos --sortpq --ignoretwist --nearpowerof2 255 32` to generate the Pallas/Vesta cycle.

Signed-off-by: Daira Hopwood <daira@jacaranda.org>
2020-11-19 19:54:53 +00:00
Ep Change to quadratic twist-secure curve. 2019-09-17 11:28:59 +01:00
Eq Change to quadratic twist-secure curve. 2019-09-17 11:28:59 +01:00
.gitignore Adapt for Tweedledum/Tweedledee. 2019-09-08 16:23:19 +01:00
LICENSE Add LICENSE and .gitignore. Also fix the curve equation. 2017-11-02 06:16:58 +00:00
README.md amicable.sage: various updates 2020-09-26 21:43:31 +01:00
amicable.sage Updates for Pallas/Vesta. 2020-11-19 19:54:53 +00:00
animation-p.webm Add animations. 2020-06-23 16:28:05 +01:00
animation-q.webm Add animations. 2020-06-23 16:28:05 +01:00
animation.sh checksumsets.py: add support for generating animations. 2020-06-23 16:27:52 +01:00
checksumsets.py checksumsets.py: the fields of State can be just int, not Optional[int]. 2020-08-24 12:56:05 +01:00
clean.sh Add clean.sh . 2019-09-17 11:14:04 +01:00
injectivitylemma.py injectivitylemma.py: output information that I used in a slide in my ZK Study Club presentation. 2020-11-19 19:52:22 +00:00
run.sh Adapt for Tweedledum/Tweedledee. 2019-09-08 16:23:19 +01:00
verify.sage verify.sage: make executable. 2020-09-26 21:43:46 +01:00

README.md

Tweedledum/Tweedledee supporting evidence

This repository contains supporting evidence that the amicable pair of prime-order curves:

  • Ep : y^2 = x^3 + 5 over GF(p) of order q, called Tweedledum;
  • Eq : y^2 = x^3 + 5 over GF(q) of order p, called Tweedledee;

with

  • p = 2^254 + 4707489545178046908921067385359695873
  • q = 2^254 + 4707489544292117082687961190295928833

satisfy some of the SafeCurves criteria.

The criteria that are not satisfied are, in summary:

  • large-magnitude CM discriminant (both curves have CM discriminant of absolute value 3, as a consequence of how they were constructed);
  • completeness (complete formulae are possible, but not according to the Safe curves criterion);
  • ladder support (not possible for prime-order curves);
  • Elligator 2 support (indistinguishability is possible using Elligator Squared, but not using Elligator 2).

Tweedledum/Tweedledee is the first cycle output by sage amicable.sage --sequential --nearpowerof2 255 32.

(The --sequential option makes the output completely deterministic and so resolves ambiguity about which result is "first". For exploratory searches it is faster not to use --sequential.)

The cycle we call Tweedledum/Tweedledee has changed from the initial (September 2019) draft of the Halo paper.

Prerequisites:

  • apt-get install sagemath
  • pip install sortedcontainers

Run sage verify.sage Ep and sage verify.sage Eq; or ./run.sh to run both and also print out the results.

When amicable.sage is used with the --isogenies option, the output includes isogenies suitable for use with the "simplified SWU" method for hashing to an elliptic curve. This is based on code from Appendix A of Wahby and Boneh 2019. Note that simplified SWU is not necessarily the preferred method to hash to a given curve. In particular it probably is not for the Tweedle curves; they only have suitable isogenies of degree 23, which is rather large.