#[non_exhaustive]pub enum CommunicationProtocol {
DataStore,
Direct,
Pipeline {
micro_batch_size: usize,
},
}Expand description
How model-parallel partitions communicate activations and gradients.
Variants (Non-exhaustive)§
This enum is marked as non-exhaustive
Non-exhaustive enums could have additional variants added in future. Therefore, when matching against variants of non-exhaustive enums, an extra wildcard arm must be added to account for any future variants.
DataStore
Intermediate values flow via DataStore (S3, shared disk).
Direct
Direct point-to-point streaming between workers.
Pipeline
Pipeline parallelism with micro-batching for overlap.
Trait Implementations§
Source§impl Clone for CommunicationProtocol
impl Clone for CommunicationProtocol
Source§fn clone(&self) -> CommunicationProtocol
fn clone(&self) -> CommunicationProtocol
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 CommunicationProtocol
impl Debug for CommunicationProtocol
Source§impl<'de> Deserialize<'de> for CommunicationProtocol
impl<'de> Deserialize<'de> for CommunicationProtocol
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 CommunicationProtocol
impl RefUnwindSafe for CommunicationProtocol
impl Send for CommunicationProtocol
impl Sync for CommunicationProtocol
impl Unpin for CommunicationProtocol
impl UnsafeUnpin for CommunicationProtocol
impl UnwindSafe for CommunicationProtocol
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