IndexedViewHelper.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) 2017 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 
11 #ifndef EIGEN_INDEXED_VIEW_HELPER_H
12 #define EIGEN_INDEXED_VIEW_HELPER_H
13 
14 namespace Eigen {
15 
16 namespace internal {
18 }
19 
38 static const symbolic::SymbolExpr<internal::symbolic_last_tag> last; // PLEASE use Eigen::last instead of Eigen::placeholders::last
39 
52 #ifdef EIGEN_PARSED_BY_DOXYGEN
53 static const auto lastp1 = last+fix<1>;
54 #else
55 // Using a FixedExpr<1> expression is important here to make sure the compiler
56 // can fully optimize the computation starting indices with zero overhead.
58 #endif
59 
60 namespace internal {
61 
62  // Replace symbolic last/end "keywords" by their true runtime value
63 inline Index eval_expr_given_size(Index x, Index /* size */) { return x; }
64 
65 template<int N>
67 
68 template<typename Derived>
70 {
71  return x.derived().eval(last=size-1);
72 }
73 
74 // Extract increment/step at compile time
75 template<typename T, typename EnableIf = void> struct get_compile_time_incr {
76  enum { value = UndefinedIncr };
77 };
78 
79 // Analogue of std::get<0>(x), but tailored for our needs.
80 template<typename T>
81 EIGEN_CONSTEXPR Index first(const T& x) EIGEN_NOEXCEPT { return x.first(); }
82 
83 // IndexedViewCompatibleType/makeIndexedViewCompatible turn an arbitrary object of type T into something usable by MatrixSlice
84 // The generic implementation is a no-op
85 template<typename T,int XprSize,typename EnableIf=void>
87  typedef T type;
88 };
89 
90 template<typename T,typename Q>
91 const T& makeIndexedViewCompatible(const T& x, Index /*size*/, Q) { return x; }
92 
93 //--------------------------------------------------------------------------------
94 // Handling of a single Index
95 //--------------------------------------------------------------------------------
96 
97 struct SingleRange {
98  enum {
99  SizeAtCompileTime = 1
100  };
101  SingleRange(Index val) : m_value(val) {}
102  Index operator[](Index) const { return m_value; }
103  static EIGEN_CONSTEXPR Index size() EIGEN_NOEXCEPT { return 1; }
104  Index first() const EIGEN_NOEXCEPT { return m_value; }
106 };
107 
108 template<> struct get_compile_time_incr<SingleRange> {
109  enum { value = 1 }; // 1 or 0 ??
110 };
111 
112 // Turn a single index into something that looks like an array (i.e., that exposes a .size(), and operator[](int) methods)
113 template<typename T, int XprSize>
114 struct IndexedViewCompatibleType<T,XprSize,typename internal::enable_if<internal::is_integral<T>::value>::type> {
115  // Here we could simply use Array, but maybe it's less work for the compiler to use
116  // a simpler wrapper as SingleRange
117  //typedef Eigen::Array<Index,1,1> type;
118  typedef SingleRange type;
119 };
120 
121 template<typename T, int XprSize>
122 struct IndexedViewCompatibleType<T, XprSize, typename enable_if<symbolic::is_symbolic<T>::value>::type> {
123  typedef SingleRange type;
124 };
125 
126 
127 template<typename T>
130  return eval_expr_given_size(id,size);
131 }
132 
133 //--------------------------------------------------------------------------------
134 // Handling of all
135 //--------------------------------------------------------------------------------
136 
137 struct all_t { all_t() {} };
138 
139 // Convert a symbolic 'all' into a usable range type
140 template<int XprSize>
141 struct AllRange {
142  enum { SizeAtCompileTime = XprSize };
143  AllRange(Index size = XprSize) : m_size(size) {}
145  EIGEN_CONSTEXPR Index size() const EIGEN_NOEXCEPT { return m_size.value(); }
148 };
149 
150 template<int XprSize>
153 };
154 
155 template<typename XprSizeType>
158 }
159 
160 template<int Size> struct get_compile_time_incr<AllRange<Size> > {
161  enum { value = 1 };
162 };
163 
164 } // end namespace internal
165 
166 
171 static const Eigen::internal::all_t all; // PLEASE use Eigen::all instead of Eigen::placeholders::all
172 
173 
174 namespace placeholders {
178 
179  EIGEN_DEPRECATED static const all_t all = Eigen::all; // PLEASE use Eigen::all instead of Eigen::placeholders::all
180  EIGEN_DEPRECATED static const last_t last = Eigen::last; // PLEASE use Eigen::last instead of Eigen::placeholders::last
181  EIGEN_DEPRECATED static const end_t end = Eigen::lastp1; // PLEASE use Eigen::lastp1 instead of Eigen::placeholders::end
182 }
183 
184 } // end namespace Eigen
185 
186 #endif // EIGEN_INDEXED_VIEW_HELPER_H
static const Eigen::internal::all_t all
AllRange(Index size=XprSize)
Index first() const EIGEN_NOEXCEPT
Namespace containing all symbols from the Eigen library.
Definition: jet.h:637
EIGEN_CONSTEXPR Index size() const EIGEN_NOEXCEPT
EIGEN_CONSTEXPR Index first(const T &x) EIGEN_NOEXCEPT
static const symbolic::SymbolExpr< internal::symbolic_last_tag > last
EIGEN_CONSTEXPR Index first() const EIGEN_NOEXCEPT
symbolic::AddExpr< symbolic::SymbolExpr< internal::symbolic_last_tag >, symbolic::ValueExpr< Eigen::internal::FixedInt< 1 > > > end_t
#define EIGEN_NOEXCEPT
Definition: Macros.h:1418
static EIGEN_CONSTEXPR Index size() EIGEN_NOEXCEPT
static const symbolic::AddExpr< symbolic::SymbolExpr< internal::symbolic_last_tag >, symbolic::ValueExpr< Eigen::internal::FixedInt< 1 > > > lastp1(last+fix< 1 >())
EIGEN_DEFAULT_DENSE_INDEX_TYPE Index
The Index type as used for the API.
Definition: Meta.h:74
Index eval_expr_given_size(Index x, Index)
variable_if_dynamic< Index, XprSize > m_size
symbolic::SymbolExpr< internal::symbolic_last_tag > last_t
#define EIGEN_CONSTEXPR
Definition: Macros.h:787
EIGEN_CONSTEXPR Index operator[](Index i) const EIGEN_NOEXCEPT
EIGEN_CONSTEXPR Index size(const T &x)
Definition: Meta.h:479
The quaternion class used to represent 3D orientations and rotations.
#define EIGEN_DEPRECATED
Definition: Macros.h:1058
static EIGEN_DEPRECATED const end_t end
const int UndefinedIncr
Definition: Constants.h:31
ArithmeticSequence< Index, typename make_size_type< SizeType >::type, IncrType > makeIndexedViewCompatible(const ArithmeticSequence< FirstType, SizeType, IncrType > &ids, Index size, SpecializedType)
const Derived & derived() const
Definition: SymbolicIndex.h:80
set noclip points set clip one set noclip two set bar set border lt lw set xdata set ydata set zdata set x2data set y2data set boxwidth set dummy x
Eigen::internal::all_t all_t
SpecializedType
Definition: Constants.h:309


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