pub struct MockDistributedCommunication { /* private fields */ }
Expand description
A mock implementation of distributed communication for testing.
Implementations§
Trait Implementations§
Source§impl DistributedCommunication for MockDistributedCommunication
impl DistributedCommunication for MockDistributedCommunication
Source§fn send(
&self,
_tensor: Box<dyn ArrayProtocol>,
destination: usize,
) -> CoreResult<()>
fn send( &self, _tensor: Box<dyn ArrayProtocol>, destination: usize, ) -> CoreResult<()>
Send a tensor to another worker.
Source§fn recv(&self, source: usize) -> CoreResult<Box<dyn ArrayProtocol>>
fn recv(&self, source: usize) -> CoreResult<Box<dyn ArrayProtocol>>
Receive a tensor from another worker.
Source§fn broadcast(
&self,
tensor: Box<dyn ArrayProtocol>,
) -> CoreResult<Box<dyn ArrayProtocol>>
fn broadcast( &self, tensor: Box<dyn ArrayProtocol>, ) -> CoreResult<Box<dyn ArrayProtocol>>
Broadcast a tensor from the master to all workers.
Source§fn gather(
&self,
tensor: Box<dyn ArrayProtocol>,
) -> CoreResult<Vec<Box<dyn ArrayProtocol>>>
fn gather( &self, tensor: Box<dyn ArrayProtocol>, ) -> CoreResult<Vec<Box<dyn ArrayProtocol>>>
Gather tensors from all workers to the master.
Source§fn scatter(
&self,
tensors: Vec<Box<dyn ArrayProtocol>>,
) -> CoreResult<Box<dyn ArrayProtocol>>
fn scatter( &self, tensors: Vec<Box<dyn ArrayProtocol>>, ) -> CoreResult<Box<dyn ArrayProtocol>>
Scatter tensors from the master to all workers.
Source§fn reduce(
&self,
tensor: Box<dyn ArrayProtocol>,
op: &str,
) -> CoreResult<Box<dyn ArrayProtocol>>
fn reduce( &self, tensor: Box<dyn ArrayProtocol>, op: &str, ) -> CoreResult<Box<dyn ArrayProtocol>>
Reduce tensors from all workers to the master.
Source§fn all_reduce(
&self,
tensor: Box<dyn ArrayProtocol>,
op: &str,
) -> CoreResult<Box<dyn ArrayProtocol>>
fn all_reduce( &self, tensor: Box<dyn ArrayProtocol>, op: &str, ) -> CoreResult<Box<dyn ArrayProtocol>>
All-reduce tensors across all workers.
Source§fn all_gather(
&self,
tensor: Box<dyn ArrayProtocol>,
) -> CoreResult<Vec<Box<dyn ArrayProtocol>>>
fn all_gather( &self, tensor: Box<dyn ArrayProtocol>, ) -> CoreResult<Vec<Box<dyn ArrayProtocol>>>
All-gather tensors from all workers to all workers.
Source§fn barrier(&self) -> CoreResult<()>
fn barrier(&self) -> CoreResult<()>
Barrier synchronization.
Source§fn box_clone(&self) -> Box<dyn DistributedCommunication>
fn box_clone(&self) -> Box<dyn DistributedCommunication>
Clone this communication channel.
Auto Trait Implementations§
impl Freeze for MockDistributedCommunication
impl RefUnwindSafe for MockDistributedCommunication
impl Send for MockDistributedCommunication
impl Sync for MockDistributedCommunication
impl Unpin for MockDistributedCommunication
impl UnwindSafe for MockDistributedCommunication
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> 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