Go to file
Daira Hopwood d74fbbcd01 Python 3 portability.
Signed-off-by: Daira Hopwood <daira@jacaranda.org>
2020-11-23 01:09:28 +00:00
Ep Update parameters for Pallas/Vesta. 2020-11-23 01:09:28 +00:00
Eq Update parameters for Pallas/Vesta. 2020-11-23 01:09:28 +00: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 Pallas/Vesta README. 2020-11-23 01:09:28 +00:00
amicable.sage Python 3 portability. 2020-11-23 01:09:28 +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 Update parameters for Pallas/Vesta. 2020-11-23 01:09:28 +00: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 Update parameters for Pallas/Vesta. 2020-11-23 01:09:28 +00:00
verify.sage verify.sage: make executable. 2020-09-26 21:43:46 +01:00

README.md

Pallas/Vesta 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 Pallas;
  • Eq : y^2 = x^3 + 5 over GF(q) of order p, called Vesta;

with

  • p = 2^254 + 45560315531419706090280762371685220353
  • q = 2^254 + 45560315531506369815346746415080538113

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);
  • twist security above 100 bits for Pallas.

Pallas/Vesta is the first cycle output by sage amicable.sage --sequential --requireisos --sortpq --ignoretwist --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.)

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.

The output of amicable.sage with the above options includes isogenies of degree 3, 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.