1
0
mirror of synced 2025-01-11 16:24:16 +00:00

Simulation tally fix (#268)

* Do not remove entry cache when the threshold is reached

* Leader super majority change

* Update leader threshold test
This commit is contained in:
gusto 2023-07-21 12:30:32 +03:00 committed by GitHub
parent 6dee12704d
commit 8dd34f81b4
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
13 changed files with 47 additions and 35 deletions

View File

@ -1,5 +1,5 @@
use super::LeaderSelection; use super::LeaderSelection;
use crate::{Committee, NodeId, Overlay}; use crate::{NodeId, Overlay};
use fraction::{Fraction, ToPrimitive}; use fraction::{Fraction, ToPrimitive};
use serde::{Deserialize, Serialize}; use serde::{Deserialize, Serialize};
const LEADER_SUPER_MAJORITY_THRESHOLD_NUM: u64 = 2; const LEADER_SUPER_MAJORITY_THRESHOLD_NUM: u64 = 2;
@ -64,7 +64,7 @@ where
} }
fn parent_committee(&self, _id: NodeId) -> crate::Committee { fn parent_committee(&self, _id: NodeId) -> crate::Committee {
Committee::new() std::iter::once(self.next_leader()).collect()
} }
fn node_committee(&self, _id: NodeId) -> crate::Committee { fn node_committee(&self, _id: NodeId) -> crate::Committee {

View File

@ -85,7 +85,12 @@ where
} }
fn parent_committee(&self, id: NodeId) -> Committee { fn parent_committee(&self, id: NodeId) -> Committee {
self.carnot_tree.parent_committee_from_member_id(&id) let c = self.carnot_tree.parent_committee_from_member_id(&id);
if !c.is_empty() {
c
} else {
std::iter::once(self.next_leader()).collect()
}
} }
fn child_committees(&self, id: NodeId) -> Vec<Committee> { fn child_committees(&self, id: NodeId) -> Vec<Committee> {
@ -143,20 +148,25 @@ where
.expect("node is not part of any committee") .expect("node is not part of any committee")
} }
// TODO: Carnot node in sim does not send votes to the next leader from the child committee of
// root committee yet. *For now* leader super majority threshold should be calculated only from
// the number of root committee nodes. The code will be reverted once vote sending from
// child committee of root committee is added to Carnot node.
fn leader_super_majority_threshold(&self, _id: NodeId) -> usize { fn leader_super_majority_threshold(&self, _id: NodeId) -> usize {
let root_committee = &self.carnot_tree.inner_committees[0]; // let root_committee = &self.carnot_tree.inner_committees[0];
let children = self.carnot_tree.child_committees(root_committee); // let children = self.carnot_tree.child_committees(root_committee);
let children_size = children.0.map_or(0, |c| { // let children_size = children.0.map_or(0, |c| {
self.carnot_tree // self.carnot_tree
.committee_by_committee_id(c) // .committee_by_committee_id(c)
.map_or(0, |c| c.len()) // .map_or(0, |c| c.len())
}) + children.1.map_or(0, |c| { // }) + children.1.map_or(0, |c| {
self.carnot_tree // self.carnot_tree
.committee_by_committee_id(c) // .committee_by_committee_id(c)
.map_or(0, |c| c.len()) // .map_or(0, |c| c.len())
}); // });
let root_size = self.root_committee().len(); // let root_size = self.root_committee().len();
let committee_size = root_size + children_size; // let committee_size = root_size + children_size;
let committee_size = self.root_committee().len();
(committee_size * 2 / 3) + 1 (committee_size * 2 / 3) + 1
} }
@ -324,7 +334,7 @@ mod tests {
assert_eq!( assert_eq!(
overlay.leader_super_majority_threshold(NodeId::new([0; 32])), overlay.leader_super_majority_threshold(NodeId::new([0; 32])),
7 3
); );
} }
} }

View File

