pub type SparseColMatMut<'a, I, T, Rows = usize, Cols = usize> = SparseColMat<Mut<'a, I, T, Rows, Cols>>;Expand description
view over sparse column major matrix
Aliased Type§
#[repr(transparent)]pub struct SparseColMatMut<'a, I, T, Rows = usize, Cols = usize>(pub Mut<'a, I, T, Rows, Cols>);Tuple Fields§
§0: Mut<'a, I, T, Rows, Cols>Implementations§
Source§impl<'a, Rows: Shape, Cols: Shape, I: Index, T> SparseColMatMut<'a, I, T, Rows, Cols>
impl<'a, Rows: Shape, Cols: Shape, I: Index, T> SparseColMatMut<'a, I, T, Rows, Cols>
Sourcepub fn new(
symbolic: SymbolicSparseColMatRef<'a, I, Rows, Cols>,
val: &'a mut [T],
) -> Self
pub fn new( symbolic: SymbolicSparseColMatRef<'a, I, Rows, Cols>, val: &'a mut [T], ) -> Self
Sourcepub fn parts(self) -> (SymbolicSparseColMatRef<'a, I, Rows, Cols>, &'a [T])
pub fn parts(self) -> (SymbolicSparseColMatRef<'a, I, Rows, Cols>, &'a [T])
Sourcepub fn parts_mut(
self,
) -> (SymbolicSparseColMatRef<'a, I, Rows, Cols>, &'a mut [T])
pub fn parts_mut( self, ) -> (SymbolicSparseColMatRef<'a, I, Rows, Cols>, &'a mut [T])
Sourcepub fn symbolic(&self) -> SymbolicSparseColMatRef<'a, I, Rows, Cols>
pub fn symbolic(&self) -> SymbolicSparseColMatRef<'a, I, Rows, Cols>
Sourcepub fn val_of_col(self, j: Idx<Cols>) -> &'a [T]
pub fn val_of_col(self, j: Idx<Cols>) -> &'a [T]
Sourcepub fn val_of_col_mut(self, j: Idx<Cols>) -> &'a mut [T]
pub fn val_of_col_mut(self, j: Idx<Cols>) -> &'a mut [T]
Sourcepub fn idx_val_of_col_mut(
self,
j: Idx<Cols>,
) -> (impl 'a + Clone + ExactSizeIterator + DoubleEndedIterator<Item = Idx<Rows>>, &'a mut [T])where
Rows: 'a,
Cols: 'a,
pub fn idx_val_of_col_mut(
self,
j: Idx<Cols>,
) -> (impl 'a + Clone + ExactSizeIterator + DoubleEndedIterator<Item = Idx<Rows>>, &'a mut [T])where
Rows: 'a,
Cols: 'a,
Sourcepub fn as_shape<V: Shape, H: Shape>(
self,
nrows: V,
ncols: H,
) -> SparseColMatRef<'a, I, T, V, H>
pub fn as_shape<V: Shape, H: Shape>( self, nrows: V, ncols: H, ) -> SparseColMatRef<'a, I, T, V, H>
Sourcepub fn as_shape_mut<V: Shape, H: Shape>(
self,
nrows: V,
ncols: H,
) -> SparseColMatMut<'a, I, T, V, H>
pub fn as_shape_mut<V: Shape, H: Shape>( self, nrows: V, ncols: H, ) -> SparseColMatMut<'a, I, T, V, H>
Sourcepub fn as_dyn(self) -> SparseColMatRef<'a, I, T>
pub fn as_dyn(self) -> SparseColMatRef<'a, I, T>
Sourcepub fn as_dyn_mut(self) -> SparseColMatMut<'a, I, T>
pub fn as_dyn_mut(self) -> SparseColMatMut<'a, I, T>
Sourcepub fn transpose(self) -> SparseRowMatRef<'a, I, T, Cols, Rows>
pub fn transpose(self) -> SparseRowMatRef<'a, I, T, Cols, Rows>
Sourcepub fn transpose_mut(self) -> SparseRowMatMut<'a, I, T, Cols, Rows>
pub fn transpose_mut(self) -> SparseRowMatMut<'a, I, T, Cols, Rows>
Sourcepub fn conjugate(self) -> SparseColMatRef<'a, I, T::Conj, Rows, Cols>where
T: Conjugate,
pub fn conjugate(self) -> SparseColMatRef<'a, I, T::Conj, Rows, Cols>where
T: Conjugate,
Sourcepub fn conjugate_mut(self) -> SparseColMatMut<'a, I, T::Conj, Rows, Cols>where
T: Conjugate,
pub fn conjugate_mut(self) -> SparseColMatMut<'a, I, T::Conj, Rows, Cols>where
T: Conjugate,
Sourcepub fn adjoint(self) -> SparseRowMatRef<'a, I, T::Conj, Cols, Rows>where
T: Conjugate,
pub fn adjoint(self) -> SparseRowMatRef<'a, I, T::Conj, Cols, Rows>where
T: Conjugate,
Sourcepub fn adjoint_mut(self) -> SparseRowMatMut<'a, I, T::Conj, Cols, Rows>where
T: Conjugate,
pub fn adjoint_mut(self) -> SparseRowMatMut<'a, I, T::Conj, Cols, Rows>where
T: Conjugate,
Sourcepub fn canonical(self) -> SparseColMatRef<'a, I, T::Canonical, Rows, Cols>where
T: Conjugate,
pub fn canonical(self) -> SparseColMatRef<'a, I, T::Canonical, Rows, Cols>where
T: Conjugate,
Sourcepub fn canonical_mut(self) -> SparseColMatMut<'a, I, T::Canonical, Rows, Cols>where
T: Conjugate,
pub fn canonical_mut(self) -> SparseColMatMut<'a, I, T::Canonical, Rows, Cols>where
T: Conjugate,
Sourcepub fn to_row_major(
&self,
) -> Result<SparseRowMat<I, T::Canonical, Rows, Cols>, FaerError>where
T: Conjugate,
pub fn to_row_major(
&self,
) -> Result<SparseRowMat<I, T::Canonical, Rows, Cols>, FaerError>where
T: Conjugate,
Methods from Deref<Target = SymbolicSparseColMatRef<'a, I, Rows, Cols>>§
Sourcepub fn shape(&self) -> (Rows, Cols)
pub fn shape(&self) -> (Rows, Cols)
returns the number of rows and columns of the matrix
Sourcepub fn to_owned(&self) -> Result<SymbolicSparseColMat<I, Rows, Cols>, FaerError>
pub fn to_owned(&self) -> Result<SymbolicSparseColMat<I, Rows, Cols>, FaerError>
returns a newly allocated matrix holding the values of self
Sourcepub fn to_row_major(
&self,
) -> Result<SymbolicSparseRowMat<I, Rows, Cols>, FaerError>
pub fn to_row_major( &self, ) -> Result<SymbolicSparseRowMat<I, Rows, Cols>, FaerError>
returns a newly allocated matrix holding the values of self in row major format
Sourcepub fn compute_nnz(&self) -> usize
pub fn compute_nnz(&self) -> usize
returns the number of non-zero elements in the matrix
Sourcepub fn col_range(&self, j: Idx<Cols>) -> Range<usize>
pub fn col_range(&self, j: Idx<Cols>) -> Range<usize>
returns the range specifying the indices of column j
Sourcepub unsafe fn col_range_unchecked(&self, j: Idx<Cols>) -> Range<usize>
pub unsafe fn col_range_unchecked(&self, j: Idx<Cols>) -> Range<usize>
returns the range specifying the indices of column j, without bound checks
Sourcepub fn row_idx_of_col_raw(&self, j: Idx<Cols>) -> &'a [Idx<Rows, I>] ⓘ
pub fn row_idx_of_col_raw(&self, j: Idx<Cols>) -> &'a [Idx<Rows, I>] ⓘ
returns the row indices of column j
Sourcepub fn row_idx_of_col(
&self,
j: Idx<Cols>,
) -> impl 'a + Clone + ExactSizeIterator + DoubleEndedIterator<Item = Idx<Rows>>where
Rows: 'a,
Cols: 'a,
pub fn row_idx_of_col(
&self,
j: Idx<Cols>,
) -> impl 'a + Clone + ExactSizeIterator + DoubleEndedIterator<Item = Idx<Rows>>where
Rows: 'a,
Cols: 'a,
returns the row indices of column j
Sourcepub fn shape(&self) -> (Rows, Cols)
pub fn shape(&self) -> (Rows, Cols)
returns the number of rows and columns of the matrix
Sourcepub fn transpose(&self) -> SymbolicSparseRowMatRef<'_, I, Cols, Rows>
pub fn transpose(&self) -> SymbolicSparseRowMatRef<'_, I, Cols, Rows>
returns a view over the transpose of self
Sourcepub fn to_owned(&self) -> Result<SymbolicSparseColMat<I, Rows, Cols>, FaerError>
pub fn to_owned(&self) -> Result<SymbolicSparseColMat<I, Rows, Cols>, FaerError>
Sourcepub fn to_row_major(
&self,
) -> Result<SymbolicSparseRowMat<I, Rows, Cols>, FaerError>
pub fn to_row_major( &self, ) -> Result<SymbolicSparseRowMat<I, Rows, Cols>, FaerError>
Sourcepub fn compute_nnz(&self) -> usize
pub fn compute_nnz(&self) -> usize
Sourcepub unsafe fn col_range_unchecked(&self, j: Idx<Cols>) -> Range<usize>
pub unsafe fn col_range_unchecked(&self, j: Idx<Cols>) -> Range<usize>
Sourcepub fn row_idx_of_col_raw(&self, j: Idx<Cols>) -> &[Idx<Rows, I>] ⓘ
pub fn row_idx_of_col_raw(&self, j: Idx<Cols>) -> &[Idx<Rows, I>] ⓘ
Sourcepub fn row_idx_of_col(
&self,
j: Idx<Cols>,
) -> impl '_ + Clone + ExactSizeIterator + DoubleEndedIterator<Item = Idx<Rows>>
pub fn row_idx_of_col( &self, j: Idx<Cols>, ) -> impl '_ + Clone + ExactSizeIterator + DoubleEndedIterator<Item = Idx<Rows>>
Sourcepub fn as_shape<V: Shape, H: Shape>(
&self,
nrows: V,
ncols: H,
) -> SymbolicSparseColMatRef<'_, I, V, H>
pub fn as_shape<V: Shape, H: Shape>( &self, nrows: V, ncols: H, ) -> SymbolicSparseColMatRef<'_, I, V, H>
Sourcepub fn as_dyn(&self) -> SymbolicSparseColMatRef<'_, I>
pub fn as_dyn(&self) -> SymbolicSparseColMatRef<'_, I>
Sourcepub fn as_ref(&self) -> SymbolicSparseColMatRef<'_, I, Rows, Cols>
pub fn as_ref(&self) -> SymbolicSparseColMatRef<'_, I, Rows, Cols>
Returns a view over the symbolic structure of self.
Trait Implementations§
Source§impl<I: Index, T: ComplexField, ViewT: Conjugate<Canonical = T>> BiLinOp<T> for SparseColMatMut<'_, I, ViewT>
impl<I: Index, T: ComplexField, ViewT: Conjugate<Canonical = T>> BiLinOp<T> for SparseColMatMut<'_, I, ViewT>
Source§fn transpose_apply_scratch(&self, rhs_ncols: usize, par: Par) -> StackReq
fn transpose_apply_scratch(&self, rhs_ncols: usize, par: Par) -> StackReq
computes the workspace layout required to apply the transpose or adjoint o
self to a matrix with rhs_ncols columnsSource§impl<I: Index, T: ComplexField, ViewT: Conjugate<Canonical = T>> BiPrecond<T> for SparseColMatMut<'_, I, ViewT>
impl<I: Index, T: ComplexField, ViewT: Conjugate<Canonical = T>> BiPrecond<T> for SparseColMatMut<'_, I, ViewT>
Source§fn transpose_apply_in_place_scratch(
&self,
rhs_ncols: usize,
par: Par,
) -> StackReq
fn transpose_apply_in_place_scratch( &self, rhs_ncols: usize, par: Par, ) -> StackReq
computes the workspace layout required to apply the transpose or adjoint of
self to a matrix with rhs_ncols columns in placeSource§impl<Rows: Shape, Cols: Shape, I: Index, T: Debug> Debug for SparseColMatMut<'_, I, T, Rows, Cols>
impl<Rows: Shape, Cols: Shape, I: Index, T: Debug> Debug for SparseColMatMut<'_, I, T, Rows, Cols>
Source§impl<'a, Rows: Shape, Cols: Shape, I: Index, T> Deref for SparseColMatMut<'a, I, T, Rows, Cols>
impl<'a, Rows: Shape, Cols: Shape, I: Index, T> Deref for SparseColMatMut<'a, I, T, Rows, Cols>
Source§impl<I: Index, T: ComplexField, ViewT: Conjugate<Canonical = T>> LinOp<T> for SparseColMatMut<'_, I, ViewT>
impl<I: Index, T: ComplexField, ViewT: Conjugate<Canonical = T>> LinOp<T> for SparseColMatMut<'_, I, ViewT>
Source§fn apply_scratch(&self, rhs_ncols: usize, par: Par) -> StackReq
fn apply_scratch(&self, rhs_ncols: usize, par: Par) -> StackReq
computes the workspace layout required to apply
self or the conjugate o
self to a matrix with rhs_ncols columnsSource§impl<I: Index, T: ComplexField, ViewT: Conjugate<Canonical = T>> Precond<T> for SparseColMatMut<'_, I, ViewT>
impl<I: Index, T: ComplexField, ViewT: Conjugate<Canonical = T>> Precond<T> for SparseColMatMut<'_, I, ViewT>
Source§fn apply_in_place_scratch(&self, rhs_ncols: usize, par: Par) -> StackReq
fn apply_in_place_scratch(&self, rhs_ncols: usize, par: Par) -> StackReq
computes the workspace layout required to apply
self or the conjugate of
self to a matrix with rhs_ncols columns in place