Thanks to visit codestin.com
Credit goes to github.com

Skip to content

MozirDmitriy/crypto

 
 

Repository files navigation

Miden Crypto

LICENSE test build RUST_VERSION CRATE

This crate contains cryptographic primitives used in Miden.

Authenticated Encryption

AEAD module provides authenticated encryption with associated data (AEAD) schemes. Currently, this includes:

  • AEAD-RPO: a scheme optimized for speed within SNARKs/STARKs. The design is based on the MonkeySpongeWrap construction and uses the RPO (Rescue Prime Optimized) permutation, creating an encryption scheme that is highly efficient when executed within zero-knowledge proof systems.
  • XChaCha20Poly1305: Extended nonce variant of ChaCha20Poly1305 providing both confidentiality and authenticity. This implementation offers significant performance advantages, showing approximately 100x faster encryption/decryption compared to the arithmetization-friendly alternative based on the RPO permutation.

Hash

Hash module provides a set of cryptographic hash functions which are used by the Miden protocol. Currently, these functions are:

  • BLAKE3 hash function with 256-bit, 192-bit, or 160-bit output. The 192-bit and 160-bit outputs are obtained by truncating the 256-bit output of the standard BLAKE3.
  • Keccak256 hash function with 256-bit.
  • RPO hash function with 256-bit output. This hash function is an algebraic hash function suitable for recursive STARKs.
  • RPX hash function with 256-bit output. Similar to RPO, this hash function is suitable for recursive STARKs but it is about 2x faster as compared to RPO.
  • Poseidon2 hash function with 256-bit output. Similar to RPO and RPX, this hash function is suitable for recursive STARKs but it is about 2x faster as compared to RPX.

For performance benchmarks of these hash functions and their comparison to other popular hash functions please see here.

Merkle

Merkle module provides a set of data structures related to Merkle trees. All these data structures are implemented using the RPO hash function described above. The data structures are:

  • MerkleStore: a collection of Merkle trees of different heights designed to efficiently store trees with common subtrees.
  • MerkleTree: a regular fully-balanced binary Merkle tree. The depth of this tree can be at most 64.
  • Mmr: a Merkle mountain range structure designed to function as an append-only log.
  • PartialMerkleTree: a partial view of a Merkle tree where some sub-trees may not be known. This is similar to a collection of Merkle paths all resolving to the same root. The length of the paths can be at most 64.
  • PartialMmr: a partial view of a Merkle mountain range structure.
  • SimpleSmt: a Sparse Merkle Tree (with no compaction), mapping 64-bit keys to 4-element values.
  • Smt: a Sparse Merkle tree (with compaction at depth 64), mapping 4-element keys to 4-element values.
  • LargeSmt: a large-scale Sparse Merkle tree backed by pluggable storage (e.g., RocksDB), optimized for datasets that exceed available memory.

The module also contains additional supporting components such as NodeIndex, MerklePath, SparseMerklePath, and MerkleError to assist with tree indexation, opening proofs, and reporting inconsistent arguments/state. SparseMerklePath provides a memory-efficient representation for Merkle paths with nodes representing empty subtrees.

Large Sparse Merkle Tree (LargeSmt)

LargeSmt (available only when the concurrent feature is enabled) is a sparse Merkle tree for very large key-value sets. It keeps only the upper part of the tree (depths 0–23) in memory for fast access while storing the deeper levels (depths 24–64) in external storage as fixed-size subtrees. This hybrid layout enables scaling beyond RAM limits while maintaining good performance for inserts, updates, and openings.

Key properties:

  • In-memory top: a flat array of inner nodes for depths 0–23.
  • Storage-backed bottom: Lower depths are organized in subtrees and stored via a storage interface. We provide an in-memory implementation and RocksDB backend behind a feature flag.
  • Supports batch construction and mutation sets for efficient batched updates.

When the rocksdb feature is enabled, LargeSmt can persist the lower subtrees and leaves to disk using RocksDB. On reopen, the in-memory top (depths 0–23) is reconstructed from persisted subtree roots. Without rocksdb, an in-memory storage implementation is available for testing and smaller datasets.

Signatures

