Skip to content

GRNADMASTERFUTHERCODETEACHERPRINCAPLE/PQC-Cheat-Sheet

 
 

Repository files navigation

Logo

The Post-Quantum Cryptopgraphy Cheat Sheets

A series of cheat sheets for the new post-quantum cryptography (PQC) algorithms and about picking the right one for your application.

Information

GitHub Latest Release) Github All Releases Github Latest Searches

Tech Stack

LaTeX

Table of Contents

  1. The PQC Cheat Sheet(s)
    1. Algorithms
    2. Working with and Interpreting the Cheat Sheet
    3. Target Audience and Objectives
  2. Preview
  3. Compiling the Source Files
  4. Credit and Further Reading
  5. Disclaimer

The PQC Cheat Sheet(s)

PQC Cheat Sheet

The cheat sheets are currently in DRAFT status and are still work in progress! They are still incomplete and likely contain mistakes. Feedback and corrections are appreciated!

No responsibility is taken for the correctness of the information contained in the document.

Algorithms

Signature: ML-DSA (CRYSTALS-DILITHIUM), Falcon, SLH-DSA (SHPINCS+), XMSS/XMSSMT, LMS/HSS

Encryption/KEM: ML-KEM (CRYSTALS-KYBER), BIKE, HQC, Classic McEliece, FrodoKEM

Working with and Interpreting the Cheat Sheet

The goal of this series of cheat sheets is to make it as easy as possible to figure out which algorithm to pick for a given use case. Algorithm ID cards break down algorithm parameter sets, their important values and performance characteristics. The cheat sheets are intended to help users primarily in technical roles, such as engineers, architects or software developers working with post-quantum cryptography.

The focus is to avoid giving specific numbers measured in bits, bytes or cycles as this makes makes comparing numbers across algorithms difficult. Instead, this complexity is simplified by only providing a color-coded number indicating the order of magnitude of each metric. Furthermore, an "Algorithm Overall Usability Score" is assigned to each algorithm. This score aims to make it visible at first glance how good of an overall package the algorithm offers (refer to the appendix for the definition of the score).

This approach prioritizes easy interpretation and comparability of metrics and in general quick informational gain over absolute precision of data -- remember this is a cheat sheet, not a standard! This document is not intended to replace the study of algorithm specifications. It just aims to point you in the right direction quickly.

The approach of focusing on orders of magnitude walks a fine line between treating too many things as "equal" and not simplifying things enough to be easy to read and compare. "In the same order of magnitude" usually refers to "equal up to a factor of at most 10", which is a very coarse way of comparing numbers. Treating metrics that differ by a factor of e.g. 9.9 as "equal" because 9.9 < 10 paints a distorted picture. In cryptography, factors of 5 or even 2 can make a significant difference in security or performance, both in theory and in practice. In order to still tease out the differences in metrics without throwing too many things together that actually differ significantly, this cheat sheet applies different scaling and "orders of magnitude" (i.e., not regarding base 10) for different metrics.

It turns out that for metrics measured in (kilo) CPU cycle counts, i.e. algorithm performance, "up to a factor of 5" is a scale that is granular enough to work out the differences between algorithms while maintaining easy comparability. Those cycle counts heavily depend on the CPU used during measurement, hence the numbers need to be taken with a grain of salt, even if given exactly and not in terms of orders of magnitude.

For signature and ciphertext sizes as well as key sizes, measuring numbers in kilobytes "up to a factor of 2" is well suited to work out the differences between algorithms while allowing for quick comparison. Specifically for signature public key sizes only, we offset the corresponding color coding by 5 orders of magnitude. This is because SLH-DSA has extremely small pubic keys compared to all other signature algorithms, which would extend the scale into negative numbers (e.g. for SLH-DSA-SHA2-128s, the public key has 32=2^5 bytes, which corresponds to an order of magnitude of -5 when measuring in orders of magnitude of base 2 and in kilobytes). This phenomenon of algorithm metrics spanning a very large range of orders of (base 2) magnitudes does not occur to this extent for encryption algorithms, making an offset unnecessary.

All values thus have a lower bound of 0. We do not limit the upper end of scales, but don't distinguish values greater than 10 anymore in terms of color coding. Please refer to the definitions in the cheat sheet for symbol explanations, color coding and interpretation of numeric values.

Target Audience and Objectives

The target audience are technical roles such as software developers, architects or engineers or simply anyone interested in cryptography and PQC. The cheat sheets aim to make it easier for them to select the right algorithm for their use cases, based on various different algorithm characteristics presented in a simplified form.

The main goal is quick information, not absolute precision! The cheat sheets are not intended to replace studying more specific specifications in a second step!

Preview

Page 1 Page 2 Page 3 Page 4 Page 5 Page 6 Page 7 Page 8 Page 9 Page 10 Page 11 Page 12 Page 13 Page 14 Page 15 Page 16 Page 17 Page 18 Page 19 Page 21 Page 21 Page 22

Compiling the Source Files

Use LuaLaTeX for compiling the .tex files (PQC-Cheat-Sheet.tex is the root document). You may need to install the provided fonts in your system first. Set the -shell-escape option in order to reconvert the *.svg graphics after any change during compilation (this requires Inkscape to be installed).

Credits and Further Reading

TBD


Disclaimer

No responsibility is taken for the correctness of the information in this cheat sheet.

About

A cheat sheet for the new post quantum cryptography algorithms

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • TeX 100.0%