pub enum SparseAccess<Txn, FE, T: CType> {
Show 21 variants Base(SparseBase<Txn, FE, T>), Table(SparseFile<FE, T>), Broadcast(Box<SparseBroadcast<Txn, FE, T>>), BroadcastAxis(Box<SparseBroadcastAxis<Self>>), Combine(Box<SparseCombine<Self, Self, T>>), CombineLeft(Box<SparseCombineLeft<Self, Self, T>>), CombineConst(Box<SparseCombineConst<Self, T>>), Compare(Box<SparseCompare<Txn, FE, T>>), CompareConst(Box<SparseCompareConst<Txn, FE, T>>), CompareLeft(Box<SparseCompareLeft<Txn, FE, T>>), Cond(Box<SparseCond<SparseAccess<Txn, FE, u8>, Self, Self>>), Cow(Box<SparseCow<FE, T, Self>>), Dense(Box<SparseDense<Txn, FE, T>>), Expand(Box<SparseExpand<Self>>), Reduce(Box<SparseReduce<Txn, FE, T>>), Reshape(Box<SparseReshape<Self>>), Slice(Box<SparseSlice<Self>>), Transpose(Box<SparseTranspose<Self>>), Unary(Box<SparseUnary<Self, T>>), UnaryCast(Box<SparseUnaryCast<Txn, FE, T>>), Version(SparseVersion<FE, T>),
}

Variants§

§

Base(SparseBase<Txn, FE, T>)

§

Table(SparseFile<FE, T>)

§

Broadcast(Box<SparseBroadcast<Txn, FE, T>>)

§

BroadcastAxis(Box<SparseBroadcastAxis<Self>>)

§

Combine(Box<SparseCombine<Self, Self, T>>)

§

CombineLeft(Box<SparseCombineLeft<Self, Self, T>>)

§

CombineConst(Box<SparseCombineConst<Self, T>>)

§

Compare(Box<SparseCompare<Txn, FE, T>>)

§

CompareConst(Box<SparseCompareConst<Txn, FE, T>>)

§

CompareLeft(Box<SparseCompareLeft<Txn, FE, T>>)

§

Cond(Box<SparseCond<SparseAccess<Txn, FE, u8>, Self, Self>>)

§

Cow(Box<SparseCow<FE, T, Self>>)

§

Dense(Box<SparseDense<Txn, FE, T>>)

§

Expand(Box<SparseExpand<Self>>)

§

Reduce(Box<SparseReduce<Txn, FE, T>>)

§

Reshape(Box<SparseReshape<Self>>)

§

Slice(Box<SparseSlice<Self>>)

§

Transpose(Box<SparseTranspose<Self>>)

§

Unary(Box<SparseUnary<Self, T>>)

§

UnaryCast(Box<SparseUnaryCast<Txn, FE, T>>)

§

Version(SparseVersion<FE, T>)

Trait Implementations§

source§

impl<Txn, FE, T: CType> Clone for SparseAccess<Txn, FE, T>

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<Txn, FE, T> Debug for SparseAccess<Txn, FE, T>
where Txn: ThreadSafe, FE: ThreadSafe, T: CType + DType,

source§

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

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

impl<Txn, FE> From<SparseAccess<Txn, FE, f32>> for SparseAccessCast<Txn, FE>

source§

fn from(access: SparseAccess<Txn, FE, f32>) -> Self

Converts to this type from the input type.
source§

impl<Txn, FE> From<SparseAccess<Txn, FE, f64>> for SparseAccessCast<Txn, FE>

source§

fn from(access: SparseAccess<Txn, FE, f64>) -> Self

Converts to this type from the input type.
source§

impl<Txn, FE> From<SparseAccess<Txn, FE, i16>> for SparseAccessCast<Txn, FE>

source§

fn from(access: SparseAccess<Txn, FE, i16>) -> Self

Converts to this type from the input type.
source§

impl<Txn, FE> From<SparseAccess<Txn, FE, i32>> for SparseAccessCast<Txn, FE>

source§

fn from(access: SparseAccess<Txn, FE, i32>) -> Self

Converts to this type from the input type.
source§

impl<Txn, FE> From<SparseAccess<Txn, FE, i64>> for SparseAccessCast<Txn, FE>

source§

fn from(access: SparseAccess<Txn, FE, i64>) -> Self

Converts to this type from the input type.
source§

impl<Txn, FE> From<SparseAccess<Txn, FE, u16>> for SparseAccessCast<Txn, FE>

source§

fn from(access: SparseAccess<Txn, FE, u16>) -> Self

Converts to this type from the input type.
source§

impl<Txn, FE> From<SparseAccess<Txn, FE, u32>> for SparseAccessCast<Txn, FE>

source§

fn from(access: SparseAccess<Txn, FE, u32>) -> Self

Converts to this type from the input type.
source§

impl<Txn, FE> From<SparseAccess<Txn, FE, u64>> for SparseAccessCast<Txn, FE>

source§

fn from(access: SparseAccess<Txn, FE, u64>) -> Self

Converts to this type from the input type.
source§

impl<Txn, FE> From<SparseAccess<Txn, FE, u8>> for SparseAccessCast<Txn, FE>

source§

fn from(access: SparseAccess<Txn, FE, u8>) -> Self

Converts to this type from the input type.
source§

impl<Txn, FE, T: CType> From<SparseBroadcast<Txn, FE, T>> for SparseAccess<Txn, FE, T>

source§

fn from(accessor: SparseBroadcast<Txn, FE, T>) -> Self

Converts to this type from the input type.
source§

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

source§

