#bls-signatures #bls12-381 #bls #signatures #signature #signature-verification

bls12_381-bls

Implementation of BLS signatures using the BLS12-381 curve

6 releases (3 breaking)

new 0.4.1 Dec 18, 2024
0.4.0 Aug 1, 2024
0.3.1 Jun 27, 2024
0.3.0 Apr 24, 2024
0.1.0 Jan 8, 2024

#1413 in Cryptography

Download history 67/week @ 2024-08-28 321/week @ 2024-09-04 110/week @ 2024-09-11 69/week @ 2024-09-18 214/week @ 2024-09-25 181/week @ 2024-10-02 247/week @ 2024-10-09 259/week @ 2024-10-16 172/week @ 2024-10-23 134/week @ 2024-10-30 126/week @ 2024-11-06 102/week @ 2024-11-13 107/week @ 2024-11-20 109/week @ 2024-11-27 78/week @ 2024-12-04 274/week @ 2024-12-11

589 downloads per month
Used in 4 crates (2 directly)

MPL-2.0 license

27KB
454 lines

Implementation of BLS signatures using the BLS12-381 curve.

This implementation currently only supports rogue-key attack resistant batching, and does not support distinct message verification.

Benchmarks

Machine specs

The benchmarks were ran on a 2020 13.3" MacBook Pro.

CPU:

$ lscpu
Intel(R) Core(TM) i7-1068NG7 CPU @ 2.30GHz

RAM:

16 GB 3733 MHz LPDDR4X

Results

test benches::bench_aggregate_pk    ... bench:   1,654,552 ns/iter (+/- 107,025)
test benches::bench_aggregate_sig   ... bench:      36,893 ns/iter (+/- 3,399)
test benches::bench_sign            ... bench:   1,480,169 ns/iter (+/- 106,151)
test benches::bench_sign_vulnerable ... bench:   1,024,052 ns/iter (+/- 111,395)
test benches::bench_verify          ... bench:   4,740,114 ns/iter (+/- 336,036)

lib.rs:

Implementation of BLS signatures on the BLS12-381 curve. Reference paper: https://crypto.stanford.edu/~dabo/pubs/papers/BLSmultisig.html

Dependencies

~2.2–3.5MB
~81K SLoC