Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Just view simplpedpop PR on github #105

Closed
wants to merge 12 commits into from
37 changes: 32 additions & 5 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -22,17 +22,22 @@ curve25519-dalek = { version = "4.1.0", default-features = false, features = [
"zeroize",
"precomputed-tables",
"legacy_compatibility",
"rand_core",
"serde",
] }
subtle = { version = "2.4.1", default-features = false }
merlin = { version = "3.0.0", default-features = false }
getrandom_or_panic = { version = "0.0.3", default-features = false }
rand_core = { version = "0.6.2", default-features = false }
serde_crate = { version = "1.0.130", package = "serde", default-features = false, optional = true }
serde = { version = "1.0.130", default-features = false, optional = true }
serde_bytes = { version = "0.11.5", default-features = false, optional = true }
cfg-if = { version = "1.0.0", optional = true }
sha2 = { version = "0.10.7", default-features = false }
failure = { version = "0.1.8", default-features = false, optional = true }
zeroize = { version = "1.6", default-features = false, features = ["zeroize_derive"] }
derive-getters = "0.3.0"
chacha20poly1305 = { version = "0.10.1", default-features = false }
hex = { version = "0.4", default-features = true, optional = true }

[dev-dependencies]
rand = "0.8.5"
Expand All @@ -47,17 +52,38 @@ serde_json = "1.0.68"
name = "schnorr_benchmarks"
harness = false

[[bench]]
name = "olaf_benchmarks"
required-features = ["alloc", "aead"]

