pub struct SparseTensor<T = f64>where
T: Number,{ /* private fields */ }
Implementations§
Source§impl<T> SparseTensor<T>where
T: Number,
impl<T> SparseTensor<T>where
T: Number,
Source§impl<T> SparseTensor<T>where
T: Number,
impl<T> SparseTensor<T>where
T: Number,
pub fn mul_kronecker_deltas( &self, deltas: &[KroneckerDelta], ) -> Result<Self, TensorError>
Source§impl<T> SparseTensor<T>where
T: Number,
impl<T> SparseTensor<T>where
T: Number,
pub fn new(sizes: Vec<usize>) -> Self
pub fn from( sizes: Vec<usize>, elems: HashMap<Vec<usize>, T>, ) -> Result<Self, TensorError>
pub fn is_same_size(&self, other: &SparseTensor<T>) -> bool
pub fn total_size(&self) -> usize
pub fn not_1dimension_ranks(&self) -> usize
pub fn reduce_1dimension_rank(&self) -> Self
pub fn to_vec(&self) -> Vec<T>
pub fn to_mat(&self) -> Matrix<T>
pub fn elems(&self) -> &HashMap<Vec<usize>, T>
pub fn elems_mut(&mut self) -> &mut HashMap<Vec<usize>, T>
pub fn eject(self) -> (Vec<usize>, HashMap<Vec<usize>, T>)
Trait Implementations§
Source§impl<T> Add<&SparseTensor<T>> for SparseTensor<T>where
T: Number,
impl<T> Add<&SparseTensor<T>> for SparseTensor<T>where
T: Number,
Source§type Output = SparseTensor<T>
type Output = SparseTensor<T>
The resulting type after applying the
+
operator.Source§impl<T> Add<SparseTensor<T>> for &SparseTensor<T>where
T: Number,
impl<T> Add<SparseTensor<T>> for &SparseTensor<T>where
T: Number,
Source§type Output = SparseTensor<T>
type Output = SparseTensor<T>
The resulting type after applying the
+
operator.Source§impl Add<SparseTensor> for &f64
impl Add<SparseTensor> for &f64
Source§impl Add<SparseTensor> for f64
impl Add<SparseTensor> for f64
Source§impl<T> Add<T> for SparseTensor<T>where
T: Number,
impl<T> Add<T> for SparseTensor<T>where
T: Number,
Source§impl<T> Add for SparseTensor<T>where
T: Number,
impl<T> Add for SparseTensor<T>where
T: Number,
Source§type Output = SparseTensor<T>
type Output = SparseTensor<T>
The resulting type after applying the
+
operator.Source§impl<T> AddAssign for SparseTensor<T>where
T: Number,
impl<T> AddAssign for SparseTensor<T>where
T: Number,
Source§fn add_assign(&mut self, rhs: SparseTensor<T>)
fn add_assign(&mut self, rhs: SparseTensor<T>)
Performs the
+=
operation. Read moreSource§impl<T> Clone for SparseTensor<T>
impl<T> Clone for SparseTensor<T>
Source§fn clone(&self) -> SparseTensor<T>
fn clone(&self) -> SparseTensor<T>
Returns a duplicate of the value. Read more
1.0.0 · Source§const fn clone_from(&mut self, source: &Self)
const fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moreSource§impl<T> Debug for SparseTensor<T>
impl<T> Debug for SparseTensor<T>
Source§impl<'de, T> Deserialize<'de> for SparseTensor<T>where
T: Number + Deserialize<'de>,
impl<'de, T> Deserialize<'de> for SparseTensor<T>where
T: Number + Deserialize<'de>,
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
Source§impl<T> Div<&SparseTensor<T>> for SparseTensor<T>where
T: Number,
impl<T> Div<&SparseTensor<T>> for SparseTensor<T>where
T: Number,
Source§type Output = SparseTensor<T>
type Output = SparseTensor<T>
The resulting type after applying the
/
operator.Source§impl<T> Div<SparseTensor<T>> for &SparseTensor<T>where
T: Number,
impl<T> Div<SparseTensor<T>> for &SparseTensor<T>where
T: Number,
Source§type Output = SparseTensor<T>
type Output = SparseTensor<T>
The resulting type after applying the
/
operator.Source§impl Div<SparseTensor> for &f64
impl Div<SparseTensor> for &f64
Source§impl Div<SparseTensor> for f64
impl Div<SparseTensor> for f64
Source§impl<T> Div<T> for SparseTensor<T>where
T: Number,
impl<T> Div<T> for SparseTensor<T>where
T: Number,
Source§impl<T> Div for SparseTensor<T>where
T: Number,
impl<T> Div for SparseTensor<T>where
T: Number,
Source§type Output = SparseTensor<T>
type Output = SparseTensor<T>
The resulting type after applying the
/
operator.Source§impl<T> DivAssign for SparseTensor<T>where
T: Number,
impl<T> DivAssign for SparseTensor<T>where
T: Number,
Source§fn div_assign(&mut self, rhs: SparseTensor<T>)
fn div_assign(&mut self, rhs: SparseTensor<T>)
Performs the
/=
operation. Read moreSource§impl<T> Mul<&SparseTensor<T>> for KroneckerDeltawhere
T: Number,
impl<T> Mul<&SparseTensor<T>> for KroneckerDeltawhere
T: Number,
Source§type Output = SparseTensor<T>
type Output = SparseTensor<T>
The resulting type after applying the
*
operator.Source§impl<T> Mul<&SparseTensor<T>> for SparseTensor<T>where
T: Number,
impl<T> Mul<&SparseTensor<T>> for SparseTensor<T>where
T: Number,
Source§type Output = SparseTensor<T>
type Output = SparseTensor<T>
The resulting type after applying the
*
operator.Source§impl<T> Mul<&SparseTensor<T>> for Vec<KroneckerDelta>where
T: Number,
impl<T> Mul<&SparseTensor<T>> for Vec<KroneckerDelta>where
T: Number,
Source§type Output = SparseTensor<T>
type Output = SparseTensor<T>
The resulting type after applying the
*
operator.Source§impl<T> Mul<KroneckerDelta> for &SparseTensor<T>where
T: Number,
impl<T> Mul<KroneckerDelta> for &SparseTensor<T>where
T: Number,
Source§type Output = SparseTensor<T>
type Output = SparseTensor<T>
The resulting type after applying the
*
operator.Source§impl<T> Mul<KroneckerDelta> for SparseTensor<T>where
T: Number,
impl<T> Mul<KroneckerDelta> for SparseTensor<T>where
T: Number,
Source§type Output = SparseTensor<T>
type Output = SparseTensor<T>
The resulting type after applying the
*
operator.Source§impl<T> Mul<SparseTensor<T>> for &SparseTensor<T>where
T: Number,
impl<T> Mul<SparseTensor<T>> for &SparseTensor<T>where
T: Number,
Source§type Output = SparseTensor<T>
type Output = SparseTensor<T>
The resulting type after applying the
*
operator.Source§impl<T> Mul<SparseTensor<T>> for KroneckerDeltawhere
T: Number,
impl<T> Mul<SparseTensor<T>> for KroneckerDeltawhere
T: Number,
Source§type Output = SparseTensor<T>
type Output = SparseTensor<T>
The resulting type after applying the
*
operator.Source§impl<T> Mul<SparseTensor<T>> for Vec<KroneckerDelta>where
T: Number,
impl<T> Mul<SparseTensor<T>> for Vec<KroneckerDelta>where
T: Number,
Source§type Output = SparseTensor<T>
type Output = SparseTensor<T>
The resulting type after applying the
*
operator.Source§impl Mul<SparseTensor> for &f64
impl Mul<SparseTensor> for &f64
Source§impl Mul<SparseTensor> for f64
impl Mul<SparseTensor> for f64
Source§impl<T> Mul<T> for SparseTensor<T>where
T: Number,
impl<T> Mul<T> for SparseTensor<T>where
T: Number,
Source§impl<T> Mul<Vec<KroneckerDelta>> for &SparseTensor<T>where
T: Number,
impl<T> Mul<Vec<KroneckerDelta>> for &SparseTensor<T>where
T: Number,
Source§impl<T> Mul<Vec<KroneckerDelta>> for SparseTensor<T>where
T: Number,
impl<T> Mul<Vec<KroneckerDelta>> for SparseTensor<T>where
T: Number,
Source§impl<T> Mul for SparseTensor<T>where
T: Number,
impl<T> Mul for SparseTensor<T>where
T: Number,
Source§type Output = SparseTensor<T>
type Output = SparseTensor<T>
The resulting type after applying the
*
operator.Source§impl<T> MulAssign for SparseTensor<T>where
T: Number,
impl<T> MulAssign for SparseTensor<T>where
T: Number,
Source§fn mul_assign(&mut self, rhs: SparseTensor<T>)
fn mul_assign(&mut self, rhs: SparseTensor<T>)
Performs the
*=
operation. Read moreSource§impl<T> Neg for SparseTensor<T>where
T: Number,
impl<T> Neg for SparseTensor<T>where
T: Number,
Source§impl<T> PartialEq for SparseTensor<T>
impl<T> PartialEq for SparseTensor<T>
Source§impl<T> Serialize for SparseTensor<T>
impl<T> Serialize for SparseTensor<T>
Source§impl<T> Sub<&SparseTensor<T>> for SparseTensor<T>where
T: Number,
impl<T> Sub<&SparseTensor<T>> for SparseTensor<T>where
T: Number,
Source§type Output = SparseTensor<T>
type Output = SparseTensor<T>
The resulting type after applying the
-
operator.Source§impl<T> Sub<SparseTensor<T>> for &SparseTensor<T>where
T: Number,
impl<T> Sub<SparseTensor<T>> for &SparseTensor<T>where
T: Number,
Source§type Output = SparseTensor<T>
type Output = SparseTensor<T>
The resulting type after applying the
-
operator.Source§impl Sub<SparseTensor> for &f64
impl Sub<SparseTensor> for &f64
Source§impl Sub<SparseTensor> for f64
impl Sub<SparseTensor> for f64
Source§impl<T> Sub<T> for SparseTensor<T>where
T: Number,
impl<T> Sub<T> for SparseTensor<T>where
T: Number,
Source§impl<T> Sub for SparseTensor<T>where
T: Number,
impl<T> Sub for SparseTensor<T>where
T: Number,
Source§type Output = SparseTensor<T>
type Output = SparseTensor<T>
The resulting type after applying the
-
operator.Source§impl<T> SubAssign for SparseTensor<T>where
T: Number,
impl<T> SubAssign for SparseTensor<T>where
T: Number,
Source§fn sub_assign(&mut self, rhs: SparseTensor<T>)
fn sub_assign(&mut self, rhs: SparseTensor<T>)
Performs the
-=
operation. Read moreSource§impl<T> Tensor<T> for SparseTensor<T>where
T: Number,
impl<T> Tensor<T> for SparseTensor<T>where
T: Number,
impl<T> StructuralPartialEq for SparseTensor<T>where
T: Number,
Auto Trait Implementations§
impl<T> Freeze for SparseTensor<T>where
T: Freeze,
impl<T> RefUnwindSafe for SparseTensor<T>where
T: RefUnwindSafe,
impl<T> Send for SparseTensor<T>
impl<T> Sync for SparseTensor<T>
impl<T> Unpin for SparseTensor<T>where
T: Unpin,
impl<T> UnwindSafe for SparseTensor<T>where
T: UnwindSafe,
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> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
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