TR-mbed
1.0
Loading...
Searching...
No Matches
core
util
algorithms
eigen-3.4.0
Eigen
src
SparseCore
SparseRedux.h
Go to the documentation of this file.
1
// This file is part of Eigen, a lightweight C++ template library
2
// for linear algebra.
3
//
4
// Copyright (C) 2008-2014 Gael Guennebaud <gael.guennebaud@inria.fr>
5
//
6
// This Source Code Form is subject to the terms of the Mozilla
7
// Public License v. 2.0. If a copy of the MPL was not distributed
8
// with this file, You can obtain one at http://mozilla.org/MPL/2.0/.
9
10
#ifndef EIGEN_SPARSEREDUX_H
11
#define EIGEN_SPARSEREDUX_H
12
13
namespace
Eigen
{
14
15
template
<
typename
Derived>
16
typename
internal::traits<Derived>::Scalar
17
SparseMatrixBase<Derived>::sum
()
const
18
{
19
eigen_assert
(
rows
()>0 &&
cols
()>0 &&
"you are using a non initialized matrix"
);
20
Scalar
res
(0);
21
internal::evaluator<Derived>
thisEval(derived());
22
for
(
Index
j
=0;
j
<outerSize(); ++
j
)
23
for
(
typename
internal::evaluator<Derived>::InnerIterator
iter(thisEval,
j
); iter; ++iter)
24
res
+= iter.value();
25
return
res
;
26
}
27
28
template
<
typename
_Scalar,
int
_Options,
typename
_Index>
29
typename
internal::traits<SparseMatrix<_Scalar,_Options,_Index>
>
::Scalar
30
SparseMatrix<_Scalar,_Options,_Index>::sum
()
const
31
{
32
eigen_assert
(
rows
()>0 &&
cols
()>0 &&
"you are using a non initialized matrix"
);
33
if
(this->isCompressed())
34
return
Matrix<Scalar,1,Dynamic>::Map
(m_data.valuePtr(), m_data.size()).sum();
35
else
36
return
Base::sum();
37
}
38
39
template
<
typename
_Scalar,
int
_Options,
typename
_Index>
40
typename
internal::traits<SparseVector<_Scalar,_Options, _Index>
>
::Scalar
41
SparseVector<_Scalar,_Options,_Index>::sum
()
const
42
{
43
eigen_assert
(
rows
()>0 &&
cols
()>0 &&
"you are using a non initialized matrix"
);
44
return
Matrix<Scalar,1,Dynamic>::Map
(m_data.valuePtr(), m_data.size()).sum();
45
}
46
47
}
// end namespace Eigen
48
49
#endif
// EIGEN_SPARSEREDUX_H
eigen_assert
#define eigen_assert(x)
Definition
Macros.h:1037
res
cout<< "Here is the matrix m:"<< endl<< m<< endl;Matrix< ptrdiff_t, 3, 1 > res
Definition
PartialRedux_count.cpp:3
rows
int rows
Definition
Tutorial_commainit_02.cpp:1
cols
int cols
Definition
Tutorial_commainit_02.cpp:1
Scalar
SCALAR Scalar
Definition
bench_gemm.cpp:46
Eigen::PlainObjectBase< Matrix< _Scalar, _Rows, _Cols, _Options, _MaxRows, _MaxCols > >::Map
friend class Eigen::Map
Definition
PlainObjectBase.h:987
Eigen::SparseMatrixBase::Scalar
internal::traits< Derived >::Scalar Scalar
Definition
SparseMatrixBase.h:31
Eigen::SparseMatrixBase::sum
Scalar sum() const
Definition
SparseRedux.h:17
Eigen::SparseMatrix::sum
Scalar sum() const
Definition
SparseRedux.h:30
Eigen::SparseVector::sum
Scalar sum() const
Definition
SparseRedux.h:41
Eigen
Namespace containing all symbols from the Eigen library.
Definition
bench_norm.cpp:85
Eigen::EigenBase::Index
Eigen::Index Index
The interface type of indices.
Definition
EigenBase.h:39
Eigen::internal::evaluator
Definition
CoreEvaluators.h:91
Eigen::internal::traits
Definition
ForwardDeclarations.h:17
j
std::ptrdiff_t j
Definition
tut_arithmetic_redux_minmax.cpp:2
Generated by
1.9.8