Struct CscMatrix

Source
pub struct CscMatrix<'a> {
    pub nrows: usize,
    pub ncols: usize,
    pub indptr: Cow<'a, [usize]>,
    pub indices: Cow<'a, [usize]>,
    pub data: Cow<'a, [f64]>,
}
Expand description

A matrix in Compressed Sparse Column format.

Fields§

§nrows: usize

The number of rows in the matrix.

§ncols: usize

The number of columns in the matrix.

§indptr: Cow<'a, [usize]>

The CSC column pointer array.

It contains the offsets into the index and data arrays of the entries in each column.

§indices: Cow<'a, [usize]>

The CSC index array.

It contains the row index of each non-zero entry.

§data: Cow<'a, [f64]>

The CSC data array.

It contains the values of each non-zero entry.

Implementations§

Source§

impl<'a> CscMatrix<'a>

Source

pub fn from_column_iter_dense<I: IntoIterator<Item = f64>>( nrows: usize, ncols: usize, iter: I, ) -> CscMatrix<'static>

Creates a dense CSC matrix with its elements filled with the components provided by an iterator in column-major order.

Panics if iter contains fewer than nrows * ncols elements.

Source

pub fn from_row_iter_dense<I: IntoIterator<Item = f64>>( nrows: usize, ncols: usize, iter: I, ) -> CscMatrix<'static>

Creates a dense CSC matrix with its elements filled with the components provided by an iterator in row-major order.

The order of elements in the slice must follow the usual mathematic writing, i.e., row-by-row.

Panics if iter contains fewer than nrows * ncols elements.

Source

pub fn is_structurally_upper_tri(&self) -> bool

Returns true if the matrix is structurally upper triangular.

A matrix is structurally upper triangular if, for each column, all elements below the diagonal, i.e. with their row number greater than their column number, are empty.

Note that an element with an explicit value of zero is not empty. To be empty an element must not be present in the sparse encoding of the matrix.

Source

pub fn into_upper_tri(self) -> CscMatrix<'a>

Extracts the upper triangular elements of the matrix.

This operation performs no allocations if the matrix is already structurally upper triangular or if it contains only owned data.

The returned matrix is guaranteed to be structurally upper triangular.

Trait Implementations§

Source§

impl<'a> Clone for CscMatrix<'a>

Source§

fn clone(&self) -> CscMatrix<'a>

Returns a duplicate of the value. Read more
1.0.0 · Source§

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

Performs copy-assignment from source. Read more
Source§

impl<'a> Debug for CscMatrix<'a>

Source§

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

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

impl<'a, 'b: 'a> From<&'a CscMatrix<'b>> for CscMatrix<'a>

Source§

fn from(mat: &'a CscMatrix<'b>) -> CscMatrix<'a>

Converts to this type from the input type.
Source§

impl<'a, I, J> From<I> for CscMatrix<'static>
where I: IntoIterator<Item = J> + 'a, J: IntoIterator<Item = &'a f64> + 'a,

Source§

fn from(rows: I) -> CscMatrix<'static>

Converts to this type from the input type.
Source§

impl<'a> PartialEq for CscMatrix<'a>

Source§

fn eq(&self, other: &CscMatrix<'a>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

const fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl<'a> StructuralPartialEq for CscMatrix<'a>

Auto Trait Implementations§

§

impl<'a> Freeze for CscMatrix<'a>

§

impl<'a> RefUnwindSafe for CscMatrix<'a>

§

impl<'a> Send for CscMatrix<'a>

§

impl<'a> Sync for CscMatrix<'a>

§

impl<'a> Unpin for CscMatrix<'a>

§

impl<'a> UnwindSafe for CscMatrix<'a>

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<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
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<T> ToOwned for T
where T: Clone,

Source§

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<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

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>,

Source§

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.