[features]
default = ["std", "getrandom"]
preaudit_deprecated = []
nightly = []
alloc = ["curve25519-dalek/alloc", "rand_core/alloc", "getrandom_or_panic/alloc", "serde_bytes/alloc"]
std = ["alloc", "getrandom", "serde_bytes/std", "rand_core/std", "getrandom_or_panic/std"]
alloc = [
"curve25519-dalek/alloc",
"rand_core/alloc",
"getrandom_or_panic/alloc",
"serde_bytes?/alloc",
]
std = [
"alloc",
"getrandom",
"serde_bytes?/std",
"rand_core/std",
"getrandom_or_panic/std",
"chacha20poly1305/std",
"hex/std",
]
asm = ["sha2/asm"]
serde = ["serde_crate", "serde_bytes", "cfg-if"]
serde = ["dep:serde", "serde_bytes", "cfg-if"]
# We cannot make getrandom a direct dependency because rand_core makes
# getrandom a feature name, which requires forwarding.
getrandom = ["rand_core/getrandom", "getrandom_or_panic/getrandom", "aead?/getrandom"]
getrandom = [
"rand_core/getrandom",
"getrandom_or_panic/getrandom",
"aead?/getrandom",
]
# We thus cannot forward the wasm-bindgen feature of getrandom,
# but our consumers could depend upon getrandom and activate its
# wasm-bindgen feature themselve, which works due to cargo features
Expand All @@ -66,3 +92,4 @@ getrandom = ["rand_core/getrandom", "getrandom_or_panic/getrandom", "aead?/getra
# See https://github.com/rust-lang/cargo/issues/9210
# and https://github.com/w3f/schnorrkel/issues/65#issuecomment-786923588
aead = ["dep:aead"]
cheater-detection = []
293 changes: 293 additions & 0 deletions benches/olaf_benchmarks.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,293 @@
use criterion::{criterion_group, criterion_main, Criterion};

mod olaf_benches {
use super::*;
use criterion::BenchmarkId;
use merlin::Transcript;
use rand_core::OsRng;
use schnorrkel::olaf::{
errors::DKGResult,
identifier::Identifier,
keys::{GroupPublicKey, GroupPublicKeyShare},
simplpedpop::{
round1::{self, PrivateData, PublicData, PublicMessage},
round2,
round2::Messages,
round3, Identifiers, Parameters,
},
};
use std::collections::{BTreeMap, BTreeSet};

fn generate_parameters(max_signers: u16, min_signers: u16) -> Vec<Parameters> {
(1..=max_signers)
.map(|_| Parameters::new(max_signers, min_signers))
.collect()
}

fn round1(
participants: u16,
threshold: u16,
) -> (
Vec<Parameters>,
Vec<PrivateData>,
Vec<PublicData>,
Vec<BTreeSet<PublicMessage>>,
) {
let parameters_list = generate_parameters(participants, threshold);

let mut all_public_messages_vec = Vec::new();
let mut participants_round1_private_data = Vec::new();
let mut participants_round1_public_data = Vec::new();

for i in 0..parameters_list.len() {
let (private_data, public_message, public_data) =
round1::run(parameters_list[i as usize].clone(), OsRng)
.expect("Round 1 should complete without errors!");

all_public_messages_vec.push(public_message.clone());
participants_round1_public_data.push(public_data);
participants_round1_private_data.push(private_data);
}

let mut received_round1_public_messages: Vec<BTreeSet<PublicMessage>> = Vec::new();

let mut all_public_messages = BTreeSet::new();

for i in 0..participants {
all_public_messages.insert(all_public_messages_vec[i as usize].clone());
}

// Iterate through each participant to create a set of messages excluding their own.
for i in 0..participants as usize {
let own_message = PublicMessage::new(&participants_round1_public_data[i]);

let mut messages_for_participant = BTreeSet::new();

for message in &all_public_messages {
if &own_message != message {
// Exclude the participant's own message.
messages_for_participant.insert(message.clone());
}
}

received_round1_public_messages.push(messages_for_participant);
}

(
parameters_list,
participants_round1_private_data,
participants_round1_public_data,
received_round1_public_messages,
)
}

fn round2(
parameters_list: &Vec<Parameters>,
participants_round1_private_data: Vec<PrivateData>,
participants_round1_public_data: &Vec<PublicData>,
participants_round1_public_messages: &Vec<BTreeSet<PublicMessage>>,
) -> (
Vec<round2::PublicData>,
Vec<Messages>,
Vec<Identifiers>,
Vec<Identifier>,
) {
let mut participants_round2_public_data = Vec::new();
let mut participants_round2_public_messages = Vec::new();
let mut participants_set_of_participants = Vec::new();
let mut identifiers_vec = Vec::new();

for i in 0..*parameters_list[0].participants() {
let result = round2::run(
participants_round1_private_data[i as usize].clone(),
&participants_round1_public_data[i as usize].clone(),
participants_round1_public_messages[i as usize].clone(),
Transcript::new(b"simplpedpop"),
)
.expect("Round 2 should complete without errors!");

participants_round2_public_data.push(result.0.clone());
participants_round2_public_messages.push(result.1);
participants_set_of_participants.push(result.0.identifiers().clone());
identifiers_vec.push(*result.0.identifiers().own_identifier());
}

(
participants_round2_public_data,
participants_round2_public_messages,
participants_set_of_participants,
identifiers_vec,
)
}

fn round3(
participants_sets_of_participants: &Vec<Identifiers>,
participants_round2_public_messages: &Vec<round2::PublicMessage>,
participants_round2_public_data: &Vec<round2::PublicData>,
participants_round1_public_data: &Vec<round1::PublicData>,
participants_round1_private_data: Vec<round1::PrivateData>,
participants_round2_private_messages: Vec<BTreeMap<Identifier, round2::PrivateMessage>>,
identifiers_vec: &Vec<Identifier>,
) -> DKGResult<
Vec<(
GroupPublicKey,
BTreeMap<Identifier, GroupPublicKeyShare>,
round3::PrivateData,
)>,
> {
let mut participant_data_round3 = Vec::new();

for i in 0..participants_sets_of_participants.len() {
let received_round2_public_messages = participants_round2_public_messages
.iter()
.enumerate()
.filter(|(index, _msg)| {
identifiers_vec[*index]
!= *participants_sets_of_participants[i as usize].own_identifier()
})
.map(|(index, msg)| (identifiers_vec[index], msg.clone()))
.collect::<BTreeMap<Identifier, round2::PublicMessage>>();

let mut round2_private_messages: Vec<BTreeMap<Identifier, round2::PrivateMessage>> =
Vec::new();

for participants in participants_sets_of_participants.iter() {
let mut messages_for_participant = BTreeMap::new();

for (i, round_messages) in participants_round2_private_messages.iter().enumerate() {
if let Some(message) = round_messages.get(&participants.own_identifier()) {
messages_for_participant.insert(identifiers_vec[i], message.clone());
}
}

round2_private_messages.push(messages_for_participant);
}

let result = round3::run(
&received_round2_public_messages,
&participants_round2_public_data[i as usize],
&participants_round1_public_data[i as usize],
participants_round1_private_data[i as usize].clone(),
&round2_private_messages[i as usize],
)?;

participant_data_round3.push(result);
}

Ok(participant_data_round3)
}

fn benchmark_simplpedpop(c: &mut Criterion) {
let mut group = c.benchmark_group("SimplPedPoP");

group
.sample_size(10)
.warm_up_time(std::time::Duration::from_secs(2))
.measurement_time(std::time::Duration::from_secs(30));

for &n in [3, 10, 100].iter() {
let participants = n;
let threshold = (n * 2 + 2) / 3;
let parameters_list = generate_parameters(participants, threshold);

group.bench_function(BenchmarkId::new("round1", participants), |b| {
b.iter(|| {
round1::run(parameters_list[0].clone(), OsRng).unwrap();
})
});

let (
parameters_list,
participants_round1_private_data,
participants_round1_public_data,
participants_round1_public_messages,
) = round1(participants, threshold);

group.bench_function(BenchmarkId::new("round2", participants), |b| {
b.iter(|| {
round2::run(
participants_round1_private_data[0].clone(),
&participants_round1_public_data[0],
participants_round1_public_messages[0].clone(),
Transcript::new(b"simplpedpop"),
)
.unwrap();
})
});

let (
participants_round2_public_data,
participants_round2_messages,
participants_sets_of_participants,
identifiers_vec,
) = round2(
&parameters_list,
participants_round1_private_data.clone(),
&participants_round1_public_data,
&participants_round1_public_messages,
);

let participants_round2_public_messages: Vec<round2::PublicMessage> =
participants_round2_messages
.iter()
.map(|msg| msg.public_message().clone())
.collect();

let participants_round2_private_messages: Vec<
BTreeMap<Identifier, round2::PrivateMessage>,
> = participants_round2_messages
.iter()
.map(|msg| msg.private_messages().clone())
.collect();

let received_round2_public_messages = participants_round2_public_messages
.iter()
.enumerate()
.filter(|(index, _msg)| {
identifiers_vec[*index]
!= *participants_sets_of_participants[0].own_identifier()
})
.map(|(index, msg)| (identifiers_vec[index], msg.clone()))
.collect::<BTreeMap<Identifier, round2::PublicMessage>>();

let mut round2_private_messages: Vec<BTreeMap<Identifier, round2::PrivateMessage>> =
Vec::new();

for participants in participants_sets_of_participants.iter() {
let mut messages_for_participant = BTreeMap::new();

for (i, round_messages) in participants_round2_private_messages.iter().enumerate() {
if let Some(message) = round_messages.get(&participants.own_identifier()) {
messages_for_participant.insert(identifiers_vec[i], message.clone());
}
}

round2_private_messages.push(messages_for_participant);
}

group.bench_function(BenchmarkId::new("round3", participants), |b| {
b.iter(|| {
round3::run(
&received_round2_public_messages,
&participants_round2_public_data[0],
&participants_round1_public_data[0],
participants_round1_private_data[0].clone(),
&round2_private_messages[0],
)
.unwrap();
})
});
}

group.finish();
}

criterion_group! {
name = olaf_benches;
config = Criterion::default();
targets =
benchmark_simplpedpop,
}
}

criterion_main!(olaf_benches::olaf_benches);
2 changes: 1 addition & 1 deletion src/aead.rs
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,7 @@ use crate::context::SigningTranscript;

use crate::cert::AdaptorCertPublic;

fn make_aead<T, AEAD>(mut t: T) -> AEAD
pub(crate) fn make_aead<T, AEAD>(mut t: T) -> AEAD
Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is not an ideal solution, likely we should be sure we're doing poly1305 right and expose it from here.

where
T: SigningTranscript,
AEAD: KeyInit,
Expand Down
2 changes: 1 addition & 1 deletion src/errors.rs
Original file line number Diff line number Diff line change
Expand Up @@ -150,7 +150,7 @@ impl failure::Fail for SignatureError {}
#[cfg(feature = "serde")]
pub fn serde_error_from_signature_error<E>(err: SignatureError) -> E
where
E: serde_crate::de::Error,
E: serde::de::Error,
{
E::custom(err)
}
Loading
Loading