DSA module provides a set of digital signature schemes supported by default in the Miden VM. Currently, these schemes are:

  • ECDSA k256: Elliptic Curve Digital Signature Algorithm using the k256 curve (also known as secp256k1) using Keccak to hash messages. This is a widely adopted signature scheme known for its compact key and signature sizes, making it efficient for storage and transmission.
  • RPO Falcon512: a variant of the Falcon signature scheme. This variant differs from the standard in that instead of using SHAKE256 hash function in the hash-to-point algorithm we use RPO256. This makes the signature more efficient to verify in Miden VM. Another point of difference is with respect to the signing process, which is deterministic in our case.

For the above signatures, key generation, signing, and signature verification are available for both std and no_std contexts (see crate features below). However, in no_std context, the user is responsible for supplying the key generation and signing procedures with a random number generator.

Key Exchange

ECDH module provides elliptic curve key exchange algorithms for secure key agreement. Implementations in this module make use of ephemeral keys for a "sealed box" approach where the sender generates an ephemeral secret key, derives a shared secret with the receiver's static public key, and includes the ephemeral public key alongside the encrypted message. This design enables secure communication without requiring prior interaction between parties. Currently, the module includes the following implementations:

  • ECDH k256: Elliptic Curve Diffie-Hellman key exchange using the k256 curve (also known as secp256k1).

Pseudo-Random Element Generator

Pseudo random element generator module provides a set of traits and data structures that facilitate generating pseudo-random elements in the context of Miden protocol. The module currently includes:

  • FeltRng: a trait for generating random field elements and random 4 field elements.
  • RpoRandomCoin: a struct implementing FeltRng as well as the RandomCoin trait using RPO hash function.
  • RpxRandomCoin: a struct implementing FeltRng as well as the RandomCoin trait using RPX hash function.

Make commands

We use make to automate building, testing, and other processes. In most cases, make commands are wrappers around cargo commands with specific arguments. You can view the list of available commands in the Makefile, or run the following command:

make

Crate features

This crate can be compiled with the following features:

  • concurrent- enabled by default; enables multi-threaded implementation of Smt::with_entries() which significantly improves performance on multi-core CPUs.
  • std - enabled by default and relies on the Rust standard library.
  • no_std does not rely on the Rust standard library and enables compilation to WebAssembly.
  • hashmaps - uses hashbrown hashmaps in SMT and Merkle Store implementation which significantly improves performance of updates. Keys ordering in iterators is not guaranteed when this feature is enabled.
  • rocksdb - enables the RocksDB-backed storage for LargeSmt and related utilities. Implies concurrent.

All of these features imply the use of alloc to support heap-allocated collections.

To compile with no_std, disable default features via --no-default-features flag or using the following command:

make build-no-std

AVX2 acceleration

On platforms with AVX2 support, RPO and RPX hash function can be accelerated by using the vector processing unit. To enable AVX2 acceleration, the code needs to be compiled with the avx2 target feature enabled. For example:

make build-avx2

SVE acceleration

On platforms with SVE support, RPO and RPX hash function can be accelerated by using the vector processing unit. To enable SVE acceleration, the code needs to be compiled with the sve target feature enabled. For example:

make build-sve

Testing

The best way to test the library is using our Makefile, this will enable you to use our pre-defined optimized testing commands:

make test

For example, some of the functions are heavy and might take a while for the tests to complete if using simply cargo test. In order to test in release and optimized mode, we have to replicate the test conditions of the development mode so all debug assertions can be verified.

We do that by enabling some special flags for the compilation (which we have set as a default in our Makefile):

RUSTFLAGS="-C debug-assertions -C overflow-checks -C debuginfo=2" cargo test --release

Fuzzing

The fuzz-smt fuzz target is designed to test the Smt implementation. It generates random SMT entries and updates, and then compares the results of the sequential and parallel implementations.

Before running the fuzz tests, ensure you have cargo-fuzz installed:

cargo install cargo-fuzz

To run the fuzz target, use:

make fuzz-smt

License

Any contribution intentionally submitted for inclusion in this repository, as defined in the Apache-2.0 license, shall be dual licensed under the MIT and Apache 2.0 licenses, without any additional terms or conditions.

About

Cryptographic primitives used in Polygon Miden rollup

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Rust 98.2%
  • C 1.4%
  • Other 0.4%