10#ifndef EIGEN_SPARSEREDUX_H
11#define EIGEN_SPARSEREDUX_H
14#include "./InternalHeaderCheck.h"
18template <
typename Derived>
19typename internal::traits<Derived>::Scalar SparseMatrixBase<Derived>::sum()
const {
20 eigen_assert(rows() > 0 && cols() > 0 &&
"you are using a non initialized matrix");
22 internal::evaluator<Derived> thisEval(derived());
23 for (
Index j = 0; j < outerSize(); ++j)
24 for (
typename internal::evaluator<Derived>::InnerIterator iter(thisEval, j); iter; ++iter) res += iter.value();
28template <
typename Scalar_,
int Options_,
typename Index_>
29typename internal::traits<SparseMatrix<Scalar_, Options_, Index_> >::Scalar
31 eigen_assert(
rows() > 0 &&
cols() > 0 &&
"you are using a non initialized matrix");
33 return Matrix<Scalar, 1, Dynamic>::Map(m_data.valuePtr(), m_data.size()).sum();
38template <
typename Scalar_,
int Options_,
typename Index_>
39typename internal::traits<SparseVector<Scalar_, Options_, Index_> >
::Scalar
41 eigen_assert(rows() > 0 && cols() > 0 &&
"you are using a non initialized matrix");
42 return Matrix<Scalar, 1, Dynamic>::Map(m_data.valuePtr(), m_data.size()).sum();
Index cols() const
Definition SparseMatrix.h:161
bool isCompressed() const
Definition SparseCompressedBase.h:114
Index rows() const
Definition SparseMatrix.h:159
Scalar sum() const
Definition SparseRedux.h:30
Scalar sum() const
Definition SparseRedux.h:40
Namespace containing all symbols from the Eigen library.
Definition B01_Experimental.dox:1
EIGEN_DEFAULT_DENSE_INDEX_TYPE Index
The Index type as used for the API.
Definition Meta.h:82