@ -134,6 +134,7 @@ impl Tree {
.and_then(|idx| self.committee_by_committee_idx(idx)) .and_then(|idx| self.committee_by_committee_idx(idx))
} }
#[allow(dead_code)]
pub(super) fn committee_by_committee_id( pub(super) fn committee_by_committee_id(
&self, &self,
committee_id: &CommitteeId, committee_id: &CommitteeId,

View File

@ -23,7 +23,7 @@ impl ProposalChunkMsg {
} }
} }
#[derive(Eq, PartialEq, Hash, Serialize, Deserialize, Clone)] #[derive(Debug, Eq, PartialEq, Hash, Serialize, Deserialize, Clone)]
pub struct VoteMsg { pub struct VoteMsg {
pub voter: NodeId, pub voter: NodeId,
pub vote: Vote, pub vote: Vote,
@ -39,7 +39,7 @@ impl VoteMsg {
} }
} }
#[derive(Serialize, Deserialize, Hash, PartialEq, Eq, Clone)] #[derive(Debug, Serialize, Deserialize, Hash, PartialEq, Eq, Clone)]
pub struct NewViewMsg { pub struct NewViewMsg {
pub voter: NodeId, pub voter: NodeId,
pub vote: NewView, pub vote: NewView,
@ -54,7 +54,7 @@ impl NewViewMsg {
} }
} }
#[derive(Serialize, Deserialize, Hash, PartialEq, Eq, Clone)] #[derive(Debug, Serialize, Deserialize, Hash, PartialEq, Eq, Clone)]
pub struct TimeoutMsg { pub struct TimeoutMsg {
pub voter: NodeId, pub voter: NodeId,
pub vote: Timeout, pub vote: Timeout,
@ -69,7 +69,7 @@ impl TimeoutMsg {
} }
} }
#[derive(Serialize, Deserialize, PartialEq, Eq, Hash, Clone)] #[derive(Debug, Serialize, Deserialize, PartialEq, Eq, Hash, Clone)]
pub struct TimeoutQcMsg { pub struct TimeoutQcMsg {
pub source: NodeId, pub source: NodeId,
pub qc: TimeoutQc, pub qc: TimeoutQc,

View File

@ -120,7 +120,7 @@ impl SimulationApp {
} }
} }
fn run<M, S, T>( fn run<M: std::fmt::Debug, S, T>(
network: Network<M>, network: Network<M>,
nodes: Vec<BoxedNode<S, T>>, nodes: Vec<BoxedNode<S, T>>,
settings: SimulationSettings, settings: SimulationSettings,

View File

@ -101,7 +101,7 @@ mod network_behaviors_serde {
} }
} }
pub struct Network<M> { pub struct Network<M: std::fmt::Debug> {
pub regions: regions::RegionsData, pub regions: regions::RegionsData,
network_time: NetworkTime, network_time: NetworkTime,
messages: Vec<(NetworkTime, NetworkMessage<M>)>, messages: Vec<(NetworkTime, NetworkMessage<M>)>,
@ -113,7 +113,7 @@ pub struct Network<M> {
impl<M> Network<M> impl<M> Network<M>
where where
M: Send + Sync + Clone, M: std::fmt::Debug + Send + Sync + Clone,
{ {
pub fn new(regions: regions::RegionsData, seed: u64) -> Self { pub fn new(regions: regions::RegionsData, seed: u64) -> Self {
Self { Self {

View File

@ -3,7 +3,7 @@ use nomos_consensus::network::messages::{
NewViewMsg, ProposalChunkMsg, TimeoutMsg, TimeoutQcMsg, VoteMsg, NewViewMsg, ProposalChunkMsg, TimeoutMsg, TimeoutQcMsg, VoteMsg,
}; };
#[derive(Eq, PartialEq, Hash, Clone)] #[derive(Debug, Eq, PartialEq, Hash, Clone)]
pub enum CarnotMessage { pub enum CarnotMessage {
Proposal(ProposalChunkMsg), Proposal(ProposalChunkMsg),
Vote(VoteMsg), Vote(VoteMsg),

View File

@ -57,6 +57,7 @@ pub const CARNOT_RECORD_KEYS: &[&str] = &[
static RECORD_SETTINGS: std::sync::OnceLock<HashMap<String, bool>> = std::sync::OnceLock::new(); static RECORD_SETTINGS: std::sync::OnceLock<HashMap<String, bool>> = std::sync::OnceLock::new();
#[derive(Debug)]
pub struct CarnotState { pub struct CarnotState {
current_view: View, current_view: View,
highest_voted_view: View, highest_voted_view: View,

View File

@ -18,7 +18,7 @@ pub fn simulate<M, R, S, T>(
chunk_size: usize, chunk_size: usize,
) -> anyhow::Result<SimulationRunnerHandle<R>> ) -> anyhow::Result<SimulationRunnerHandle<R>>
where where
M: Clone + Send + Sync + 'static, M: std::fmt::Debug + Clone + Send + Sync + 'static,
R: Record R: Record
+ for<'a> TryFrom<&'a SimulationState<S, T>, Error = anyhow::Error> + for<'a> TryFrom<&'a SimulationState<S, T>, Error = anyhow::Error>
+ Send + Send

View File

@ -21,7 +21,7 @@ pub fn simulate<M, R, S, T>(
maximum_iterations: usize, maximum_iterations: usize,
) -> anyhow::Result<SimulationRunnerHandle<R>> ) -> anyhow::Result<SimulationRunnerHandle<R>>
where where
M: Send + Sync + Clone + 'static, M: std::fmt::Debug + Send + Sync + Clone + 'static,
R: Record R: Record
+ for<'a> TryFrom<&'a SimulationState<S, T>, Error = anyhow::Error> + for<'a> TryFrom<&'a SimulationState<S, T>, Error = anyhow::Error>
+ Send + Send

View File

@ -54,7 +54,7 @@ pub fn simulate<M, R, S, T>(
distribution: Option<Vec<f32>>, distribution: Option<Vec<f32>>,
) -> anyhow::Result<SimulationRunnerHandle<R>> ) -> anyhow::Result<SimulationRunnerHandle<R>>
where where
M: Send + Sync + Clone + 'static, M: std::fmt::Debug + Send + Sync + Clone + 'static,
R: Record R: Record
+ for<'a> TryFrom<&'a SimulationState<S, T>, Error = anyhow::Error> + for<'a> TryFrom<&'a SimulationState<S, T>, Error = anyhow::Error>
+ Send + Send
@ -163,7 +163,7 @@ fn choose_random_layer_and_node_id(
(i, *node_id) (i, *node_id)
} }
fn build_node_ids_deque<M, R, S, T>( fn build_node_ids_deque<M: std::fmt::Debug, R, S, T>(
gap: usize, gap: usize,
runner: &SimulationRunner<M, R, S, T>, runner: &SimulationRunner<M, R, S, T>,
) -> FixedSliceDeque<BTreeSet<NodeId>> { ) -> FixedSliceDeque<BTreeSet<NodeId>> {

View File

@ -60,7 +60,7 @@ impl<R: Record> SimulationRunnerHandle<R> {
} }
} }
pub(crate) struct SimulationRunnerInner<M> { pub(crate) struct SimulationRunnerInner<M: std::fmt::Debug> {
network: Network<M>, network: Network<M>,
wards: Vec<Ward>, wards: Vec<Ward>,
rng: SmallRng, rng: SmallRng,
@ -68,7 +68,7 @@ pub(crate) struct SimulationRunnerInner<M> {
impl<M> SimulationRunnerInner<M> impl<M> SimulationRunnerInner<M>
where where
M: Send + Sync + Clone, M: std::fmt::Debug + Send + Sync + Clone,
{ {
fn check_wards<S, T>(&mut self, state: &SimulationState<S, T>) -> bool { fn check_wards<S, T>(&mut self, state: &SimulationState<S, T>) -> bool {
self.wards self.wards
@ -88,7 +88,7 @@ where
/// Encapsulation solution for the simulations runner /// Encapsulation solution for the simulations runner
/// Holds the network state, the simulating nodes and the simulation settings. /// Holds the network state, the simulating nodes and the simulation settings.
pub struct SimulationRunner<M, R, S, T> { pub struct SimulationRunner<M: std::fmt::Debug, R, S, T> {
inner: SimulationRunnerInner<M>, inner: SimulationRunnerInner<M>,
nodes: Arc<RwLock<Vec<BoxedNode<S, T>>>>, nodes: Arc<RwLock<Vec<BoxedNode<S, T>>>>,
runner_settings: RunnerSettings, runner_settings: RunnerSettings,
@ -97,7 +97,7 @@ pub struct SimulationRunner<M, R, S, T> {
impl<M, R, S, T> SimulationRunner<M, R, S, T> impl<M, R, S, T> SimulationRunner<M, R, S, T>
where where
M: Clone + Send + Sync + 'static, M: std::fmt::Debug + Clone + Send + Sync + 'static,
R: Record R: Record
+ for<'a> TryFrom<&'a SimulationState<S, T>, Error = anyhow::Error> + for<'a> TryFrom<&'a SimulationState<S, T>, Error = anyhow::Error>
+ Send + Send
@ -172,7 +172,7 @@ where
impl<M, R, S, T> SimulationRunner<M, R, S, T> impl<M, R, S, T> SimulationRunner<M, R, S, T>
where where
M: Clone + Send + Sync + 'static, M: std::fmt::Debug + Clone + Send + Sync + 'static,
R: Record R: Record
+ serde::Serialize + serde::Serialize
+ for<'a> TryFrom<&'a SimulationState<S, T>, Error = anyhow::Error> + for<'a> TryFrom<&'a SimulationState<S, T>, Error = anyhow::Error>

View File

@ -10,7 +10,7 @@ pub fn simulate<M, R, S, T>(
runner: SimulationRunner<M, R, S, T>, runner: SimulationRunner<M, R, S, T>,
) -> anyhow::Result<SimulationRunnerHandle<R>> ) -> anyhow::Result<SimulationRunnerHandle<R>>
where where
M: Send + Sync + Clone + 'static, M: std::fmt::Debug + Send + Sync + Clone + 'static,
R: Record R: Record
+ for<'a> TryFrom<&'a SimulationState<S, T>, Error = anyhow::Error> + for<'a> TryFrom<&'a SimulationState<S, T>, Error = anyhow::Error>
+ Send + Send