選択できるのは25トピックまでです。 トピックは、先頭が英数字で、英数字とダッシュ('-')を使用した35文字以内のものにしてください。
 
 
 
Kris Kwiatkowski 40f4da2265 WIP 6年前
etc sike: algorithm implementation (#7) 6年前
internal/utils WIP 6年前
p503toolbox WIP 6年前
p751toolbox WIP 6年前
sidh WIP 6年前
sike makes GeneratePublicKey method of PrivateKey 6年前
.travis.yml makefile: improvements 6年前
LICENSE cln16sidh: add LICENSE text 7年前
Makefile WIP 6年前
README.md sike: algorithm implementation (#7) 6年前

README.md

p751sidh

Project provides a Go implementation of (ephemeral) supersingular isogeny Diffie-Hellman (SIDH) and supersingular isogeny key exchange (SIKE), as specified in SIDH-spec, PQC NIST Submission (Nov 30, 2017).

The implementation is intended for use on the amd64 architecture only -- no generic field arithmetic implementation is provided. Portions of the field arithmetic were ported from the Microsoft Research implementation.

The SIDH package does NOT implement key validation. It means that it should only be used for ephemeral DH. Each keypair should be used at most once.

If you feel that SIDH may be appropriate for you, consult your cryptographer.

Source code

Project provides following packages:

  • p751toolbox: P751 field arithmetic, curve computation and isogeny internal functions
  • sidh: Implementation of SIDH key agreement
  • sike: Implementation of SIKE PKE and KEM, based on sidh package

Testing

At development time following make targets may come handy:

  • make test : unit testing
  • make bench: benchmarking
  • make cover: produces code coverage as txt file (used by travis)

It is possible to add one of following postfixes to each of the targets above, in order to run tests specific to -p751toolbox, -sidh or -sike.

Acknowledgements

Special thanks to Craig Costello, Diego Aranha, and Deirdre Connolly for advice and discussion.