#stark #serialization #transmute #prover #verifier #iterator #deserialize

no-std winter-utils

Utilities for the Winterfell STARK prover/verifier

32 releases

0.11.0 Nov 24, 2024
0.10.1 Oct 30, 2024
0.9.1 Jun 24, 2024
0.8.4 Mar 18, 2024
0.2.0 Aug 24, 2021

#727 in Cryptography

Download history 2370/week @ 2024-09-20 1422/week @ 2024-09-27 2164/week @ 2024-10-04 1221/week @ 2024-10-11 1378/week @ 2024-10-18 2162/week @ 2024-10-25 2618/week @ 2024-11-01 652/week @ 2024-11-08 1839/week @ 2024-11-15 1893/week @ 2024-11-22 1438/week @ 2024-11-29 1223/week @ 2024-12-06 854/week @ 2024-12-13 659/week @ 2024-12-20 567/week @ 2024-12-27 617/week @ 2025-01-03

3,075 downloads per month
Used in 54 crates (14 directly)

MIT license

77KB
1.5K SLoC

Winter utils

This crate contains utilities used by the Winterfell STARK prover and verifier. These utilities fall into the following broad categories:

  • Traits used for serialization and deserialization.
  • Functions for transmuting vectors and slices.
  • Macros for easily switching between regular and parallel iterators.
  • Feature-based re-exports of collections and strings.

Crate features

This crate can be compiled with the following features:

  • std - enabled by default and relies on the Rust standard library.
  • concurrent - implies std and also re-exports rayon crate and enables multi-threaded execution for some of the crate functions.
  • no_std - does not rely on Rust's standard library and enables compilation to WebAssembly.

To compile with no_std, disable default features via --no-default-features flag.

Concurrent execution

When compiled with concurrent feature enabled, this crate re-exports rayon crate and executes the following functions using multiple threads:

  • transpose_slice()

The number of threads can be configured via RAYON_NUM_THREADS environment variable, and usually defaults to the number of logical cores on the machine.

License

This project is MIT licensed.

Dependencies

~0–265KB