Remove CooMatrix::to_dense() and `Scalar` trait bound, add ::nnz()

This commit is contained in:
Andreas Longva 2020-11-23 15:58:02 +01:00
parent f20e764edc
commit 41ce9a23df
3 changed files with 15 additions and 27 deletions

View File

@ -1,8 +1,6 @@
//! An implementation of the COO sparse matrix format.
use crate::SparseFormatError;
use nalgebra::{ClosedAdd, DMatrix, Scalar};
use num_traits::Zero;
/// A COO representation of a sparse matrix.
///
@ -47,8 +45,6 @@ pub struct CooMatrix<T> {
}
impl<T> CooMatrix<T>
where
T: Scalar,
{
/// Construct a zero COO matrix of the given dimensions.
///
@ -146,6 +142,16 @@ where
self.ncols
}
/// The number of explicitly stored entries in the matrix.
///
/// This number *includes* duplicate entries. For example, if the `CooMatrix` contains duplicate
/// entries, then it may have a different number of non-zeros as reported by `nnz()` compared
/// to its CSR representation.
#[inline]
pub fn nnz(&self) -> usize {
self.values.len()
}
/// The row indices of the explicitly stored entries.
pub fn row_indices(&self) -> &[usize] {
&self.row_indices
@ -182,22 +188,4 @@ where
pub fn disassemble(self) -> (Vec<usize>, Vec<usize>, Vec<T>) {
(self.row_indices, self.col_indices, self.values)
}
/// Construct the dense representation of the COO matrix.
///
/// Duplicate entries are summed together.
///
/// TODO: Remove?
pub fn to_dense(&self) -> DMatrix<T>
where
T: ClosedAdd + Zero,
{
let mut result = DMatrix::zeros(self.nrows, self.ncols);
for (i, j, v) in self.triplet_iter() {
result[(i, j)] += v.clone();
}
result
}
}

View File

@ -19,7 +19,7 @@ fn coo_construction_for_valid_data() {
assert!(coo.col_indices().is_empty());
assert!(coo.values().is_empty());
assert_eq!(coo.to_dense(), DMatrix::repeat(3, 2, 0));
assert_eq!(DMatrix::from(&coo), DMatrix::repeat(3, 2, 0));
}
{
@ -51,7 +51,7 @@ fn coo_construction_for_valid_data() {
0, 0, 3, 0, 0,
0, 0, 0, 1, 0
]);
assert_eq!(coo.to_dense(), expected_dense);
assert_eq!(DMatrix::from(&coo), expected_dense);
}
{
@ -83,7 +83,7 @@ fn coo_construction_for_valid_data() {
0, 0, 8, 0, 0,
0, 0, 0, 1, 0
]);
assert_eq!(coo.to_dense(), expected_dense);
assert_eq!(DMatrix::from(&coo), expected_dense);
}
}

View File

@ -1,6 +1,6 @@
use nalgebra_sparse::coo::CooMatrix;
use nalgebra_sparse::ops::spmv_coo;
use nalgebra::DVector;
use nalgebra::{DVector, DMatrix};
#[test]
fn spmv_coo_agrees_with_dense_gemv() {
@ -20,7 +20,7 @@ fn spmv_coo_agrees_with_dense_gemv() {
let mut y_dense = y.clone();
spmv_coo(beta, &mut y, alpha, &a, &x);
y_dense.gemv(alpha, &a.to_dense(), &x, beta);
y_dense.gemv(alpha, &DMatrix::from(&a), &x, beta);
assert_eq!(y, y_dense);
}