WPILibC++ 2023.4.3-108-ge5452e3
Reverse.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) 2006-2008 Benoit Jacob <jacob.benoit.1@gmail.com>
5// Copyright (C) 2009 Ricard Marxer <email@ricardmarxer.com>
6// Copyright (C) 2009-2010 Gael Guennebaud <gael.guennebaud@inria.fr>
7//
8// This Source Code Form is subject to the terms of the Mozilla
9// Public License v. 2.0. If a copy of the MPL was not distributed
10// with this file, You can obtain one at http://mozilla.org/MPL/2.0/.
11
12#ifndef EIGEN_REVERSE_H
13#define EIGEN_REVERSE_H
14
15namespace Eigen {
16
17namespace internal {
18
19template<typename MatrixType, int Direction>
20struct traits<Reverse<MatrixType, Direction> >
21 : traits<MatrixType>
22{
23 typedef typename MatrixType::Scalar Scalar;
28 enum {
29 RowsAtCompileTime = MatrixType::RowsAtCompileTime,
30 ColsAtCompileTime = MatrixType::ColsAtCompileTime,
31 MaxRowsAtCompileTime = MatrixType::MaxRowsAtCompileTime,
32 MaxColsAtCompileTime = MatrixType::MaxColsAtCompileTime,
33 Flags = _MatrixTypeNested::Flags & (RowMajorBit | LvalueBit)
34 };
35};
36
37template<typename PacketType, bool ReversePacket> struct reverse_packet_cond
38{
39 static inline PacketType run(const PacketType& x) { return preverse(x); }
40};
41
42template<typename PacketType> struct reverse_packet_cond<PacketType,false>
43{
44 static inline PacketType run(const PacketType& x) { return x; }
45};
46
47} // end namespace internal
48
49/** \class Reverse
50 * \ingroup Core_Module
51 *
52 * \brief Expression of the reverse of a vector or matrix
53 *
54 * \tparam MatrixType the type of the object of which we are taking the reverse
55 * \tparam Direction defines the direction of the reverse operation, can be Vertical, Horizontal, or BothDirections
56 *
57 * This class represents an expression of the reverse of a vector.
58 * It is the return type of MatrixBase::reverse() and VectorwiseOp::reverse()
59 * and most of the time this is the only way it is used.
60 *
61 * \sa MatrixBase::reverse(), VectorwiseOp::reverse()
62 */
63template<typename MatrixType, int Direction> class Reverse
64 : public internal::dense_xpr_base< Reverse<MatrixType, Direction> >::type
65{
66 public:
67
70 typedef typename internal::remove_all<MatrixType>::type NestedExpression;
71 using Base::IsRowMajor;
72
73 protected:
74 enum {
76 IsColMajor = !IsRowMajor,
77 ReverseRow = (Direction == Vertical) || (Direction == BothDirections),
78 ReverseCol = (Direction == Horizontal) || (Direction == BothDirections),
80 OffsetCol = ReverseCol && IsRowMajor ? PacketSize : 1,
81 ReversePacket = (Direction == BothDirections)
82 || ((Direction == Vertical) && IsColMajor)
83 || ((Direction == Horizontal) && IsRowMajor)
84 };
86 public:
87
88 EIGEN_DEVICE_FUNC explicit inline Reverse(const MatrixType& matrix) : m_matrix(matrix) { }
89
91
93 inline Index rows() const EIGEN_NOEXCEPT { return m_matrix.rows(); }
95 inline Index cols() const EIGEN_NOEXCEPT { return m_matrix.cols(); }
96
98 {
99 return -m_matrix.innerStride();
100 }
101
104 {
105 return m_matrix;
106 }
107
108 protected:
109 typename MatrixType::Nested m_matrix;
110};
111
112/** \returns an expression of the reverse of *this.
113 *
114 * Example: \include MatrixBase_reverse.cpp
115 * Output: \verbinclude MatrixBase_reverse.out
116 *
117 */
118template<typename Derived>
121{
122 return ReverseReturnType(derived());
123}
124
125
126//reverse const overload moved DenseBase.h due to a CUDA compiler bug
127
128/** This is the "in place" version of reverse: it reverses \c *this.
129 *
130 * In most cases it is probably better to simply use the reversed expression
131 * of a matrix. However, when reversing the matrix data itself is really needed,
132 * then this "in-place" version is probably the right choice because it provides
133 * the following additional benefits:
134 * - less error prone: doing the same operation with .reverse() requires special care:
135 * \code m = m.reverse().eval(); \endcode
136 * - this API enables reverse operations without the need for a temporary
137 * - it allows future optimizations (cache friendliness, etc.)
138 *
139 * \sa VectorwiseOp::reverseInPlace(), reverse() */
140template<typename Derived>
142{
143 if(cols()>rows())
144 {
145 Index half = cols()/2;
147 if((cols()%2)==1)
148 {
149 Index half2 = rows()/2;
150 col(half).head(half2).swap(col(half).tail(half2).reverse());
151 }
152 }
153 else
154 {
155 Index half = rows()/2;
157 if((rows()%2)==1)
158 {
159 Index half2 = cols()/2;
160 row(half).head(half2).swap(row(half).tail(half2).reverse());
161 }
162 }
163}
164
165namespace internal {
166
167template<int Direction>
169
170template<>
172{
173 template<typename ExpressionType>
174 static void run(ExpressionType &xpr)
175 {
176 const int HalfAtCompileTime = ExpressionType::RowsAtCompileTime==Dynamic?Dynamic:ExpressionType::RowsAtCompileTime/2;
177 Index half = xpr.rows()/2;
178 xpr.topRows(fix<HalfAtCompileTime>(half))
179 .swap(xpr.bottomRows(fix<HalfAtCompileTime>(half)).colwise().reverse());
180 }
181};
182
183template<>
185{
186 template<typename ExpressionType>
187 static void run(ExpressionType &xpr)
188 {
189 const int HalfAtCompileTime = ExpressionType::ColsAtCompileTime==Dynamic?Dynamic:ExpressionType::ColsAtCompileTime/2;
190 Index half = xpr.cols()/2;
191 xpr.leftCols(fix<HalfAtCompileTime>(half))
192 .swap(xpr.rightCols(fix<HalfAtCompileTime>(half)).rowwise().reverse());
193 }
194};
195
196} // end namespace internal
197
198/** This is the "in place" version of VectorwiseOp::reverse: it reverses each column or row of \c *this.
199 *
200 * In most cases it is probably better to simply use the reversed expression
201 * of a matrix. However, when reversing the matrix data itself is really needed,
202 * then this "in-place" version is probably the right choice because it provides
203 * the following additional benefits:
204 * - less error prone: doing the same operation with .reverse() requires special care:
205 * \code m = m.reverse().eval(); \endcode
206 * - this API enables reverse operations without the need for a temporary
207 *
208 * \sa DenseBase::reverseInPlace(), reverse() */
209template<typename ExpressionType, int Direction>
211{
213}
214
215} // end namespace Eigen
216
217#endif // EIGEN_REVERSE_H
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 FixedSegmentReturnType< internal::get_fixed_value< NType >::value >::Type tail(NType n)
Definition: BlockMethods.h:1257
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE NRowsBlockXpr< internal::get_fixed_value< NRowsType >::value >::Type topRows(NRowsType n)
Definition: BlockMethods.h:570
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE NColsBlockXpr< internal::get_fixed_value< NColsType >::value >::Type rightCols(NColsType n)
Definition: BlockMethods.h:872
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE NRowsBlockXpr< internal::get_fixed_value< NRowsType >::value >::Type bottomRows(NRowsType n)
Definition: BlockMethods.h:645
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE NColsBlockXpr< internal::get_fixed_value< NColsType >::value >::Type leftCols(NColsType n)
Definition: BlockMethods.h:797
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE RowXpr row(Index i)
This is the const version of row(). *‍/.
Definition: BlockMethods.h:1118
#define EIGEN_NOEXCEPT
Definition: Macros.h:1428
#define EIGEN_CONSTEXPR
Definition: Macros.h:797
#define EIGEN_DEVICE_FUNC
Definition: Macros.h:986
#define EIGEN_DENSE_PUBLIC_INTERFACE(Derived)
Definition: Macros.h:1293
#define EIGEN_INHERIT_ASSIGNMENT_OPERATORS(Derived)
Definition: Macros.h:1241
EIGEN_DEVICE_FUNC void reverseInPlace()
This is the "in place" version of reverse: it reverses *this.
Definition: Reverse.h:141
EIGEN_DEVICE_FUNC ReverseReturnType reverse()
Definition: Reverse.h:120
Expression of the reverse of a vector or matrix.
Definition: Reverse.h:65
internal::remove_all< MatrixType >::type NestedExpression
Definition: Reverse.h:70
EIGEN_DEVICE_FUNC Index innerStride() const
Definition: Reverse.h:97
@ OffsetCol
Definition: Reverse.h:80
@ ReversePacket
Definition: Reverse.h:81
@ ReverseRow
Definition: Reverse.h:77
@ PacketSize
Definition: Reverse.h:75
@ ReverseCol
Definition: Reverse.h:78
@ OffsetRow
Definition: Reverse.h:79
@ IsColMajor
Definition: Reverse.h:76
internal::reverse_packet_cond< PacketScalar, ReversePacket > reverse_packet
Definition: Reverse.h:85
EIGEN_DEVICE_FUNC EIGEN_CONSTEXPR Index rows() const EIGEN_NOEXCEPT
Definition: Reverse.h:93
EIGEN_DEVICE_FUNC Reverse(const MatrixType &matrix)
Definition: Reverse.h:88
EIGEN_DEVICE_FUNC const internal::remove_all< typenameMatrixType::Nested >::type & nestedExpression() const
Definition: Reverse.h:103
MatrixType::Nested m_matrix
Definition: Reverse.h:109
EIGEN_DEVICE_FUNC EIGEN_CONSTEXPR Index cols() const EIGEN_NOEXCEPT
Definition: Reverse.h:95
internal::dense_xpr_base< Reverse >::type Base
Definition: Reverse.h:68
EIGEN_DEVICE_FUNC void reverseInPlace()
This is the "in place" version of VectorwiseOp::reverse: it reverses each column or row of *this.
Definition: Reverse.h:210
type
Definition: core.h:575
@ BothDirections
For Reverse, both rows and columns are reversed; not used for PartialReduxExpr and VectorwiseOp.
Definition: Constants.h:270
@ Horizontal
For Reverse, all rows are reversed; for PartialReduxExpr and VectorwiseOp, act on rows.
Definition: Constants.h:267
@ Vertical
For Reverse, all columns are reversed; for PartialReduxExpr and VectorwiseOp, act on columns.
Definition: Constants.h:264
const unsigned int LvalueBit
Means the expression has a coeffRef() method, i.e.
Definition: Constants.h:144
const unsigned int RowMajorBit
for a matrix, this means that the storage order is row-major.
Definition: Constants.h:66
EIGEN_STRONG_INLINE Packet8f preverse(const Packet8f &a)
Definition: PacketMath.h:707
Namespace containing all symbols from the Eigen library.
Definition: Core:141
EIGEN_DEFAULT_DENSE_INDEX_TYPE Index
The Index type as used for the API.
Definition: Meta.h:74
const int Dynamic
This value means that a positive quantity (e.g., a size) is not known at compile-time,...
Definition: Constants.h:22
Definition: Eigen_Colamd.h:50
Definition: Half.h:142
Definition: XprHelper.h:484
Definition: GenericPacketMath.h:107
Definition: XprHelper.h:417
T type
Definition: Meta.h:126
T type
Definition: Meta.h:114
static PacketType run(const PacketType &x)
Definition: Reverse.h:44
Definition: Reverse.h:38
static PacketType run(const PacketType &x)
Definition: Reverse.h:39
traits< MatrixType >::StorageKind StorageKind
Definition: Reverse.h:24
ref_selector< MatrixType >::type MatrixTypeNested
Definition: Reverse.h:26
traits< MatrixType >::XprKind XprKind
Definition: Reverse.h:25
remove_reference< MatrixTypeNested >::type _MatrixTypeNested
Definition: Reverse.h:27
MatrixType::Scalar Scalar
Definition: Reverse.h:23
Definition: ForwardDeclarations.h:17
static void run(ExpressionType &xpr)
Definition: Reverse.h:187
static void run(ExpressionType &xpr)
Definition: Reverse.h:174