Crates.io | dusk-plonk |
lib.rs | dusk-plonk |
version | 0.20.2 |
source | src |
created_at | 2020-04-25 15:51:41.76214 |
updated_at | 2024-10-14 08:25:52.552981 |
description | A pure-Rust implementation of the PLONK ZK-Proof algorithm |
homepage | |
repository | https://github.com/dusk-network/plonk |
max_upload_size | |
id | 233998 |
size | 867,425 |
This is a pure Rust implementation of the PLONK proving system over BLS12-381.
This library contains a modular implementation of KZG10 as the default polynomial commitment scheme. Moreover, it includes custom gates for efficiency purposes. The details on our specific implementation can be found here.
DISCLAIMER: This library is currently unstable and still needs to undergo an exhaustive security analysis. Use at your own risk.
To see how to use this library, check the 'examples' directory.
This crate includes a variety of features which are briefly explained below:
alloc
: Enables the usage of an allocator, allowing for Proof
constructions and verifications. Without this feature it IS NOT possible to prove or verify anything.
Its absence only makes dusk-plonk
export certain fixed-size data structures such as Proof
, which can be useful in no_std environments where we don't have allocators available.std
: Enables std
usage as well as rayon
parallelization in some proving and verifying operations.
It also uses the std
versions of the elliptic curve dependencies, utilizing the parallel
feature
from dusk-bls12-381
. This feature is enabled by default.debug
: Enables the runtime debugger backend, outputting CDF files to the path defined in the CDF_OUTPUT
environment variable. When used, the binary must be compiled with debug = true
. For more info, check the cargo book.
It is recommended to derive the std output and std error and then place them in a text file for efficient gate analysis.The crate documentation provides information about all the functions that the library provides, as well
as the documentation regarding the data structures that it exports. To check this, visit the documentation page or run make doc
or make doc-internal
.
Benchmarks taken on Apple M1
, for a circuit-size of 2^16
constraints:
7.871s
2.821ms
(This time does not vary depending on the circuit-size.)For more results, please run cargo bench
to get a full report of benchmarks in respect of constraint numbers.
This code is licensed under the Mozilla Public License Version 2.0 (MPL-2.0). Please see LICENSE for more information.
This implementation is designed by the Dusk team.