CoreIterators.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_COREITERATORS_H
11 #define EIGEN_COREITERATORS_H
12 
13 namespace Eigen {
14 
15 /* This file contains the respective InnerIterator definition of the expressions defined in Eigen/Core
16  */
17 
18 namespace internal {
19 
20 template<typename XprType, typename EvaluatorKind>
22 
23 }
24 
32 template<typename XprType>
34 {
35 protected:
39 public:
41  InnerIterator(const XprType &xpr, const Index &outerId)
42  : m_eval(xpr), m_iter(m_eval, outerId, xpr.innerSize())
43  {}
44 
46  EIGEN_STRONG_INLINE Scalar value() const { return m_iter.value(); }
50  EIGEN_STRONG_INLINE InnerIterator& operator++() { m_iter.operator++(); return *this; }
51  EIGEN_STRONG_INLINE InnerIterator& operator+=(Index i) { m_iter.operator+=(i); return *this; }
53  { InnerIterator result(*this); result+=i; return result; }
54 
55 
57  EIGEN_STRONG_INLINE Index index() const { return m_iter.index(); }
59  EIGEN_STRONG_INLINE Index row() const { return m_iter.row(); }
61  EIGEN_STRONG_INLINE Index col() const { return m_iter.col(); }
63  EIGEN_STRONG_INLINE operator bool() const { return m_iter; }
64 
65 protected:
66  EvaluatorType m_eval;
67  IteratorType m_iter;
68 private:
69  // If you get here, then you're not using the right InnerIterator type, e.g.:
70  // SparseMatrix<double,RowMajor> A;
71  // SparseMatrix<double>::InnerIterator it(A,0);
72  template<typename T> InnerIterator(const EigenBase<T>&,Index outer);
73 };
74 
75 namespace internal {
76 
77 // Generic inner iterator implementation for dense objects
78 template<typename XprType>
80 {
81 protected:
83  typedef typename traits<XprType>::Scalar Scalar;
84  enum { IsRowMajor = (XprType::Flags&RowMajorBit)==RowMajorBit };
85 
86 public:
87  EIGEN_STRONG_INLINE inner_iterator_selector(const EvaluatorType &eval, const Index &outerId, const Index &innerSize)
88  : m_eval(eval), m_inner(0), m_outer(outerId), m_end(innerSize)
89  {}
90 
91  EIGEN_STRONG_INLINE Scalar value() const
92  {
93  return (IsRowMajor) ? m_eval.coeff(m_outer, m_inner)
94  : m_eval.coeff(m_inner, m_outer);
95  }
96 
97  EIGEN_STRONG_INLINE inner_iterator_selector& operator++() { m_inner++; return *this; }
98 
99  EIGEN_STRONG_INLINE Index index() const { return m_inner; }
100  inline Index row() const { return IsRowMajor ? m_outer : index(); }
101  inline Index col() const { return IsRowMajor ? index() : m_outer; }
102 
103  EIGEN_STRONG_INLINE operator bool() const { return m_inner < m_end && m_inner>=0; }
104 
105 protected:
106  const EvaluatorType& m_eval;
108  const Index m_outer;
109  const Index m_end;
110 };
111 
112 // For iterator-based evaluator, inner-iterator is already implemented as
113 // evaluator<>::InnerIterator
114 template<typename XprType>
116  : public evaluator<XprType>::InnerIterator
117 {
118 protected:
121 
122 public:
123  EIGEN_STRONG_INLINE inner_iterator_selector(const EvaluatorType &eval, const Index &outerId, const Index &/*innerSize*/)
124  : Base(eval, outerId)
125  {}
126 };
127 
128 } // end namespace internal
129 
130 } // end namespace Eigen
131 
132 #endif // EIGEN_COREITERATORS_H
#define EIGEN_STRONG_INLINE
Definition: Macros.h:917
internal::evaluator< XprType > EvaluatorType
Definition: CoreIterators.h:37
EIGEN_STRONG_INLINE Index index() const
Definition: CoreIterators.h:57
EIGEN_STRONG_INLINE inner_iterator_selector(const EvaluatorType &eval, const Index &outerId, const Index &innerSize)
Definition: CoreIterators.h:87
Namespace containing all symbols from the Eigen library.
Definition: jet.h:637
const unsigned int RowMajorBit
Definition: Constants.h:66
internal::traits< XprType >::Scalar Scalar
Definition: CoreIterators.h:38
EIGEN_STRONG_INLINE Index row() const
Definition: CoreIterators.h:59
InnerIterator(const XprType &xpr, const Index &outerId)
Definition: CoreIterators.h:41
EIGEN_STRONG_INLINE inner_iterator_selector & operator++()
Definition: CoreIterators.h:97
Values result
internal::inner_iterator_selector< XprType, typename internal::evaluator_traits< XprType >::Kind > IteratorType
Definition: CoreIterators.h:36
EIGEN_DEFAULT_DENSE_INDEX_TYPE Index
The Index type as used for the API.
Definition: Meta.h:74
EIGEN_STRONG_INLINE inner_iterator_selector(const EvaluatorType &eval, const Index &outerId, const Index &)
EIGEN_STRONG_INLINE InnerIterator operator+(Index i)
Definition: CoreIterators.h:52
CwiseBinaryOp< internal::scalar_sum_op< double, double >, const CpyMatrixXd, const CpyMatrixXd > XprType
Definition: nestbyvalue.cpp:15
EIGEN_STRONG_INLINE InnerIterator & operator+=(Index i)
Definition: CoreIterators.h:51
EvaluatorType m_eval
Definition: CoreIterators.h:66
EIGEN_STRONG_INLINE Scalar value() const
Definition: CoreIterators.h:46
EIGEN_STRONG_INLINE Index col() const
Definition: CoreIterators.h:61
IteratorType m_iter
Definition: CoreIterators.h:67
An InnerIterator allows to loop over the element of any matrix expression.
Definition: CoreIterators.h:33
EIGEN_STRONG_INLINE InnerIterator & operator++()
Definition: CoreIterators.h:50


gtsam
Author(s):
autogenerated on Tue Jul 4 2023 02:34:06