pub struct DistributedNdarray<T, D>{
pub config: DistributedConfig,
/* private fields */
}Expand description
A distributed array implementation
Fields§
§config: DistributedConfigConfiguration 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, reducefn: G) -> R
pub fn map_reduce<F, R, G>(&self, map_fn: F, reducefn: 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> CheckedAs for T
impl<T> CheckedAs for T
Source§fn checked_as<Dst>(self) -> Option<Dst>where
T: CheckedCast<Dst>,
fn checked_as<Dst>(self) -> Option<Dst>where
T: CheckedCast<Dst>,
Casts the value.
Source§impl<Src, Dst> CheckedCastFrom<Src> for Dstwhere
Src: CheckedCast<Dst>,
impl<Src, Dst> CheckedCastFrom<Src> for Dstwhere
Src: CheckedCast<Dst>,
Source§fn checked_cast_from(src: Src) -> Option<Dst>
fn checked_cast_from(src: Src) -> Option<Dst>
Casts the value.
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 moreSource§impl<T> OverflowingAs for T
impl<T> OverflowingAs for T
Source§fn overflowing_as<Dst>(self) -> (Dst, bool)where
T: OverflowingCast<Dst>,
fn overflowing_as<Dst>(self) -> (Dst, bool)where
T: OverflowingCast<Dst>,
Casts the value.
Source§impl<Src, Dst> OverflowingCastFrom<Src> for Dstwhere
Src: OverflowingCast<Dst>,
impl<Src, Dst> OverflowingCastFrom<Src> for Dstwhere
Src: OverflowingCast<Dst>,
Source§fn overflowing_cast_from(src: Src) -> (Dst, bool)
fn overflowing_cast_from(src: Src) -> (Dst, bool)
Casts the value.
Source§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<T> PolicyExt for Twhere
T: ?Sized,
impl<T> PolicyExt for Twhere
T: ?Sized,
Source§impl<T> SaturatingAs for T
impl<T> SaturatingAs for T
Source§fn saturating_as<Dst>(self) -> Dstwhere
T: SaturatingCast<Dst>,
fn saturating_as<Dst>(self) -> Dstwhere
T: SaturatingCast<Dst>,
Casts the value.
Source§impl<Src, Dst> SaturatingCastFrom<Src> for Dstwhere
Src: SaturatingCast<Dst>,
impl<Src, Dst> SaturatingCastFrom<Src> for Dstwhere
Src: SaturatingCast<Dst>,
Source§fn saturating_cast_from(src: Src) -> Dst
fn saturating_cast_from(src: Src) -> Dst
Casts the value.
Source§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
Source§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
The inverse inclusion map: attempts to construct
self from the equivalent element of its
superset. Read moreSource§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
Checks if
self is actually part of its subset T (and can be converted to it).Source§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
Use with care! Same as
self.to_subset but without any property checks. Always succeeds.Source§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
The inclusion map: converts
self to the equivalent element of its superset.Source§impl<T> UnwrappedAs for T
impl<T> UnwrappedAs for T
Source§fn unwrapped_as<Dst>(self) -> Dstwhere
T: UnwrappedCast<Dst>,
fn unwrapped_as<Dst>(self) -> Dstwhere
T: UnwrappedCast<Dst>,
Casts the value.
Source§impl<Src, Dst> UnwrappedCastFrom<Src> for Dstwhere
Src: UnwrappedCast<Dst>,
impl<Src, Dst> UnwrappedCastFrom<Src> for Dstwhere
Src: UnwrappedCast<Dst>,
Source§fn unwrapped_cast_from(src: Src) -> Dst
fn unwrapped_cast_from(src: Src) -> Dst
Casts the value.
Source§impl<T> WithSubscriber for T
impl<T> WithSubscriber for T
Source§fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
Source§fn with_current_subscriber(self) -> WithDispatch<Self>
fn with_current_subscriber(self) -> WithDispatch<Self>
Source§impl<T> WrappingAs for T
impl<T> WrappingAs for T
Source§fn wrapping_as<Dst>(self) -> Dstwhere
T: WrappingCast<Dst>,
fn wrapping_as<Dst>(self) -> Dstwhere
T: WrappingCast<Dst>,
Casts the value.
Source§impl<Src, Dst> WrappingCastFrom<Src> for Dstwhere
Src: WrappingCast<Dst>,
impl<Src, Dst> WrappingCastFrom<Src> for Dstwhere
Src: WrappingCast<Dst>,
Source§fn wrapping_cast_from(src: Src) -> Dst
fn wrapping_cast_from(src: Src) -> Dst
Casts the value.