Skip to main content

Implemenation of same basic algorithms used in cryptography.

Project description

kryptools

Gerald Teschl Gerald.Teschl@univie.ac.at

This package was written for my course on cryptography. Consequently its intention is mainly educational, that is, to show how basic algorithms are implemented. In particular, you are welcome to read (and modify) the source. Any suggestions on how to make the code more readable or make it better are welcome. However, my main goal is to keep it simple and readability will be preferred over small speed improvements.

It does not require any external libraries.

The tools contained are:

  • number theory: sqrt modulo primes, Jacobi/Legendre symbol, Chinese Remainder Theorem, continued fractions, etc.

  • primes: Sieve of Erathostenes, primality tests, generation of random safe/strong primes

  • solvers for discrete logarithms (naive, Pollard rho, Shanks baby step/giant step, index calculus, quadratic sieve)

  • integer factorization (Fermat, Pollard p-1, Pollard rho, Lenstra's ECM, Dixon, basic quadratic sieve)

  • elliptic curves (Weierstrass form), group operations, order, discrete logarithms

  • linear algebra: Hermite normal form, Gram-Schmidt

  • lattices: Hadamard ratio, Babai rounding/nearest plane algorithm, lattice reduction (Lenstra-Lenstra-Lovaz)

  • Matrix: a class for Matrices (inverse, det, reduced echelon form, etc.)

  • Poly: a class for polynomials (division, modulo)

  • Zmod: a class for the ring of integers modulo an integer

Documentation can be found in the jupyter notebook (mostly done, but might not contain everything: use the force, read the source).

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

kryptools-0.9.8.tar.gz (32.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

kryptools-0.9.8-py3-none-any.whl (41.9 kB view details)

Uploaded Python 3

File details

Details for the file kryptools-0.9.8.tar.gz.

File metadata

  • Download URL: kryptools-0.9.8.tar.gz
  • Upload date:
  • Size: 32.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for kryptools-0.9.8.tar.gz
Algorithm Hash digest
SHA256 e17049ebd152138f84fbe37cc4e5c5dbe253fdf5db87c4fbf33e5c868f106341
MD5 8121aee937380d2cea11f0f7f3ecf930
BLAKE2b-256 971a4b8e6c861aefcaf6d4f94fcc8da319e1cbba7decd0d1c9a367f905396aaa

See more details on using hashes here.

File details

Details for the file kryptools-0.9.8-py3-none-any.whl.

File metadata

  • Download URL: kryptools-0.9.8-py3-none-any.whl
  • Upload date:
  • Size: 41.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for kryptools-0.9.8-py3-none-any.whl
Algorithm Hash digest
SHA256 5efbc0f9158bc7bd66f74ad96461079d5832ba191fc0d03b496487d4b9cd5fd3
MD5 442944eed73e88c289fe1fa4d0272e78
BLAKE2b-256 1a7cc1516aa6391947261551e32baa90899004376867869a03ebac2ac26efa06

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page