fn from(broadcast: SparseBroadcastAxis<S>) -> Self

Converts to this type from the input type.
source§

impl<Txn, FE, L, R, T> From<SparseCombine<L, R, T>> for SparseAccess<Txn, FE, T>
where L: Into<SparseAccess<Txn, FE, T>>, R: Into<SparseAccess<Txn, FE, T>>, T: CType,

source§

fn from(combine: SparseCombine<L, R, T>) -> Self

Converts to this type from the input type.
source§

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

source§

fn from(combine: SparseCombineConst<S, T>) -> Self

Converts to this type from the input type.
source§

impl<Txn, FE, L, R, T> From<SparseCombineLeft<L, R, T>> for SparseAccess<Txn, FE, T>
where FE: ThreadSafe, L: Into<SparseAccess<Txn, FE, T>>, R: Into<SparseAccess<Txn, FE, T>>, T: CType,

source§

fn from(combine: SparseCombineLeft<L, R, T>) -> Self

Converts to this type from the input type.
source§

impl<Txn, FE, T: CType> From<SparseCompare<Txn, FE, T>> for SparseAccess<Txn, FE, T>

source§

fn from(compare: SparseCompare<Txn, FE, T>) -> Self

Converts to this type from the input type.
source§

impl<Txn, FE, T: CType> From<SparseCompareConst<Txn, FE, T>> for SparseAccess<Txn, FE, T>

source§

fn from(compare: SparseCompareConst<Txn, FE, T>) -> Self

Converts to this type from the input type.
source§

impl<Txn, FE, T: CType> From<SparseCompareLeft<Txn, FE, T>> for SparseAccess<Txn, FE, T>

source§

fn from(compare: SparseCompareLeft<Txn, FE, T>) -> Self

Converts to this type from the input type.
source§

impl<Txn, FE, Cond, Then, OrElse, T> From<SparseCond<Cond, Then, OrElse>> for SparseAccess<Txn, FE, T>
where Cond: Into<SparseAccess<Txn, FE, u8>>, Then: Into<SparseAccess<Txn, FE, T>>, OrElse: Into<SparseAccess<Txn, FE, T>>, T: CType,

source§

fn from(cond: SparseCond<Cond, Then, OrElse>) -> Self

Converts to this type from the input type.
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<Txn, FE, T: CType> From<SparseDense<Txn, FE, T>> for SparseAccess<Txn, FE, T>

source§

fn from(dense: SparseDense<Txn, FE, T>) -> Self

Converts to this type from the input type.
source§

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

source§

fn from(expand: SparseExpand<S>) -> Self

Converts to this type from the input type.
source§

impl<Txn, FE, T> From<SparseReduce<Txn, FE, T>> for SparseAccess<Txn, FE, T>
where T: CType,

source§

fn from(reduce: SparseReduce<Txn, FE, T>) -> Self

Converts to this type from the input type.
source§

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

source§

fn from(reshape: SparseReshape<S>) -> Self

Converts to this type from the input type.
source§

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

source§

fn from(slice: SparseSlice<S>) -> Self

Converts to this type from the input type.
source§

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

source§

fn from(transpose: SparseTranspose<S>) -> Self

Converts to this type from the input type.
source§

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

source§

fn from(unary: SparseUnary<S, T>) -> Self

Converts to this type from the input type.
source§

impl<Txn, FE, T: CType> From<SparseUnaryCast<Txn, FE, T>> for SparseAccess<Txn, FE, T>

source§

fn from(unary: SparseUnaryCast<Txn, FE, T>) -> Self

Converts to this type from the input type.
source§

impl<Txn, FE, T: CType> From<SparseVersion<FE, T>> for SparseAccess<Txn, FE, T>

source§

fn from(version: SparseVersion<FE, T>) -> Self

Converts to this type from the input type.
source§

impl<Txn, FE, T> SparseInstance for SparseAccess<Txn, FE, T>
where Txn: Transaction<FE>, FE: DenseCacheFile + AsType<Node> + AsType<Buffer<T>>, T: CType + DType + Debug, Buffer<T>: FromStream<Context = ()>, Number: From<T> + CastInto<T>,

§

type CoordBlock = Accessor<u64>

§

type ValueBlock = Accessor<T>

§

type Blocks = Pin<Box<dyn Stream<Item = Result<(Array<u64, <SparseAccess<Txn, FE, T> as SparseInstance>::CoordBlock, Platform>, Array<T, <SparseAccess<Txn, FE, T> 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<Txn, FE, T> TensorInstance for SparseAccess<Txn, FE, T>
where Txn: ThreadSafe, FE: ThreadSafe, T: CType + DType,

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<Txn, FE, T> TensorPermitRead for SparseAccess<Txn, FE, T>
where Txn: ThreadSafe, FE: ThreadSafe, T: CType + DType,

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<Txn, FE, T> TensorPermitWrite for SparseAccess<Txn, FE, T>
where Txn: ThreadSafe, FE: ThreadSafe, T: CType + DType,

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<Txn, FE, T> !RefUnwindSafe for SparseAccess<Txn, FE, T>

§

impl<Txn, FE, T> Send for SparseAccess<Txn, FE, T>
where FE: Sync + Send, Txn: Sync + Send,

§

impl<Txn, FE, T> Sync for SparseAccess<Txn, FE, T>
where FE: Sync + Send, Txn: Sync + Send,

§

impl<Txn, FE, T> Unpin for SparseAccess<Txn, FE, T>
where T: Unpin,

§

impl<Txn, FE, T> !UnwindSafe for SparseAccess<Txn, FE, T>

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,