pub struct FederatedRound {
pub round_num: usize,
pub client_count: usize,
pub global_model: Cid,
pub aggregated_gradient: Option<Vec<f32>>,
pub start_time: i64,
pub end_time: Option<i64>,
pub completed_count: usize,
}Expand description
Federated learning round
Fields§
§round_num: usizeRound number
client_count: usizeClients participating in this round (stored as count for serialization)
global_model: CidGlobal model CID for this round
aggregated_gradient: Option<Vec<f32>>Aggregated gradient for this round (if computed)
start_time: i64Round start timestamp
end_time: Option<i64>Round end timestamp (if completed)
completed_count: usizeCompleted client count
Implementations§
Source§impl FederatedRound
impl FederatedRound
Sourcepub fn new(round_num: usize, global_model: Cid, client_count: usize) -> Self
pub fn new(round_num: usize, global_model: Cid, client_count: usize) -> Self
Create a new federated round
Sourcepub fn mark_client_completed(&mut self)
pub fn mark_client_completed(&mut self)
Mark a client as completed
Sourcepub fn is_complete(&self) -> bool
pub fn is_complete(&self) -> bool
Check if round is complete
Trait Implementations§
Source§impl Clone for FederatedRound
impl Clone for FederatedRound
Source§fn clone(&self) -> FederatedRound
fn clone(&self) -> FederatedRound
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl Debug for FederatedRound
impl Debug for FederatedRound
Source§impl<'de> Deserialize<'de> for FederatedRound
impl<'de> Deserialize<'de> for FederatedRound
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
Auto Trait Implementations§
impl Freeze for FederatedRound
impl RefUnwindSafe for FederatedRound
impl Send for FederatedRound
impl Sync for FederatedRound
impl Unpin for FederatedRound
impl UnwindSafe for FederatedRound
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more