10#ifndef EIGEN_EULERSYSTEM_H
11#define EIGEN_EULERSYSTEM_H
16 template <
typename _Scalar,
class _System>
22 template <
int Num,
bool IsPositive = (Num > 0)>
40 template<
typename System,
42 int OtherRows=Other::RowsAtCompileTime,
43 int OtherCols=Other::ColsAtCompileTime>
47 #define EIGEN_EULER_ANGLES_CLASS_STATIC_ASSERT(COND,MSG) typedef char static_assertion_##MSG[(COND)?1:-1]
125 template <
int _AlphaAxis,
int _BetaAxis,
int _GammaAxis>
162 ALPHA_AXIS_IS_INVALID);
165 BETA_AXIS_IS_INVALID);
168 GAMMA_AXIS_IS_INVALID);
171 ALPHA_AXIS_CANT_BE_EQUAL_TO_BETA_AXIS);
174 BETA_AXIS_CANT_BE_EQUAL_TO_GAMMA_AXIS);
186 template <
typename Derived>
192 typedef typename Derived::Scalar
Scalar;
205 else if(plusMinus *
mat(I_, K_) > 0) {
209 res[0] = alphaPlusMinusGamma;
213 Scalar sneg = plusMinus * (
mat(K_, J_) + minusPlus *
mat(J_, I_));
216 res[0] = alphaMinusPlusBeta;
221 template <
typename Derived>
223 const MatrixBase<Derived>&
mat, internal::false_type )
228 typedef typename Derived::Scalar
Scalar;
238 if(Rsum > 4 * NumTraits<Scalar>::epsilon()) {
242 else if(
mat(I_, I_) > 0) {
243 Scalar spos = plusMinus *
mat(K_, J_) + minusPlus *
mat(J_, K_);
249 Scalar sneg = plusMinus *
mat(K_, J_) + plusMinus *
mat(J_, K_);
256 template<
typename Scalar>
257 static void CalcEulerAngles(
266 res.alpha() = -
res.alpha();
272 res.gamma() = -
res.gamma();
275 template <
typename _Scalar,
class _System>
278 template<
typename System,
285#define EIGEN_EULER_SYSTEM_TYPEDEF(A, B, C) \
287 typedef EulerSystem<EULER_##A, EULER_##B, EULER_##C> EulerSystem##A##B##C;
#define EIGEN_EULER_ANGLES_CLASS_STATIC_ASSERT(COND, MSG)
Definition EulerSystem.h:47
#define EIGEN_EULER_SYSTEM_TYPEDEF(A, B, C)
Definition EulerSystem.h:285
cout<< "Here is the matrix m:"<< endl<< m<< endl;Matrix< ptrdiff_t, 3, 1 > res
Definition PartialRedux_count.cpp:3
MatrixXf mat
Definition Tutorial_AdvancedInitialization_CommaTemporary.cpp:1
SCALAR Scalar
Definition bench_gemm.cpp:46
Represents a rotation in a 3 dimensional space as three Euler angles.
Definition EulerAngles.h:101
Represents a fixed Euler rotation system.
Definition EulerSystem.h:127
static const int BetaAxis
Definition EulerSystem.h:136
@ GammaAxisAbs
Definition EulerSystem.h:145
@ IsOdd
Definition EulerSystem.h:153
@ IsGammaOpposite
Definition EulerSystem.h:149
@ IsAlphaOpposite
Definition EulerSystem.h:147
@ IsEven
Definition EulerSystem.h:154
@ AlphaAxisAbs
Definition EulerSystem.h:143
@ BetaAxisAbs
Definition EulerSystem.h:144
@ IsTaitBryan
Definition EulerSystem.h:156
@ IsBetaOpposite
Definition EulerSystem.h:148
static const int AlphaAxis
Definition EulerSystem.h:133
static const int GammaAxis
Definition EulerSystem.h:139
Base class for all dense matrices, vectors, and expressions.
Definition MatrixBase.h:50
internal::traits< Derived >::Scalar Scalar
Definition MatrixBase.h:56
The matrix class, also used for vectors and row-vectors.
Definition Matrix.h:180
Definition quaternion_demo.cpp:136
#define X
Definition icosphere.cpp:20
#define Z
Definition icosphere.cpp:21
EIGEN_STRONG_INLINE EIGEN_DEVICE_FUNC bfloat16 sqrt(const bfloat16 &a)
Definition BFloat16.h:511
Namespace containing all symbols from the Eigen library.
Definition bench_norm.cpp:85
const AutoDiffScalar< Matrix< typename internal::traits< typename internal::remove_all< DerTypeA >::type >::Scalar, Dynamic, 1 > > atan2(const AutoDiffScalar< DerTypeA > &a, const AutoDiffScalar< DerTypeB > &b)
Definition AutoDiffScalar.h:654
EulerAxis
Representation of a fixed signed rotation axis for EulerSystem.
Definition EulerSystem.h:62
@ EULER_X
Definition EulerSystem.h:63
@ EULER_Z
Definition EulerSystem.h:65
@ EULER_Y
Definition EulerSystem.h:64
Definition BandTriangularSolver.h:13
Holds information about the various numeric (i.e. scalar) types allowed by Eigen.
Definition NumTraits.h:233
Definition EulerSystem.h:24
@ value
Definition EulerSystem.h:25
Definition EulerSystem.h:36
Then type
Definition Meta.h:109
Definition EulerSystem.h:44
Definition ForwardDeclarations.h:17
const char Y
Definition EulerAngles.cpp:31