-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsign.rs
66 lines (53 loc) · 2.46 KB
/
sign.rs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
use ark_bn254::{Bn254, Fr};
use criterion::{black_box, criterion_group, criterion_main, BenchmarkId, Criterion, Throughput};
use rand::Rng;
use bbs_plus::{
constants::Bn254Const, key_gen::SecretKey, utils::interface_utilities::HashToG1Bn254,
};
// benchmarking signing on single message with varying message length
pub fn sign_benchmark_single_msg(c: &mut Criterion) {
let mut key_material: [u8; 32] = [1; 32];
let key_dst = b"BBS-SIG-KEYGEN-SALT-";
let sk = SecretKey::<Fr>::key_gen::<Bn254>(&mut key_material, &[], key_dst).unwrap();
let mut group = c.benchmark_group("sign_single_msg");
// message size
for size in [32, 64, 128, 256, 512, 1024, 2048].iter() {
group.throughput(Throughput::Bytes(*size as u64));
group.bench_with_input(BenchmarkId::from_parameter(size), size, |b, &size| {
let mut rng = rand::thread_rng();
let msg: Vec<u8> = (0..size).map(|_| rng.gen::<u8>()).collect(); // generating random message
b.iter(|| sk.sign::<Bn254, Bn254Const, HashToG1Bn254>(black_box(&[&msg]), &[]));
});
}
group.finish();
}
// benchmarking signing on multiple messages each of length 32bytes
pub fn sign_benchmark_multiple_msgs(c: &mut Criterion) {
let mut key_material: [u8; 32] = [1; 32];
let key_dst = b"BBS-SIG-KEYGEN-SALT-";
let sk = SecretKey::<Fr>::key_gen::<Bn254>(&mut key_material, &[], key_dst).unwrap();
let mut group = c.benchmark_group("sign_multiple_msgs");
// numer of messages
for size in [1, 2, 4, 8, 16, 32, 64, 128].iter() {
group.throughput(Throughput::Bytes(*size as u64));
group.bench_with_input(BenchmarkId::from_parameter(size), size, |b, &size| {
let random_msgs_vecs: Vec<Vec<u8>> = (0..size)
.map(|_| {
let mut rng = rand::thread_rng();
// each msg length of 32 bytes
(0..32).map(|_| rng.gen::<u8>()).collect()
})
.collect();
let msg_slices: Vec<&[u8]> = random_msgs_vecs.iter().map(|v| v.as_slice()).collect();
let msgs: &[&[u8]] = &msg_slices;
b.iter(|| sk.sign::<Bn254, Bn254Const, HashToG1Bn254>(black_box(msgs), &[]));
});
}
group.finish();
}
criterion_group! {
name = benches;
config = Criterion::default().sample_size(10); // Decrease sample size to 10
targets = sign_benchmark_single_msg, sign_benchmark_multiple_msgs
}
criterion_main!(benches);