pub struct SparseCow<FE, T, S> { /* private fields */ }

Implementations§

source§

impl<FE, T, S> SparseCow<FE, T, S>

source

pub fn create( source: S, filled: SparseFile<FE, T>, zeros: SparseFile<FE, T> ) -> Self
where S: Debug,

source

pub fn into_deltas(self) -> (SparseFile<FE, T>, SparseFile<FE, T>)

Trait Implementations§

source§

impl<FE, T, S: Clone> Clone for SparseCow<FE, T, S>

source§

fn clone(&self) -> Self

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl<FE, T, S> Debug for SparseCow<FE, T, S>
where FE: ThreadSafe, T: CType + DType, S: Debug,

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<Txn, FE, T, S> From<SparseCow<FE, T, S>> for SparseAccess<Txn, FE, T>
where T: CType, S: Into<SparseAccess<Txn, FE, T>>,

source§

fn from(cow: SparseCow<FE, T, S>) -> Self

Converts to this type from the input type.
source§

impl<FE, T, S> SparseInstance for SparseCow<FE, T, S>
where FE: AsType<Node> + ThreadSafe, T: CType + DType + Debug, S: SparseInstance<DType = T>, Number: CastInto<T>,

§

type CoordBlock = Accessor<u64>

§

type ValueBlock = AccessBuf<Buffer<T>>

§

type Blocks = Pin<Box<dyn Stream<Item = Result<(Array<u64, <SparseCow<FE, T, S> as SparseInstance>::CoordBlock, Platform>, Array<T, <SparseCow<FE, T, S> as SparseInstance>::ValueBlock, Platform>), TCError>> + Send>>

§

type DType = T

source§

fn blocks<'async_trait>( self, txn_id: TxnId, range: Range, order: Axes ) -> Pin<Box<dyn Future<Output = Result<Self::Blocks, TCError>> + Send + 'async_trait>>
where Self: 'async_trait,

source§

fn elements<'async_trait>( self, txn_id: TxnId, range: Range, order: Axes ) -> Pin<Box<dyn Future<Output = Result<Elements<Self::DType>, TCError>> + Send + 'async_trait>>
where Self: 'async_trait,

source§

fn read_value<'life0, 'async_trait>( &'life0 self, txn_id: TxnId, coord: Coord ) -> Pin<Box<dyn Future<Output = Result<Self::DType, TCError>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

source§

fn filled_at<'async_trait>( self, txn_id: TxnId, range: Range, order: Axes, axes: Axes ) -> Pin<Box<dyn Future<Output = TCResult<TCBoxTryStream<'static, Coord>>> + Send + 'async_trait>>
where Self: Sized + Send + 'async_trait,

source§

impl<'a, FE, T, S> SparseWriteLock<'a> for SparseCow<FE, T, S>
where FE: AsType<Node> + ThreadSafe, T: CType + DType + Debug, S: SparseInstance<DType = T> + Clone, Number: From<T> + CastInto<T>,

§

type Guard = SparseCowWriteGuard<'a, FE, T, S>

source§

fn write<'async_trait>( &'a self ) -> Pin<Box<dyn Future<Output = Self::Guard> + Send + 'async_trait>>
where Self: 'async_trait, 'a: 'async_trait,

source§

impl<FE, T, S> TensorInstance for SparseCow<FE, T, S>
where FE: ThreadSafe, T: CType + DType, S: TensorInstance,

source§

fn dtype(&self) -> NumberType

source§

fn shape(&self) -> &Shape

source§

fn ndim(&self) -> usize

source§

fn size(&self) -> u64

source§

fn schema(&self) -> Schema

source§

impl<FE, T, S> TensorPermitRead for SparseCow<FE, T, S>
where FE: Send + Sync, T: CType + DType, S: TensorPermitRead,

source§

fn read_permit<'life0, 'async_trait>( &'life0 self, txn_id: TxnId, range: Range ) -> Pin<Box<dyn Future<Output = TCResult<SmallVec<[PermitRead<Range>; 16]>>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Acquire a read lock on the given range of this tensor.
source§

impl<FE, T, S> TensorPermitWrite for SparseCow<FE, T, S>
where FE: Send + Sync, T: CType + DType, S: TensorPermitWrite,

source§

fn write_permit<'life0, 'async_trait>( &'life0 self, txn_id: TxnId, range: Range ) -> Pin<Box<dyn Future<Output = TCResult<PermitWrite<Range>>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Acquire a write lock on the given range of this tensor.

Auto Trait Implementations§

§

impl<FE, T, S> !RefUnwindSafe for SparseCow<FE, T, S>

§

impl<FE, T, S> Send for SparseCow<FE, T, S>
where FE: Sync + Send, S: Send, T: Send,

§

impl<FE, T, S> Sync for SparseCow<FE, T, S>
where FE: Sync + Send, S: Sync, T: Sync,

§

impl<FE, T, S> Unpin for SparseCow<FE, T, S>
where S: Unpin, T: Unpin,

§

impl<FE, T, S> !UnwindSafe for SparseCow<FE, T, S>

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<F, T> CastFrom<F> for T
where T: From<F>,

source§

fn cast_from(f: F) -> T

Cast an instance of T into an instance of Self.
source§

impl<T, F> CastInto<F> for T
where F: CastFrom<T>,

source§

fn cast_into(self) -> F

Cast an instance of Self into an instance of T.
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<F> Match for F

source§

fn matches<T>(&self) -> bool
where T: TryCastFrom<Self>,

Returns true if self can be cast into the target type T.
§

impl<T> Pointable for T

§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
source§

impl<T> Same for T

§

type Output = T

Should always be Self
source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<State, T> ToState<State> for T
where State: StateInstance, T: Clone + Into<State>,

source§

fn to_state(&self) -> State

source§

impl<F, T> TryCastFrom<F> for T
where T: CastFrom<F>,

source§

fn can_cast_from(_: &F) -> bool

Test if value can be cast into Self.
source§

fn opt_cast_from(f: F) -> Option<T>

Returns Some(Self) if the source value can be cast into Self, otherwise None.
source§

fn try_cast_from<Err, OnErr>(value: T, on_err: OnErr) -> Result<Self, Err>
where OnErr: FnOnce(&T) -> Err,

Returns Ok(Self) if the source value can be cast into Self, otherwise calls on_err.
source§

impl<F, T> TryCastInto<T> for F
where T: TryCastFrom<F>,

source§

fn can_cast_into(&self) -> bool

Test if self can be cast into T.
source§

fn opt_cast_into(self) -> Option<T>

Returns Some(T) if self can be cast into T, otherwise None.
source§

fn try_cast_into<Err, OnErr>(self, on_err: OnErr) -> Result<T, Err>
where OnErr: FnOnce(&Self) -> Err,

Returns Ok(T) if self can be cast into T, otherwise calls on_err.
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

source§

impl<T> ThreadSafe for T
where T: Send + Sync + 'static,