pub struct DistributedNdarray<T, D>{
pub config: DistributedConfig,
/* private fields */
}
Expand description
A distributed array implementation
Fields§
§config: DistributedConfig
Configuration for this distributed array
Implementations§
Source§impl<T, D> DistributedNdarray<T, D>
impl<T, D> DistributedNdarray<T, D>
Sourcepub fn new(
chunks: Vec<ArrayChunk<T, D>>,
shape: Vec<usize>,
config: DistributedConfig,
) -> Self
pub fn new( chunks: Vec<ArrayChunk<T, D>>, shape: Vec<usize>, config: DistributedConfig, ) -> Self
Create a new distributed array from chunks.
Sourcepub fn from_array(array: &Array<T, D>, config: DistributedConfig) -> Selfwhere
T: Clone,
pub fn from_array(array: &Array<T, D>, config: DistributedConfig) -> Selfwhere
T: Clone,
Create a distributed array by splitting an existing array.
Sourcepub fn num_chunks(&self) -> usize
pub fn num_chunks(&self) -> usize
Get the number of chunks in this distributed array.
Sourcepub fn chunks(&self) -> &[ArrayChunk<T, D>]
pub fn chunks(&self) -> &[ArrayChunk<T, D>]
Get a reference to the chunks in this distributed array.
Sourcepub fn to_array(&self) -> CoreResult<Array<T, IxDyn>>
pub fn to_array(&self) -> CoreResult<Array<T, IxDyn>>
Convert this distributed array back to a regular array.
Note: This implementation is simplified to avoid complex trait bounds. In a real implementation, this would involve proper communication between nodes.
§Errors
Returns CoreError
if array conversion fails.
Sourcepub fn map_reduce<F, R, G>(&self, map_fn: F, reduce_fn: G) -> R
pub fn map_reduce<F, R, G>(&self, map_fn: F, reduce_fn: G) -> R
Reduce the results of mapping a function across all chunks.
§Panics
Panics if the chunks collection is empty and no initial value can be reduced.
Trait Implementations§
Source§impl<T, D> ArrayProtocol for DistributedNdarray<T, D>
impl<T, D> ArrayProtocol for DistributedNdarray<T, D>
Source§fn array_function(
&self,
func: &ArrayFunction,
_types: &[TypeId],
args: &[Box<dyn Any>],
kwargs: &HashMap<String, Box<dyn Any>>,
) -> Result<Box<dyn Any>, NotImplemented>
fn array_function( &self, func: &ArrayFunction, _types: &[TypeId], args: &[Box<dyn Any>], kwargs: &HashMap<String, Box<dyn Any>>, ) -> Result<Box<dyn Any>, NotImplemented>
Implementation of the array protocol. Read more
Source§fn shape(&self) -> &[usize]
fn shape(&self) -> &[usize]
Get the shape of the array (default implementation returns empty slice)
Source§fn box_clone(&self) -> Box<dyn ArrayProtocol>
fn box_clone(&self) -> Box<dyn ArrayProtocol>
Clone this array protocol object.
Source§impl<T, D> Debug for DistributedNdarray<T, D>
impl<T, D> Debug for DistributedNdarray<T, D>
Source§impl<T, D> DistributedArray for DistributedNdarray<T, D>
impl<T, D> DistributedArray for DistributedNdarray<T, D>
Source§fn gather(&self) -> CoreResult<Box<dyn ArrayProtocol>>
fn gather(&self) -> CoreResult<Box<dyn ArrayProtocol>>
§Errors
Returns CoreError
if gathering fails.
Source§fn scatter(&self, chunks: usize) -> CoreResult<Box<dyn DistributedArray>>
fn scatter(&self, chunks: usize) -> CoreResult<Box<dyn DistributedArray>>
§Errors
Returns CoreError
if scattering fails.
Source§fn distribution_info(&self) -> HashMap<String, String>
fn distribution_info(&self) -> HashMap<String, String>
Get information about the distribution of this array.
Source§fn is_distributed(&self) -> bool
fn is_distributed(&self) -> bool
Check if this array is distributed.
Auto Trait Implementations§
impl<T, D> Freeze for DistributedNdarray<T, D>
impl<T, D> RefUnwindSafe for DistributedNdarray<T, D>where
D: RefUnwindSafe,
T: RefUnwindSafe,
impl<T, D> Send for DistributedNdarray<T, D>where
T: Send,
impl<T, D> Sync for DistributedNdarray<T, D>where
T: Sync,
impl<T, D> Unpin for DistributedNdarray<T, D>where
D: Unpin,
impl<T, D> UnwindSafe for DistributedNdarray<T, D>where
D: UnwindSafe,
T: RefUnwindSafe,
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