Skip to content

Latest commit

 

History

History
65 lines (35 loc) · 1.52 KB

README.md

File metadata and controls

65 lines (35 loc) · 1.52 KB

Benchmarking primitives in this workspace

Run cargo bench to run all the benchmarks and will use the standard library and rayon for parallelization. To avoid both standard library and rayon, run cargo bench --no-default-features

For running specific benchmarks, see below

Schnorr protocol

To run all benchmarks for this, run

cargo bench --bench=schnorr

Like others, above uses the standard library and rayon, to avoid both, run

cargo bench --no-default-features --bench=schnorr

BBS+ signatures

To run benchmarks for signing and verifying (both groups G1 and G2), run

cargo bench --bench=bbs_plus_signature

For proof of knowledge (signature in G1 only)

cargo bench --bench=bbs_plus_proof

Accumulators

For positive accumulator

cargo bench --bench=positive_accumulator

For universal accumulator

cargo bench --bench=universal_accumulator

For witness update (both using and without secret key)

cargo bench --bench=accum_witness_updates

PS signatures

To run benchmarks for signing and verifying (both groups G1 and G2), run

cargo bench --bench=ps_signature

For proof of knowledge (signature in G1 only)

cargo bench --bench=ps_proof

Oblivious transfer and multiplication based on it

For KOS OT extension

cargo bench --bench=kos_ote

For 2-party batch multiplication

cargo bench --bench=dkls19_batch_mul_2p

SyRA

cargo bench --bench=syra

Since threshold issuance benchmarks can take long, a reduced sample size can be tried like of 10.

cargo bench --bench=syra -- --sample-size=10