10 #ifndef EIGEN_SPARSE_COMPRESSED_BASE_H
11 #define EIGEN_SPARSE_COMPRESSED_BASE_H
15 template<
typename Derived>
class SparseCompressedBase;
19 template<
typename Derived>
35 template<
typename Derived>
42 using Base::operator=;
139 const Index outer = Derived::IsRowMajor ?
row :
col;
140 const Index inner = Derived::IsRowMajor ?
col :
row;
144 eigen_assert(
end>=start &&
"you are using a non finalized sparse matrix or written coefficient does not exist");
157 template<
typename Derived>
162 : m_values(0), m_indices(0), m_outer(0), m_id(0), m_end(0)
166 : m_values(other.m_values), m_indices(other.m_indices), m_outer(other.m_outer), m_id(other.m_id), m_end(other.m_end)
204 : m_values(data.
valuePtr()), m_indices(data.indexPtr()), m_outer(0), m_id(0), m_end(data.
size())
227 inline operator bool()
const {
return (m_id < m_end); }
243 template<
typename Derived>
272 : m_values(data.
valuePtr()), m_indices(data.indexPtr()), m_outer(0), m_start(0), m_id(data.
size())
295 inline operator bool()
const {
return (m_id > m_start); }
308 template<
typename Derived>
324 explicit evaluator(
const Derived &mat) : m_matrix(&mat), m_zero(0)
330 return m_matrix->nonZeros();
333 operator Derived&() {
return m_matrix->const_cast_derived(); }
334 operator const Derived&()
const {
return *m_matrix; }
344 return m_matrix->const_cast_derived().valuePtr()[p];
351 return m_matrix->const_cast_derived().valuePtr()[p];
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE ColXpr col(Index i)
This is the const version of col().
Definition: BlockMethods.h:1097
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE RowXpr row(Index i)
This is the const version of row(). */.
Definition: BlockMethods.h:1118
#define eigen_internal_assert(x)
Definition: Macros.h:1043
#define eigen_assert(x)
Definition: Macros.h:1037
#define EIGEN_SPARSE_PUBLIC_INTERFACE(Derived)
Definition: SparseUtil.h:43
#define EIGEN_INTERNAL_CHECK_COST_VALUE(C)
Definition: StaticAssert.h:218
#define EIGEN_STATIC_ASSERT_VECTOR_ONLY(TYPE)
Definition: StaticAssert.h:142
Definition: ForwardDeclarations.h:50
A matrix or vector expression mapping an existing array of data.
Definition: Map.h:96
static ConstMapType Map(const Scalar *data)
Definition: PlainObjectBase.h:644
Definition: SparseCompressedBase.h:159
InnerIterator(const InnerIterator &other)
Definition: SparseCompressedBase.h:165
Scalar & valueRef()
Definition: SparseCompressedBase.h:220
InnerIterator(const SparseCompressedBase &mat)
Definition: SparseCompressedBase.h:197
Index m_end
Definition: SparseCompressedBase.h:235
InnerIterator(const SparseMatrixBase< T > &, Index outer)
InnerIterator()
Definition: SparseCompressedBase.h:161
const Scalar & value() const
Definition: SparseCompressedBase.h:219
const OuterType m_outer
Definition: SparseCompressedBase.h:233
InnerIterator & operator+=(Index i)
Definition: SparseCompressedBase.h:210
Index col() const
Definition: SparseCompressedBase.h:225
InnerIterator & operator=(const InnerIterator &other)
Definition: SparseCompressedBase.h:169
Index m_id
Definition: SparseCompressedBase.h:234
InnerIterator & operator++()
Definition: SparseCompressedBase.h:209
internal::variable_if_dynamic< Index, Derived::IsVectorAtCompileTime?0:Dynamic > OuterType
Definition: SparseCompressedBase.h:232
StorageIndex index() const
Definition: SparseCompressedBase.h:222
const Scalar * m_values
Definition: SparseCompressedBase.h:230
Index row() const
Definition: SparseCompressedBase.h:224
InnerIterator operator+(Index i)
Definition: SparseCompressedBase.h:212
const StorageIndex * m_indices
Definition: SparseCompressedBase.h:231
InnerIterator(const SparseCompressedBase &mat, Index outer)
Definition: SparseCompressedBase.h:179
InnerIterator(const internal::CompressedStorage< Scalar, StorageIndex > &data)
Definition: SparseCompressedBase.h:203
Index outer() const
Definition: SparseCompressedBase.h:223
Definition: SparseCompressedBase.h:245
Index m_id
Definition: SparseCompressedBase.h:303
internal::variable_if_dynamic< Index, Derived::IsVectorAtCompileTime?0:Dynamic > OuterType
Definition: SparseCompressedBase.h:300
StorageIndex index() const
Definition: SparseCompressedBase.h:290
Index row() const
Definition: SparseCompressedBase.h:292
Index outer() const
Definition: SparseCompressedBase.h:291
const StorageIndex * m_indices
Definition: SparseCompressedBase.h:299
ReverseInnerIterator & operator--()
Definition: SparseCompressedBase.h:277
const Scalar & value() const
Definition: SparseCompressedBase.h:287
Index m_start
Definition: SparseCompressedBase.h:302
Scalar & valueRef()
Definition: SparseCompressedBase.h:288
const Scalar * m_values
Definition: SparseCompressedBase.h:298
const OuterType m_outer
Definition: SparseCompressedBase.h:301
ReverseInnerIterator operator-(Index i)
Definition: SparseCompressedBase.h:280
Index col() const
Definition: SparseCompressedBase.h:293
ReverseInnerIterator(const internal::CompressedStorage< Scalar, StorageIndex > &data)
Definition: SparseCompressedBase.h:271
ReverseInnerIterator(const SparseCompressedBase &mat)
Definition: SparseCompressedBase.h:265
ReverseInnerIterator & operator-=(Index i)
Definition: SparseCompressedBase.h:278
ReverseInnerIterator(const SparseCompressedBase &mat, Index outer)
Definition: SparseCompressedBase.h:247
Common base class for sparse [compressed]-{row|column}-storage format.
Definition: SparseCompressedBase.h:38
Index nonZeros() const
Definition: SparseCompressedBase.h:56
Scalar * valuePtr()
Definition: SparseCompressedBase.h:75
const Scalar * valuePtr() const
Definition: SparseCompressedBase.h:71
const Map< const Array< Scalar, Dynamic, 1 > > coeffs() const
Definition: SparseCompressedBase.h:114
StorageIndex * innerIndexPtr()
Definition: SparseCompressedBase.h:84
const StorageIndex * outerIndexPtr() const
Definition: SparseCompressedBase.h:90
StorageIndex * innerNonZeroPtr()
Definition: SparseCompressedBase.h:104
SparseMatrixBase< Derived > Base
Definition: SparseCompressedBase.h:40
StorageIndex * outerIndexPtr()
Definition: SparseCompressedBase.h:95
internal::LowerBoundIndex lower_bound(Index row, Index col) const
Definition: SparseCompressedBase.h:135
const Eigen::Map< const IndexVector > innerNonZeros() const
Definition: SparseCompressedBase.h:51
Map< Array< Scalar, Dynamic, 1 > > coeffs()
Definition: SparseCompressedBase.h:126
bool isCompressed() const
Definition: SparseCompressedBase.h:107
const StorageIndex * innerIndexPtr() const
Definition: SparseCompressedBase.h:80
SparseCompressedBase(const SparseCompressedBase< OtherDerived > &)
Base::IndexVector IndexVector
Definition: SparseCompressedBase.h:46
@ IsRowMajor
Definition: SparseMatrixBase.h:100
SparseCompressedBase()
Definition: SparseCompressedBase.h:130
const StorageIndex * innerNonZeroPtr() const
Definition: SparseCompressedBase.h:100
Eigen::Map< IndexVector > innerNonZeros()
Definition: SparseCompressedBase.h:50
Base class of any sparse matrices or sparse expressions.
Definition: SparseMatrixBase.h:28
internal::traits< Derived >::StorageIndex StorageIndex
Definition: SparseMatrixBase.h:43
Index size() const
Definition: SparseMatrixBase.h:181
Index rows() const
Definition: SparseMatrixBase.h:176
internal::traits< Derived >::Scalar Scalar
Definition: SparseMatrixBase.h:31
const Derived & derived() const
Definition: SparseMatrixBase.h:143
Index outerSize() const
Definition: SparseMatrixBase.h:189
Index cols() const
Definition: SparseMatrixBase.h:178
@ IsRowMajor
Definition: SparseMatrixBase.h:100
Definition: XprHelper.h:130
static EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE EIGEN_CONSTEXPR T value()
Definition: XprHelper.h:135
static EIGEN_DEPRECATED const end_t end
Definition: IndexedViewHelper.h:181
Namespace containing all symbols from the Eigen library.
Definition: LDLT.h:16
EIGEN_DEFAULT_DENSE_INDEX_TYPE Index
The Index type as used for the API.
Definition: Meta.h:74
const int Dynamic
Definition: Constants.h:22
Flags
Special flags for archives.
Definition: cereal.hpp:185
Definition: document.h:416
Eigen::Index Index
The interface type of indices.
Definition: EigenBase.h:39
Holds information about the various numeric (i.e. scalar) types allowed by Eigen.
Definition: NumTraits.h:233
Definition: SparseUtil.h:144
bool found
Definition: SparseUtil.h:148
Index value
Definition: SparseUtil.h:147
Derived::Scalar Scalar
Definition: SparseCompressedBase.h:312
Index find(Index row, Index col) const
Definition: SparseCompressedBase.h:356
evaluator()
Definition: SparseCompressedBase.h:320
const Scalar & coeff(Index row, Index col) const
Definition: SparseCompressedBase.h:337
DenseCoeffsBase< Derived, ReadOnlyAccessors >::CoeffReturnType CoeffReturnType
Definition: SparseCompressedBase.h:336
Index nonZerosEstimate() const
Definition: SparseCompressedBase.h:329
const Derived * m_matrix
Definition: SparseCompressedBase.h:362
evaluator(const Derived &mat)
Definition: SparseCompressedBase.h:324
const Scalar m_zero
Definition: SparseCompressedBase.h:363
Derived::InnerIterator InnerIterator
Definition: SparseCompressedBase.h:313
Scalar & coeffRef(Index row, Index col)
Definition: SparseCompressedBase.h:347
Definition: CoreEvaluators.h:111
Definition: CoreEvaluators.h:91
Definition: ForwardDeclarations.h:17