xtgeo 4.10.0__cp310-cp310-macosx_11_0_arm64.whl → 4.10.1__cp310-cp310-macosx_11_0_arm64.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of xtgeo might be problematic. Click here for more details.

Files changed (561) hide show
  1. xtgeo/_internal.cpython-310-darwin.so +0 -0
  2. xtgeo/common/version.py +2 -2
  3. xtgeo/include/fmt/args.h +220 -0
  4. xtgeo/include/fmt/base.h +2989 -0
  5. xtgeo/include/fmt/chrono.h +2330 -0
  6. xtgeo/include/fmt/color.h +637 -0
  7. xtgeo/include/fmt/compile.h +539 -0
  8. xtgeo/include/fmt/core.h +5 -0
  9. xtgeo/include/fmt/format-inl.h +1948 -0
  10. xtgeo/include/fmt/format.h +4244 -0
  11. xtgeo/include/fmt/os.h +427 -0
  12. xtgeo/include/fmt/ostream.h +167 -0
  13. xtgeo/include/fmt/printf.h +633 -0
  14. xtgeo/include/fmt/ranges.h +850 -0
  15. xtgeo/include/fmt/std.h +728 -0
  16. xtgeo/include/fmt/xchar.h +369 -0
  17. xtgeo/lib/cmake/fmt/fmt-config-version.cmake +43 -0
  18. xtgeo/lib/cmake/fmt/fmt-config.cmake +31 -0
  19. xtgeo/lib/cmake/fmt/fmt-targets-release.cmake +19 -0
  20. xtgeo/{share/eigen3/cmake/Eigen3Targets.cmake → lib/cmake/fmt/fmt-targets.cmake} +16 -6
  21. xtgeo/lib/libfmt.a +0 -0
  22. xtgeo/lib/pkgconfig/fmt.pc +11 -0
  23. {xtgeo-4.10.0.dist-info → xtgeo-4.10.1.dist-info}/METADATA +1 -1
  24. xtgeo-4.10.1.dist-info/RECORD +137 -0
  25. xtgeo/include/eigen3/Eigen/Cholesky +0 -45
  26. xtgeo/include/eigen3/Eigen/CholmodSupport +0 -48
  27. xtgeo/include/eigen3/Eigen/Core +0 -384
  28. xtgeo/include/eigen3/Eigen/Dense +0 -7
  29. xtgeo/include/eigen3/Eigen/Eigen +0 -2
  30. xtgeo/include/eigen3/Eigen/Eigenvalues +0 -60
  31. xtgeo/include/eigen3/Eigen/Geometry +0 -59
  32. xtgeo/include/eigen3/Eigen/Householder +0 -29
  33. xtgeo/include/eigen3/Eigen/IterativeLinearSolvers +0 -48
  34. xtgeo/include/eigen3/Eigen/Jacobi +0 -32
  35. xtgeo/include/eigen3/Eigen/KLUSupport +0 -41
  36. xtgeo/include/eigen3/Eigen/LU +0 -47
  37. xtgeo/include/eigen3/Eigen/MetisSupport +0 -35
  38. xtgeo/include/eigen3/Eigen/OrderingMethods +0 -70
  39. xtgeo/include/eigen3/Eigen/PaStiXSupport +0 -49
  40. xtgeo/include/eigen3/Eigen/PardisoSupport +0 -35
  41. xtgeo/include/eigen3/Eigen/QR +0 -50
  42. xtgeo/include/eigen3/Eigen/QtAlignedMalloc +0 -39
  43. xtgeo/include/eigen3/Eigen/SPQRSupport +0 -34
  44. xtgeo/include/eigen3/Eigen/SVD +0 -50
  45. xtgeo/include/eigen3/Eigen/Sparse +0 -34
  46. xtgeo/include/eigen3/Eigen/SparseCholesky +0 -37
  47. xtgeo/include/eigen3/Eigen/SparseCore +0 -69
  48. xtgeo/include/eigen3/Eigen/SparseLU +0 -50
  49. xtgeo/include/eigen3/Eigen/SparseQR +0 -36
  50. xtgeo/include/eigen3/Eigen/StdDeque +0 -27
  51. xtgeo/include/eigen3/Eigen/StdList +0 -26
  52. xtgeo/include/eigen3/Eigen/StdVector +0 -27
  53. xtgeo/include/eigen3/Eigen/SuperLUSupport +0 -64
  54. xtgeo/include/eigen3/Eigen/UmfPackSupport +0 -40
  55. xtgeo/include/eigen3/Eigen/src/Cholesky/LDLT.h +0 -688
  56. xtgeo/include/eigen3/Eigen/src/Cholesky/LLT.h +0 -558
  57. xtgeo/include/eigen3/Eigen/src/Cholesky/LLT_LAPACKE.h +0 -99
  58. xtgeo/include/eigen3/Eigen/src/CholmodSupport/CholmodSupport.h +0 -682
  59. xtgeo/include/eigen3/Eigen/src/Core/ArithmeticSequence.h +0 -413
  60. xtgeo/include/eigen3/Eigen/src/Core/Array.h +0 -417
  61. xtgeo/include/eigen3/Eigen/src/Core/ArrayBase.h +0 -226
  62. xtgeo/include/eigen3/Eigen/src/Core/ArrayWrapper.h +0 -209
  63. xtgeo/include/eigen3/Eigen/src/Core/Assign.h +0 -90
  64. xtgeo/include/eigen3/Eigen/src/Core/AssignEvaluator.h +0 -1010
  65. xtgeo/include/eigen3/Eigen/src/Core/Assign_MKL.h +0 -178
  66. xtgeo/include/eigen3/Eigen/src/Core/BandMatrix.h +0 -353
  67. xtgeo/include/eigen3/Eigen/src/Core/Block.h +0 -448
  68. xtgeo/include/eigen3/Eigen/src/Core/BooleanRedux.h +0 -162
  69. xtgeo/include/eigen3/Eigen/src/Core/CommaInitializer.h +0 -164
  70. xtgeo/include/eigen3/Eigen/src/Core/ConditionEstimator.h +0 -175
  71. xtgeo/include/eigen3/Eigen/src/Core/CoreEvaluators.h +0 -1741
  72. xtgeo/include/eigen3/Eigen/src/Core/CoreIterators.h +0 -132
  73. xtgeo/include/eigen3/Eigen/src/Core/CwiseBinaryOp.h +0 -183
  74. xtgeo/include/eigen3/Eigen/src/Core/CwiseNullaryOp.h +0 -1001
  75. xtgeo/include/eigen3/Eigen/src/Core/CwiseTernaryOp.h +0 -197
  76. xtgeo/include/eigen3/Eigen/src/Core/CwiseUnaryOp.h +0 -103
  77. xtgeo/include/eigen3/Eigen/src/Core/CwiseUnaryView.h +0 -132
  78. xtgeo/include/eigen3/Eigen/src/Core/DenseBase.h +0 -701
  79. xtgeo/include/eigen3/Eigen/src/Core/DenseCoeffsBase.h +0 -685
  80. xtgeo/include/eigen3/Eigen/src/Core/DenseStorage.h +0 -652
  81. xtgeo/include/eigen3/Eigen/src/Core/Diagonal.h +0 -258
  82. xtgeo/include/eigen3/Eigen/src/Core/DiagonalMatrix.h +0 -391
  83. xtgeo/include/eigen3/Eigen/src/Core/DiagonalProduct.h +0 -28
  84. xtgeo/include/eigen3/Eigen/src/Core/Dot.h +0 -318
  85. xtgeo/include/eigen3/Eigen/src/Core/EigenBase.h +0 -160
  86. xtgeo/include/eigen3/Eigen/src/Core/ForceAlignedAccess.h +0 -150
  87. xtgeo/include/eigen3/Eigen/src/Core/Fuzzy.h +0 -155
  88. xtgeo/include/eigen3/Eigen/src/Core/GeneralProduct.h +0 -465
  89. xtgeo/include/eigen3/Eigen/src/Core/GenericPacketMath.h +0 -1040
  90. xtgeo/include/eigen3/Eigen/src/Core/GlobalFunctions.h +0 -194
  91. xtgeo/include/eigen3/Eigen/src/Core/IO.h +0 -258
  92. xtgeo/include/eigen3/Eigen/src/Core/IndexedView.h +0 -237
  93. xtgeo/include/eigen3/Eigen/src/Core/Inverse.h +0 -117
  94. xtgeo/include/eigen3/Eigen/src/Core/Map.h +0 -171
  95. xtgeo/include/eigen3/Eigen/src/Core/MapBase.h +0 -310
  96. xtgeo/include/eigen3/Eigen/src/Core/MathFunctions.h +0 -2057
  97. xtgeo/include/eigen3/Eigen/src/Core/MathFunctionsImpl.h +0 -200
  98. xtgeo/include/eigen3/Eigen/src/Core/Matrix.h +0 -565
  99. xtgeo/include/eigen3/Eigen/src/Core/MatrixBase.h +0 -547
  100. xtgeo/include/eigen3/Eigen/src/Core/NestByValue.h +0 -85
  101. xtgeo/include/eigen3/Eigen/src/Core/NoAlias.h +0 -109
  102. xtgeo/include/eigen3/Eigen/src/Core/NumTraits.h +0 -335
  103. xtgeo/include/eigen3/Eigen/src/Core/PartialReduxEvaluator.h +0 -232
  104. xtgeo/include/eigen3/Eigen/src/Core/PermutationMatrix.h +0 -605
  105. xtgeo/include/eigen3/Eigen/src/Core/PlainObjectBase.h +0 -1128
  106. xtgeo/include/eigen3/Eigen/src/Core/Product.h +0 -191
  107. xtgeo/include/eigen3/Eigen/src/Core/ProductEvaluators.h +0 -1179
  108. xtgeo/include/eigen3/Eigen/src/Core/Random.h +0 -218
  109. xtgeo/include/eigen3/Eigen/src/Core/Redux.h +0 -515
  110. xtgeo/include/eigen3/Eigen/src/Core/Ref.h +0 -381
  111. xtgeo/include/eigen3/Eigen/src/Core/Replicate.h +0 -142
  112. xtgeo/include/eigen3/Eigen/src/Core/Reshaped.h +0 -454
  113. xtgeo/include/eigen3/Eigen/src/Core/ReturnByValue.h +0 -119
  114. xtgeo/include/eigen3/Eigen/src/Core/Reverse.h +0 -217
  115. xtgeo/include/eigen3/Eigen/src/Core/Select.h +0 -164
  116. xtgeo/include/eigen3/Eigen/src/Core/SelfAdjointView.h +0 -365
  117. xtgeo/include/eigen3/Eigen/src/Core/SelfCwiseBinaryOp.h +0 -47
  118. xtgeo/include/eigen3/Eigen/src/Core/Solve.h +0 -188
  119. xtgeo/include/eigen3/Eigen/src/Core/SolveTriangular.h +0 -235
  120. xtgeo/include/eigen3/Eigen/src/Core/SolverBase.h +0 -168
  121. xtgeo/include/eigen3/Eigen/src/Core/StableNorm.h +0 -251
  122. xtgeo/include/eigen3/Eigen/src/Core/StlIterators.h +0 -463
  123. xtgeo/include/eigen3/Eigen/src/Core/Stride.h +0 -116
  124. xtgeo/include/eigen3/Eigen/src/Core/Swap.h +0 -68
  125. xtgeo/include/eigen3/Eigen/src/Core/Transpose.h +0 -464
  126. xtgeo/include/eigen3/Eigen/src/Core/Transpositions.h +0 -386
  127. xtgeo/include/eigen3/Eigen/src/Core/TriangularMatrix.h +0 -1001
  128. xtgeo/include/eigen3/Eigen/src/Core/VectorBlock.h +0 -96
  129. xtgeo/include/eigen3/Eigen/src/Core/VectorwiseOp.h +0 -784
  130. xtgeo/include/eigen3/Eigen/src/Core/Visitor.h +0 -381
  131. xtgeo/include/eigen3/Eigen/src/Core/arch/AVX/Complex.h +0 -372
  132. xtgeo/include/eigen3/Eigen/src/Core/arch/AVX/MathFunctions.h +0 -228
  133. xtgeo/include/eigen3/Eigen/src/Core/arch/AVX/PacketMath.h +0 -1574
  134. xtgeo/include/eigen3/Eigen/src/Core/arch/AVX/TypeCasting.h +0 -115
  135. xtgeo/include/eigen3/Eigen/src/Core/arch/AVX512/Complex.h +0 -422
  136. xtgeo/include/eigen3/Eigen/src/Core/arch/AVX512/MathFunctions.h +0 -362
  137. xtgeo/include/eigen3/Eigen/src/Core/arch/AVX512/PacketMath.h +0 -2303
  138. xtgeo/include/eigen3/Eigen/src/Core/arch/AVX512/TypeCasting.h +0 -89
  139. xtgeo/include/eigen3/Eigen/src/Core/arch/AltiVec/Complex.h +0 -417
  140. xtgeo/include/eigen3/Eigen/src/Core/arch/AltiVec/MathFunctions.h +0 -90
  141. xtgeo/include/eigen3/Eigen/src/Core/arch/AltiVec/MatrixProduct.h +0 -2937
  142. xtgeo/include/eigen3/Eigen/src/Core/arch/AltiVec/MatrixProductCommon.h +0 -221
  143. xtgeo/include/eigen3/Eigen/src/Core/arch/AltiVec/MatrixProductMMA.h +0 -629
  144. xtgeo/include/eigen3/Eigen/src/Core/arch/AltiVec/PacketMath.h +0 -2711
  145. xtgeo/include/eigen3/Eigen/src/Core/arch/CUDA/Complex.h +0 -258
  146. xtgeo/include/eigen3/Eigen/src/Core/arch/Default/BFloat16.h +0 -700
  147. xtgeo/include/eigen3/Eigen/src/Core/arch/Default/ConjHelper.h +0 -117
  148. xtgeo/include/eigen3/Eigen/src/Core/arch/Default/GenericPacketMathFunctions.h +0 -1649
  149. xtgeo/include/eigen3/Eigen/src/Core/arch/Default/GenericPacketMathFunctionsFwd.h +0 -110
  150. xtgeo/include/eigen3/Eigen/src/Core/arch/Default/Half.h +0 -942
  151. xtgeo/include/eigen3/Eigen/src/Core/arch/Default/Settings.h +0 -49
  152. xtgeo/include/eigen3/Eigen/src/Core/arch/Default/TypeCasting.h +0 -120
  153. xtgeo/include/eigen3/Eigen/src/Core/arch/GPU/MathFunctions.h +0 -103
  154. xtgeo/include/eigen3/Eigen/src/Core/arch/GPU/PacketMath.h +0 -1685
  155. xtgeo/include/eigen3/Eigen/src/Core/arch/GPU/TypeCasting.h +0 -80
  156. xtgeo/include/eigen3/Eigen/src/Core/arch/HIP/hcc/math_constants.h +0 -23
  157. xtgeo/include/eigen3/Eigen/src/Core/arch/MSA/Complex.h +0 -648
  158. xtgeo/include/eigen3/Eigen/src/Core/arch/MSA/MathFunctions.h +0 -387
  159. xtgeo/include/eigen3/Eigen/src/Core/arch/MSA/PacketMath.h +0 -1233
  160. xtgeo/include/eigen3/Eigen/src/Core/arch/NEON/Complex.h +0 -584
  161. xtgeo/include/eigen3/Eigen/src/Core/arch/NEON/GeneralBlockPanelKernel.h +0 -183
  162. xtgeo/include/eigen3/Eigen/src/Core/arch/NEON/MathFunctions.h +0 -75
  163. xtgeo/include/eigen3/Eigen/src/Core/arch/NEON/PacketMath.h +0 -4587
  164. xtgeo/include/eigen3/Eigen/src/Core/arch/NEON/TypeCasting.h +0 -1419
  165. xtgeo/include/eigen3/Eigen/src/Core/arch/SSE/Complex.h +0 -351
  166. xtgeo/include/eigen3/Eigen/src/Core/arch/SSE/MathFunctions.h +0 -199
  167. xtgeo/include/eigen3/Eigen/src/Core/arch/SSE/PacketMath.h +0 -1505
  168. xtgeo/include/eigen3/Eigen/src/Core/arch/SSE/TypeCasting.h +0 -142
  169. xtgeo/include/eigen3/Eigen/src/Core/arch/SVE/MathFunctions.h +0 -44
  170. xtgeo/include/eigen3/Eigen/src/Core/arch/SVE/PacketMath.h +0 -752
  171. xtgeo/include/eigen3/Eigen/src/Core/arch/SVE/TypeCasting.h +0 -49
  172. xtgeo/include/eigen3/Eigen/src/Core/arch/SYCL/InteropHeaders.h +0 -232
  173. xtgeo/include/eigen3/Eigen/src/Core/arch/SYCL/MathFunctions.h +0 -301
  174. xtgeo/include/eigen3/Eigen/src/Core/arch/SYCL/PacketMath.h +0 -670
  175. xtgeo/include/eigen3/Eigen/src/Core/arch/SYCL/SyclMemoryModel.h +0 -694
  176. xtgeo/include/eigen3/Eigen/src/Core/arch/SYCL/TypeCasting.h +0 -85
  177. xtgeo/include/eigen3/Eigen/src/Core/arch/ZVector/Complex.h +0 -426
  178. xtgeo/include/eigen3/Eigen/src/Core/arch/ZVector/MathFunctions.h +0 -233
  179. xtgeo/include/eigen3/Eigen/src/Core/arch/ZVector/PacketMath.h +0 -1060
  180. xtgeo/include/eigen3/Eigen/src/Core/functors/AssignmentFunctors.h +0 -177
  181. xtgeo/include/eigen3/Eigen/src/Core/functors/BinaryFunctors.h +0 -541
  182. xtgeo/include/eigen3/Eigen/src/Core/functors/NullaryFunctors.h +0 -189
  183. xtgeo/include/eigen3/Eigen/src/Core/functors/StlFunctors.h +0 -166
  184. xtgeo/include/eigen3/Eigen/src/Core/functors/TernaryFunctors.h +0 -25
  185. xtgeo/include/eigen3/Eigen/src/Core/functors/UnaryFunctors.h +0 -1131
  186. xtgeo/include/eigen3/Eigen/src/Core/products/GeneralBlockPanelKernel.h +0 -2645
  187. xtgeo/include/eigen3/Eigen/src/Core/products/GeneralMatrixMatrix.h +0 -517
  188. xtgeo/include/eigen3/Eigen/src/Core/products/GeneralMatrixMatrixTriangular.h +0 -317
  189. xtgeo/include/eigen3/Eigen/src/Core/products/GeneralMatrixMatrixTriangular_BLAS.h +0 -145
  190. xtgeo/include/eigen3/Eigen/src/Core/products/GeneralMatrixMatrix_BLAS.h +0 -124
  191. xtgeo/include/eigen3/Eigen/src/Core/products/GeneralMatrixVector.h +0 -518
  192. xtgeo/include/eigen3/Eigen/src/Core/products/GeneralMatrixVector_BLAS.h +0 -136
  193. xtgeo/include/eigen3/Eigen/src/Core/products/Parallelizer.h +0 -180
  194. xtgeo/include/eigen3/Eigen/src/Core/products/SelfadjointMatrixMatrix.h +0 -544
  195. xtgeo/include/eigen3/Eigen/src/Core/products/SelfadjointMatrixMatrix_BLAS.h +0 -295
  196. xtgeo/include/eigen3/Eigen/src/Core/products/SelfadjointMatrixVector.h +0 -262
  197. xtgeo/include/eigen3/Eigen/src/Core/products/SelfadjointMatrixVector_BLAS.h +0 -118
  198. xtgeo/include/eigen3/Eigen/src/Core/products/SelfadjointProduct.h +0 -133
  199. xtgeo/include/eigen3/Eigen/src/Core/products/SelfadjointRank2Update.h +0 -94
  200. xtgeo/include/eigen3/Eigen/src/Core/products/TriangularMatrixMatrix.h +0 -472
  201. xtgeo/include/eigen3/Eigen/src/Core/products/TriangularMatrixMatrix_BLAS.h +0 -317
  202. xtgeo/include/eigen3/Eigen/src/Core/products/TriangularMatrixVector.h +0 -350
  203. xtgeo/include/eigen3/Eigen/src/Core/products/TriangularMatrixVector_BLAS.h +0 -255
  204. xtgeo/include/eigen3/Eigen/src/Core/products/TriangularSolverMatrix.h +0 -337
  205. xtgeo/include/eigen3/Eigen/src/Core/products/TriangularSolverMatrix_BLAS.h +0 -167
  206. xtgeo/include/eigen3/Eigen/src/Core/products/TriangularSolverVector.h +0 -148
  207. xtgeo/include/eigen3/Eigen/src/Core/util/BlasUtil.h +0 -583
  208. xtgeo/include/eigen3/Eigen/src/Core/util/ConfigureVectorization.h +0 -512
  209. xtgeo/include/eigen3/Eigen/src/Core/util/Constants.h +0 -563
  210. xtgeo/include/eigen3/Eigen/src/Core/util/DisableStupidWarnings.h +0 -106
  211. xtgeo/include/eigen3/Eigen/src/Core/util/ForwardDeclarations.h +0 -322
  212. xtgeo/include/eigen3/Eigen/src/Core/util/IndexedViewHelper.h +0 -186
  213. xtgeo/include/eigen3/Eigen/src/Core/util/IntegralConstant.h +0 -272
  214. xtgeo/include/eigen3/Eigen/src/Core/util/MKL_support.h +0 -137
  215. xtgeo/include/eigen3/Eigen/src/Core/util/Macros.h +0 -1464
  216. xtgeo/include/eigen3/Eigen/src/Core/util/Memory.h +0 -1163
  217. xtgeo/include/eigen3/Eigen/src/Core/util/Meta.h +0 -812
  218. xtgeo/include/eigen3/Eigen/src/Core/util/NonMPL2.h +0 -3
  219. xtgeo/include/eigen3/Eigen/src/Core/util/ReenableStupidWarnings.h +0 -31
  220. xtgeo/include/eigen3/Eigen/src/Core/util/ReshapedHelper.h +0 -51
  221. xtgeo/include/eigen3/Eigen/src/Core/util/StaticAssert.h +0 -221
  222. xtgeo/include/eigen3/Eigen/src/Core/util/SymbolicIndex.h +0 -293
  223. xtgeo/include/eigen3/Eigen/src/Core/util/XprHelper.h +0 -856
  224. xtgeo/include/eigen3/Eigen/src/Eigenvalues/ComplexEigenSolver.h +0 -346
  225. xtgeo/include/eigen3/Eigen/src/Eigenvalues/ComplexSchur.h +0 -462
  226. xtgeo/include/eigen3/Eigen/src/Eigenvalues/ComplexSchur_LAPACKE.h +0 -91
  227. xtgeo/include/eigen3/Eigen/src/Eigenvalues/EigenSolver.h +0 -622
  228. xtgeo/include/eigen3/Eigen/src/Eigenvalues/GeneralizedEigenSolver.h +0 -418
  229. xtgeo/include/eigen3/Eigen/src/Eigenvalues/GeneralizedSelfAdjointEigenSolver.h +0 -226
  230. xtgeo/include/eigen3/Eigen/src/Eigenvalues/HessenbergDecomposition.h +0 -374
  231. xtgeo/include/eigen3/Eigen/src/Eigenvalues/MatrixBaseEigenvalues.h +0 -158
  232. xtgeo/include/eigen3/Eigen/src/Eigenvalues/RealQZ.h +0 -657
  233. xtgeo/include/eigen3/Eigen/src/Eigenvalues/RealSchur.h +0 -558
  234. xtgeo/include/eigen3/Eigen/src/Eigenvalues/RealSchur_LAPACKE.h +0 -77
  235. xtgeo/include/eigen3/Eigen/src/Eigenvalues/SelfAdjointEigenSolver.h +0 -904
  236. xtgeo/include/eigen3/Eigen/src/Eigenvalues/SelfAdjointEigenSolver_LAPACKE.h +0 -87
  237. xtgeo/include/eigen3/Eigen/src/Eigenvalues/Tridiagonalization.h +0 -561
  238. xtgeo/include/eigen3/Eigen/src/Geometry/AlignedBox.h +0 -486
  239. xtgeo/include/eigen3/Eigen/src/Geometry/AngleAxis.h +0 -247
  240. xtgeo/include/eigen3/Eigen/src/Geometry/EulerAngles.h +0 -114
  241. xtgeo/include/eigen3/Eigen/src/Geometry/Homogeneous.h +0 -501
  242. xtgeo/include/eigen3/Eigen/src/Geometry/Hyperplane.h +0 -282
  243. xtgeo/include/eigen3/Eigen/src/Geometry/OrthoMethods.h +0 -235
  244. xtgeo/include/eigen3/Eigen/src/Geometry/ParametrizedLine.h +0 -232
  245. xtgeo/include/eigen3/Eigen/src/Geometry/Quaternion.h +0 -870
  246. xtgeo/include/eigen3/Eigen/src/Geometry/Rotation2D.h +0 -199
  247. xtgeo/include/eigen3/Eigen/src/Geometry/RotationBase.h +0 -206
  248. xtgeo/include/eigen3/Eigen/src/Geometry/Scaling.h +0 -188
  249. xtgeo/include/eigen3/Eigen/src/Geometry/Transform.h +0 -1563
  250. xtgeo/include/eigen3/Eigen/src/Geometry/Translation.h +0 -202
  251. xtgeo/include/eigen3/Eigen/src/Geometry/Umeyama.h +0 -166
  252. xtgeo/include/eigen3/Eigen/src/Geometry/arch/Geometry_SIMD.h +0 -168
  253. xtgeo/include/eigen3/Eigen/src/Householder/BlockHouseholder.h +0 -110
  254. xtgeo/include/eigen3/Eigen/src/Householder/Householder.h +0 -176
  255. xtgeo/include/eigen3/Eigen/src/Householder/HouseholderSequence.h +0 -545
  256. xtgeo/include/eigen3/Eigen/src/IterativeLinearSolvers/BasicPreconditioners.h +0 -226
  257. xtgeo/include/eigen3/Eigen/src/IterativeLinearSolvers/BiCGSTAB.h +0 -212
  258. xtgeo/include/eigen3/Eigen/src/IterativeLinearSolvers/ConjugateGradient.h +0 -229
  259. xtgeo/include/eigen3/Eigen/src/IterativeLinearSolvers/IncompleteCholesky.h +0 -394
  260. xtgeo/include/eigen3/Eigen/src/IterativeLinearSolvers/IncompleteLUT.h +0 -453
  261. xtgeo/include/eigen3/Eigen/src/IterativeLinearSolvers/IterativeSolverBase.h +0 -444
  262. xtgeo/include/eigen3/Eigen/src/IterativeLinearSolvers/LeastSquareConjugateGradient.h +0 -198
  263. xtgeo/include/eigen3/Eigen/src/IterativeLinearSolvers/SolveWithGuess.h +0 -117
  264. xtgeo/include/eigen3/Eigen/src/Jacobi/Jacobi.h +0 -483
  265. xtgeo/include/eigen3/Eigen/src/KLUSupport/KLUSupport.h +0 -358
  266. xtgeo/include/eigen3/Eigen/src/LU/Determinant.h +0 -117
  267. xtgeo/include/eigen3/Eigen/src/LU/FullPivLU.h +0 -877
  268. xtgeo/include/eigen3/Eigen/src/LU/InverseImpl.h +0 -432
  269. xtgeo/include/eigen3/Eigen/src/LU/PartialPivLU.h +0 -624
  270. xtgeo/include/eigen3/Eigen/src/LU/PartialPivLU_LAPACKE.h +0 -83
  271. xtgeo/include/eigen3/Eigen/src/LU/arch/InverseSize4.h +0 -351
  272. xtgeo/include/eigen3/Eigen/src/MetisSupport/MetisSupport.h +0 -137
  273. xtgeo/include/eigen3/Eigen/src/OrderingMethods/Amd.h +0 -435
  274. xtgeo/include/eigen3/Eigen/src/OrderingMethods/Eigen_Colamd.h +0 -1863
  275. xtgeo/include/eigen3/Eigen/src/OrderingMethods/Ordering.h +0 -153
  276. xtgeo/include/eigen3/Eigen/src/PaStiXSupport/PaStiXSupport.h +0 -678
  277. xtgeo/include/eigen3/Eigen/src/PardisoSupport/PardisoSupport.h +0 -545
  278. xtgeo/include/eigen3/Eigen/src/QR/ColPivHouseholderQR.h +0 -674
  279. xtgeo/include/eigen3/Eigen/src/QR/ColPivHouseholderQR_LAPACKE.h +0 -97
  280. xtgeo/include/eigen3/Eigen/src/QR/CompleteOrthogonalDecomposition.h +0 -635
  281. xtgeo/include/eigen3/Eigen/src/QR/FullPivHouseholderQR.h +0 -713
  282. xtgeo/include/eigen3/Eigen/src/QR/HouseholderQR.h +0 -434
  283. xtgeo/include/eigen3/Eigen/src/QR/HouseholderQR_LAPACKE.h +0 -68
  284. xtgeo/include/eigen3/Eigen/src/SPQRSupport/SuiteSparseQRSupport.h +0 -335
  285. xtgeo/include/eigen3/Eigen/src/SVD/BDCSVD.h +0 -1366
  286. xtgeo/include/eigen3/Eigen/src/SVD/JacobiSVD.h +0 -812
  287. xtgeo/include/eigen3/Eigen/src/SVD/JacobiSVD_LAPACKE.h +0 -91
  288. xtgeo/include/eigen3/Eigen/src/SVD/SVDBase.h +0 -376
  289. xtgeo/include/eigen3/Eigen/src/SVD/UpperBidiagonalization.h +0 -414
  290. xtgeo/include/eigen3/Eigen/src/SparseCholesky/SimplicialCholesky.h +0 -697
  291. xtgeo/include/eigen3/Eigen/src/SparseCholesky/SimplicialCholesky_impl.h +0 -174
  292. xtgeo/include/eigen3/Eigen/src/SparseCore/AmbiVector.h +0 -378
  293. xtgeo/include/eigen3/Eigen/src/SparseCore/CompressedStorage.h +0 -274
  294. xtgeo/include/eigen3/Eigen/src/SparseCore/ConservativeSparseSparseProduct.h +0 -352
  295. xtgeo/include/eigen3/Eigen/src/SparseCore/MappedSparseMatrix.h +0 -67
  296. xtgeo/include/eigen3/Eigen/src/SparseCore/SparseAssign.h +0 -270
  297. xtgeo/include/eigen3/Eigen/src/SparseCore/SparseBlock.h +0 -571
  298. xtgeo/include/eigen3/Eigen/src/SparseCore/SparseColEtree.h +0 -206
  299. xtgeo/include/eigen3/Eigen/src/SparseCore/SparseCompressedBase.h +0 -370
  300. xtgeo/include/eigen3/Eigen/src/SparseCore/SparseCwiseBinaryOp.h +0 -722
  301. xtgeo/include/eigen3/Eigen/src/SparseCore/SparseCwiseUnaryOp.h +0 -150
  302. xtgeo/include/eigen3/Eigen/src/SparseCore/SparseDenseProduct.h +0 -342
  303. xtgeo/include/eigen3/Eigen/src/SparseCore/SparseDiagonalProduct.h +0 -138
  304. xtgeo/include/eigen3/Eigen/src/SparseCore/SparseDot.h +0 -98
  305. xtgeo/include/eigen3/Eigen/src/SparseCore/SparseFuzzy.h +0 -29
  306. xtgeo/include/eigen3/Eigen/src/SparseCore/SparseMap.h +0 -305
  307. xtgeo/include/eigen3/Eigen/src/SparseCore/SparseMatrix.h +0 -1518
  308. xtgeo/include/eigen3/Eigen/src/SparseCore/SparseMatrixBase.h +0 -398
  309. xtgeo/include/eigen3/Eigen/src/SparseCore/SparsePermutation.h +0 -178
  310. xtgeo/include/eigen3/Eigen/src/SparseCore/SparseProduct.h +0 -181
  311. xtgeo/include/eigen3/Eigen/src/SparseCore/SparseRedux.h +0 -49
  312. xtgeo/include/eigen3/Eigen/src/SparseCore/SparseRef.h +0 -397
  313. xtgeo/include/eigen3/Eigen/src/SparseCore/SparseSelfAdjointView.h +0 -659
  314. xtgeo/include/eigen3/Eigen/src/SparseCore/SparseSolverBase.h +0 -124
  315. xtgeo/include/eigen3/Eigen/src/SparseCore/SparseSparseProductWithPruning.h +0 -198
  316. xtgeo/include/eigen3/Eigen/src/SparseCore/SparseTranspose.h +0 -92
  317. xtgeo/include/eigen3/Eigen/src/SparseCore/SparseTriangularView.h +0 -189
  318. xtgeo/include/eigen3/Eigen/src/SparseCore/SparseUtil.h +0 -186
  319. xtgeo/include/eigen3/Eigen/src/SparseCore/SparseVector.h +0 -478
  320. xtgeo/include/eigen3/Eigen/src/SparseCore/SparseView.h +0 -254
  321. xtgeo/include/eigen3/Eigen/src/SparseCore/TriangularSolver.h +0 -315
  322. xtgeo/include/eigen3/Eigen/src/SparseLU/SparseLU.h +0 -923
  323. xtgeo/include/eigen3/Eigen/src/SparseLU/SparseLUImpl.h +0 -66
  324. xtgeo/include/eigen3/Eigen/src/SparseLU/SparseLU_Memory.h +0 -226
  325. xtgeo/include/eigen3/Eigen/src/SparseLU/SparseLU_Structs.h +0 -110
  326. xtgeo/include/eigen3/Eigen/src/SparseLU/SparseLU_SupernodalMatrix.h +0 -375
  327. xtgeo/include/eigen3/Eigen/src/SparseLU/SparseLU_Utils.h +0 -80
  328. xtgeo/include/eigen3/Eigen/src/SparseLU/SparseLU_column_bmod.h +0 -181
  329. xtgeo/include/eigen3/Eigen/src/SparseLU/SparseLU_column_dfs.h +0 -179
  330. xtgeo/include/eigen3/Eigen/src/SparseLU/SparseLU_copy_to_ucol.h +0 -107
  331. xtgeo/include/eigen3/Eigen/src/SparseLU/SparseLU_gemm_kernel.h +0 -280
  332. xtgeo/include/eigen3/Eigen/src/SparseLU/SparseLU_heap_relax_snode.h +0 -126
  333. xtgeo/include/eigen3/Eigen/src/SparseLU/SparseLU_kernel_bmod.h +0 -130
  334. xtgeo/include/eigen3/Eigen/src/SparseLU/SparseLU_panel_bmod.h +0 -223
  335. xtgeo/include/eigen3/Eigen/src/SparseLU/SparseLU_panel_dfs.h +0 -258
  336. xtgeo/include/eigen3/Eigen/src/SparseLU/SparseLU_pivotL.h +0 -137
  337. xtgeo/include/eigen3/Eigen/src/SparseLU/SparseLU_pruneL.h +0 -136
  338. xtgeo/include/eigen3/Eigen/src/SparseLU/SparseLU_relax_snode.h +0 -83
  339. xtgeo/include/eigen3/Eigen/src/SparseQR/SparseQR.h +0 -758
  340. xtgeo/include/eigen3/Eigen/src/StlSupport/StdDeque.h +0 -116
  341. xtgeo/include/eigen3/Eigen/src/StlSupport/StdList.h +0 -106
  342. xtgeo/include/eigen3/Eigen/src/StlSupport/StdVector.h +0 -131
  343. xtgeo/include/eigen3/Eigen/src/StlSupport/details.h +0 -84
  344. xtgeo/include/eigen3/Eigen/src/SuperLUSupport/SuperLUSupport.h +0 -1025
  345. xtgeo/include/eigen3/Eigen/src/UmfPackSupport/UmfPackSupport.h +0 -642
  346. xtgeo/include/eigen3/Eigen/src/misc/Image.h +0 -82
  347. xtgeo/include/eigen3/Eigen/src/misc/Kernel.h +0 -79
  348. xtgeo/include/eigen3/Eigen/src/misc/RealSvd2x2.h +0 -55
  349. xtgeo/include/eigen3/Eigen/src/misc/blas.h +0 -440
  350. xtgeo/include/eigen3/Eigen/src/misc/lapack.h +0 -152
  351. xtgeo/include/eigen3/Eigen/src/misc/lapacke.h +0 -16292
  352. xtgeo/include/eigen3/Eigen/src/misc/lapacke_mangling.h +0 -17
  353. xtgeo/include/eigen3/Eigen/src/plugins/ArrayCwiseBinaryOps.h +0 -358
  354. xtgeo/include/eigen3/Eigen/src/plugins/ArrayCwiseUnaryOps.h +0 -696
  355. xtgeo/include/eigen3/Eigen/src/plugins/BlockMethods.h +0 -1442
  356. xtgeo/include/eigen3/Eigen/src/plugins/CommonCwiseBinaryOps.h +0 -115
  357. xtgeo/include/eigen3/Eigen/src/plugins/CommonCwiseUnaryOps.h +0 -177
  358. xtgeo/include/eigen3/Eigen/src/plugins/IndexedViewMethods.h +0 -262
  359. xtgeo/include/eigen3/Eigen/src/plugins/MatrixCwiseBinaryOps.h +0 -152
  360. xtgeo/include/eigen3/Eigen/src/plugins/MatrixCwiseUnaryOps.h +0 -95
  361. xtgeo/include/eigen3/Eigen/src/plugins/ReshapedMethods.h +0 -149
  362. xtgeo/include/eigen3/signature_of_eigen3_matrix_library +0 -1
  363. xtgeo/include/eigen3/unsupported/Eigen/AdolcForward +0 -159
  364. xtgeo/include/eigen3/unsupported/Eigen/AlignedVector3 +0 -234
  365. xtgeo/include/eigen3/unsupported/Eigen/ArpackSupport +0 -30
  366. xtgeo/include/eigen3/unsupported/Eigen/AutoDiff +0 -46
  367. xtgeo/include/eigen3/unsupported/Eigen/BVH +0 -95
  368. xtgeo/include/eigen3/unsupported/Eigen/CXX11/Tensor +0 -137
  369. xtgeo/include/eigen3/unsupported/Eigen/CXX11/TensorSymmetry +0 -42
  370. xtgeo/include/eigen3/unsupported/Eigen/CXX11/ThreadPool +0 -74
  371. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/Tensor.h +0 -554
  372. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorArgMax.h +0 -329
  373. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorAssign.h +0 -247
  374. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorBase.h +0 -1176
  375. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorBlock.h +0 -1559
  376. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorBroadcasting.h +0 -1093
  377. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorChipping.h +0 -518
  378. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorConcatenation.h +0 -377
  379. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorContraction.h +0 -1023
  380. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorContractionBlocking.h +0 -73
  381. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorContractionCuda.h +0 -6
  382. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorContractionGpu.h +0 -1413
  383. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorContractionMapper.h +0 -575
  384. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorContractionSycl.h +0 -1650
  385. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorContractionThreadPool.h +0 -1679
  386. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorConversion.h +0 -456
  387. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorConvolution.h +0 -1132
  388. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorConvolutionSycl.h +0 -544
  389. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorCostModel.h +0 -214
  390. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorCustomOp.h +0 -347
  391. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorDevice.h +0 -137
  392. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorDeviceCuda.h +0 -6
  393. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorDeviceDefault.h +0 -104
  394. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorDeviceGpu.h +0 -389
  395. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorDeviceSycl.h +0 -1048
  396. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorDeviceThreadPool.h +0 -409
  397. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorDimensionList.h +0 -236
  398. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorDimensions.h +0 -490
  399. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorEvalTo.h +0 -236
  400. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorEvaluator.h +0 -983
  401. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorExecutor.h +0 -703
  402. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorExpr.h +0 -388
  403. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorFFT.h +0 -669
  404. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorFixedSize.h +0 -379
  405. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorForcedEval.h +0 -237
  406. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorForwardDeclarations.h +0 -191
  407. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorFunctors.h +0 -488
  408. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorGenerator.h +0 -302
  409. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorGlobalFunctions.h +0 -33
  410. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorGpuHipCudaDefines.h +0 -99
  411. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorGpuHipCudaUndefines.h +0 -44
  412. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorIO.h +0 -79
  413. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorImagePatch.h +0 -603
  414. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorIndexList.h +0 -738
  415. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorInflation.h +0 -247
  416. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorInitializer.h +0 -82
  417. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorIntDiv.h +0 -263
  418. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorLayoutSwap.h +0 -216
  419. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorMacros.h +0 -98
  420. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorMap.h +0 -327
  421. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorMeta.h +0 -311
  422. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorMorphing.h +0 -1102
  423. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorPadding.h +0 -708
  424. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorPatch.h +0 -291
  425. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorRandom.h +0 -322
  426. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorReduction.h +0 -998
  427. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorReductionCuda.h +0 -6
  428. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorReductionGpu.h +0 -966
  429. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorReductionSycl.h +0 -582
  430. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorRef.h +0 -454
  431. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorReverse.h +0 -465
  432. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorScan.h +0 -528
  433. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorScanSycl.h +0 -513
  434. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorShuffling.h +0 -471
  435. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorStorage.h +0 -161
  436. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorStriding.h +0 -346
  437. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorTrace.h +0 -303
  438. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorTraits.h +0 -264
  439. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorUInt128.h +0 -249
  440. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorVolumePatch.h +0 -629
  441. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/TensorSymmetry/DynamicSymmetry.h +0 -293
  442. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/TensorSymmetry/StaticSymmetry.h +0 -236
  443. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/TensorSymmetry/Symmetry.h +0 -338
  444. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/TensorSymmetry/util/TemplateGroupTheory.h +0 -669
  445. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/ThreadPool/Barrier.h +0 -67
  446. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/ThreadPool/EventCount.h +0 -249
  447. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/ThreadPool/NonBlockingThreadPool.h +0 -486
  448. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/ThreadPool/RunQueue.h +0 -236
  449. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/ThreadPool/ThreadCancel.h +0 -23
  450. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/ThreadPool/ThreadEnvironment.h +0 -40
  451. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/ThreadPool/ThreadLocal.h +0 -301
  452. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/ThreadPool/ThreadPoolInterface.h +0 -48
  453. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/ThreadPool/ThreadYield.h +0 -20
  454. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/util/CXX11Meta.h +0 -537
  455. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/util/CXX11Workarounds.h +0 -88
  456. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/util/EmulateArray.h +0 -261
  457. xtgeo/include/eigen3/unsupported/Eigen/CXX11/src/util/MaxSizeVector.h +0 -158
  458. xtgeo/include/eigen3/unsupported/Eigen/EulerAngles +0 -43
  459. xtgeo/include/eigen3/unsupported/Eigen/FFT +0 -419
  460. xtgeo/include/eigen3/unsupported/Eigen/IterativeSolvers +0 -51
  461. xtgeo/include/eigen3/unsupported/Eigen/KroneckerProduct +0 -36
  462. xtgeo/include/eigen3/unsupported/Eigen/LevenbergMarquardt +0 -49
  463. xtgeo/include/eigen3/unsupported/Eigen/MPRealSupport +0 -213
  464. xtgeo/include/eigen3/unsupported/Eigen/MatrixFunctions +0 -504
  465. xtgeo/include/eigen3/unsupported/Eigen/MoreVectorization +0 -24
  466. xtgeo/include/eigen3/unsupported/Eigen/NonLinearOptimization +0 -140
  467. xtgeo/include/eigen3/unsupported/Eigen/NumericalDiff +0 -56
  468. xtgeo/include/eigen3/unsupported/Eigen/OpenGLSupport +0 -322
  469. xtgeo/include/eigen3/unsupported/Eigen/Polynomials +0 -137
  470. xtgeo/include/eigen3/unsupported/Eigen/Skyline +0 -39
  471. xtgeo/include/eigen3/unsupported/Eigen/SparseExtra +0 -54
  472. xtgeo/include/eigen3/unsupported/Eigen/SpecialFunctions +0 -103
  473. xtgeo/include/eigen3/unsupported/Eigen/Splines +0 -35
  474. xtgeo/include/eigen3/unsupported/Eigen/src/AutoDiff/AutoDiffJacobian.h +0 -108
  475. xtgeo/include/eigen3/unsupported/Eigen/src/AutoDiff/AutoDiffScalar.h +0 -730
  476. xtgeo/include/eigen3/unsupported/Eigen/src/AutoDiff/AutoDiffVector.h +0 -220
  477. xtgeo/include/eigen3/unsupported/Eigen/src/BVH/BVAlgorithms.h +0 -293
  478. xtgeo/include/eigen3/unsupported/Eigen/src/BVH/KdBVH.h +0 -223
  479. xtgeo/include/eigen3/unsupported/Eigen/src/Eigenvalues/ArpackSelfAdjointEigenSolver.h +0 -790
  480. xtgeo/include/eigen3/unsupported/Eigen/src/EulerAngles/EulerAngles.h +0 -355
  481. xtgeo/include/eigen3/unsupported/Eigen/src/EulerAngles/EulerSystem.h +0 -305
  482. xtgeo/include/eigen3/unsupported/Eigen/src/FFT/ei_fftw_impl.h +0 -261
  483. xtgeo/include/eigen3/unsupported/Eigen/src/FFT/ei_kissfft_impl.h +0 -449
  484. xtgeo/include/eigen3/unsupported/Eigen/src/IterativeSolvers/ConstrainedConjGrad.h +0 -187
  485. xtgeo/include/eigen3/unsupported/Eigen/src/IterativeSolvers/DGMRES.h +0 -511
  486. xtgeo/include/eigen3/unsupported/Eigen/src/IterativeSolvers/GMRES.h +0 -335
  487. xtgeo/include/eigen3/unsupported/Eigen/src/IterativeSolvers/IDRS.h +0 -436
  488. xtgeo/include/eigen3/unsupported/Eigen/src/IterativeSolvers/IncompleteLU.h +0 -90
  489. xtgeo/include/eigen3/unsupported/Eigen/src/IterativeSolvers/IterationController.h +0 -154
  490. xtgeo/include/eigen3/unsupported/Eigen/src/IterativeSolvers/MINRES.h +0 -267
  491. xtgeo/include/eigen3/unsupported/Eigen/src/IterativeSolvers/Scaling.h +0 -193
  492. xtgeo/include/eigen3/unsupported/Eigen/src/KroneckerProduct/KroneckerTensorProduct.h +0 -305
  493. xtgeo/include/eigen3/unsupported/Eigen/src/LevenbergMarquardt/LMcovar.h +0 -84
  494. xtgeo/include/eigen3/unsupported/Eigen/src/LevenbergMarquardt/LMonestep.h +0 -202
  495. xtgeo/include/eigen3/unsupported/Eigen/src/LevenbergMarquardt/LMpar.h +0 -160
  496. xtgeo/include/eigen3/unsupported/Eigen/src/LevenbergMarquardt/LMqrsolv.h +0 -188
  497. xtgeo/include/eigen3/unsupported/Eigen/src/LevenbergMarquardt/LevenbergMarquardt.h +0 -396
  498. xtgeo/include/eigen3/unsupported/Eigen/src/MatrixFunctions/MatrixExponential.h +0 -441
  499. xtgeo/include/eigen3/unsupported/Eigen/src/MatrixFunctions/MatrixFunction.h +0 -569
  500. xtgeo/include/eigen3/unsupported/Eigen/src/MatrixFunctions/MatrixLogarithm.h +0 -373
  501. xtgeo/include/eigen3/unsupported/Eigen/src/MatrixFunctions/MatrixPower.h +0 -705
  502. xtgeo/include/eigen3/unsupported/Eigen/src/MatrixFunctions/MatrixSquareRoot.h +0 -368
  503. xtgeo/include/eigen3/unsupported/Eigen/src/MatrixFunctions/StemFunction.h +0 -117
  504. xtgeo/include/eigen3/unsupported/Eigen/src/MoreVectorization/MathFunctions.h +0 -95
  505. xtgeo/include/eigen3/unsupported/Eigen/src/NonLinearOptimization/HybridNonLinearSolver.h +0 -601
  506. xtgeo/include/eigen3/unsupported/Eigen/src/NonLinearOptimization/LevenbergMarquardt.h +0 -657
  507. xtgeo/include/eigen3/unsupported/Eigen/src/NonLinearOptimization/chkder.h +0 -66
  508. xtgeo/include/eigen3/unsupported/Eigen/src/NonLinearOptimization/covar.h +0 -70
  509. xtgeo/include/eigen3/unsupported/Eigen/src/NonLinearOptimization/dogleg.h +0 -107
  510. xtgeo/include/eigen3/unsupported/Eigen/src/NonLinearOptimization/fdjac1.h +0 -79
  511. xtgeo/include/eigen3/unsupported/Eigen/src/NonLinearOptimization/lmpar.h +0 -298
  512. xtgeo/include/eigen3/unsupported/Eigen/src/NonLinearOptimization/qrsolv.h +0 -91
  513. xtgeo/include/eigen3/unsupported/Eigen/src/NonLinearOptimization/r1mpyq.h +0 -30
  514. xtgeo/include/eigen3/unsupported/Eigen/src/NonLinearOptimization/r1updt.h +0 -99
  515. xtgeo/include/eigen3/unsupported/Eigen/src/NonLinearOptimization/rwupdt.h +0 -49
  516. xtgeo/include/eigen3/unsupported/Eigen/src/NumericalDiff/NumericalDiff.h +0 -130
  517. xtgeo/include/eigen3/unsupported/Eigen/src/Polynomials/Companion.h +0 -280
  518. xtgeo/include/eigen3/unsupported/Eigen/src/Polynomials/PolynomialSolver.h +0 -428
  519. xtgeo/include/eigen3/unsupported/Eigen/src/Polynomials/PolynomialUtils.h +0 -143
  520. xtgeo/include/eigen3/unsupported/Eigen/src/Skyline/SkylineInplaceLU.h +0 -352
  521. xtgeo/include/eigen3/unsupported/Eigen/src/Skyline/SkylineMatrix.h +0 -862
  522. xtgeo/include/eigen3/unsupported/Eigen/src/Skyline/SkylineMatrixBase.h +0 -212
  523. xtgeo/include/eigen3/unsupported/Eigen/src/Skyline/SkylineProduct.h +0 -295
  524. xtgeo/include/eigen3/unsupported/Eigen/src/Skyline/SkylineStorage.h +0 -259
  525. xtgeo/include/eigen3/unsupported/Eigen/src/Skyline/SkylineUtil.h +0 -89
  526. xtgeo/include/eigen3/unsupported/Eigen/src/SparseExtra/BlockOfDynamicSparseMatrix.h +0 -122
  527. xtgeo/include/eigen3/unsupported/Eigen/src/SparseExtra/BlockSparseMatrix.h +0 -1079
  528. xtgeo/include/eigen3/unsupported/Eigen/src/SparseExtra/DynamicSparseMatrix.h +0 -404
  529. xtgeo/include/eigen3/unsupported/Eigen/src/SparseExtra/MarketIO.h +0 -282
  530. xtgeo/include/eigen3/unsupported/Eigen/src/SparseExtra/MatrixMarketIterator.h +0 -247
  531. xtgeo/include/eigen3/unsupported/Eigen/src/SparseExtra/RandomSetter.h +0 -349
  532. xtgeo/include/eigen3/unsupported/Eigen/src/SpecialFunctions/BesselFunctionsArrayAPI.h +0 -286
  533. xtgeo/include/eigen3/unsupported/Eigen/src/SpecialFunctions/BesselFunctionsBFloat16.h +0 -68
  534. xtgeo/include/eigen3/unsupported/Eigen/src/SpecialFunctions/BesselFunctionsFunctors.h +0 -357
  535. xtgeo/include/eigen3/unsupported/Eigen/src/SpecialFunctions/BesselFunctionsHalf.h +0 -66
  536. xtgeo/include/eigen3/unsupported/Eigen/src/SpecialFunctions/BesselFunctionsImpl.h +0 -1959
  537. xtgeo/include/eigen3/unsupported/Eigen/src/SpecialFunctions/BesselFunctionsPacketMath.h +0 -118
  538. xtgeo/include/eigen3/unsupported/Eigen/src/SpecialFunctions/HipVectorCompatibility.h +0 -67
  539. xtgeo/include/eigen3/unsupported/Eigen/src/SpecialFunctions/SpecialFunctionsArrayAPI.h +0 -167
  540. xtgeo/include/eigen3/unsupported/Eigen/src/SpecialFunctions/SpecialFunctionsBFloat16.h +0 -58
  541. xtgeo/include/eigen3/unsupported/Eigen/src/SpecialFunctions/SpecialFunctionsFunctors.h +0 -330
  542. xtgeo/include/eigen3/unsupported/Eigen/src/SpecialFunctions/SpecialFunctionsHalf.h +0 -58
  543. xtgeo/include/eigen3/unsupported/Eigen/src/SpecialFunctions/SpecialFunctionsImpl.h +0 -2045
  544. xtgeo/include/eigen3/unsupported/Eigen/src/SpecialFunctions/SpecialFunctionsPacketMath.h +0 -79
  545. xtgeo/include/eigen3/unsupported/Eigen/src/SpecialFunctions/arch/AVX/BesselFunctions.h +0 -46
  546. xtgeo/include/eigen3/unsupported/Eigen/src/SpecialFunctions/arch/AVX/SpecialFunctions.h +0 -16
  547. xtgeo/include/eigen3/unsupported/Eigen/src/SpecialFunctions/arch/AVX512/BesselFunctions.h +0 -46
  548. xtgeo/include/eigen3/unsupported/Eigen/src/SpecialFunctions/arch/AVX512/SpecialFunctions.h +0 -16
  549. xtgeo/include/eigen3/unsupported/Eigen/src/SpecialFunctions/arch/GPU/SpecialFunctions.h +0 -369
  550. xtgeo/include/eigen3/unsupported/Eigen/src/SpecialFunctions/arch/NEON/BesselFunctions.h +0 -54
  551. xtgeo/include/eigen3/unsupported/Eigen/src/SpecialFunctions/arch/NEON/SpecialFunctions.h +0 -34
  552. xtgeo/include/eigen3/unsupported/Eigen/src/Splines/Spline.h +0 -507
  553. xtgeo/include/eigen3/unsupported/Eigen/src/Splines/SplineFitting.h +0 -431
  554. xtgeo/include/eigen3/unsupported/Eigen/src/Splines/SplineFwd.h +0 -93
  555. xtgeo/share/eigen3/cmake/Eigen3Config.cmake +0 -37
  556. xtgeo/share/eigen3/cmake/Eigen3ConfigVersion.cmake +0 -65
  557. xtgeo/share/eigen3/cmake/UseEigen3.cmake +0 -6
  558. xtgeo/share/pkgconfig/eigen3.pc +0 -9
  559. xtgeo-4.10.0.dist-info/RECORD +0 -652
  560. {xtgeo-4.10.0.dist-info → xtgeo-4.10.1.dist-info}/WHEEL +0 -0
  561. {xtgeo-4.10.0.dist-info → xtgeo-4.10.1.dist-info}/licenses/LICENSE.md +0 -0
@@ -1,870 +0,0 @@
1
- // This file is part of Eigen, a lightweight C++ template library
2
- // for linear algebra.
3
- //
4
- // Copyright (C) 2008-2010 Gael Guennebaud <gael.guennebaud@inria.fr>
5
- // Copyright (C) 2009 Mathieu Gautier <mathieu.gautier@cea.fr>
6
- //
7
- // This Source Code Form is subject to the terms of the Mozilla
8
- // Public License v. 2.0. If a copy of the MPL was not distributed
9
- // with this file, You can obtain one at http://mozilla.org/MPL/2.0/.
10
-
11
- #ifndef EIGEN_QUATERNION_H
12
- #define EIGEN_QUATERNION_H
13
- namespace Eigen {
14
-
15
-
16
- /***************************************************************************
17
- * Definition of QuaternionBase<Derived>
18
- * The implementation is at the end of the file
19
- ***************************************************************************/
20
-
21
- namespace internal {
22
- template<typename Other,
23
- int OtherRows=Other::RowsAtCompileTime,
24
- int OtherCols=Other::ColsAtCompileTime>
25
- struct quaternionbase_assign_impl;
26
- }
27
-
28
- /** \geometry_module \ingroup Geometry_Module
29
- * \class QuaternionBase
30
- * \brief Base class for quaternion expressions
31
- * \tparam Derived derived type (CRTP)
32
- * \sa class Quaternion
33
- */
34
- template<class Derived>
35
- class QuaternionBase : public RotationBase<Derived, 3>
36
- {
37
- public:
38
- typedef RotationBase<Derived, 3> Base;
39
-
40
- using Base::operator*;
41
- using Base::derived;
42
-
43
- typedef typename internal::traits<Derived>::Scalar Scalar;
44
- typedef typename NumTraits<Scalar>::Real RealScalar;
45
- typedef typename internal::traits<Derived>::Coefficients Coefficients;
46
- typedef typename Coefficients::CoeffReturnType CoeffReturnType;
47
- typedef typename internal::conditional<bool(internal::traits<Derived>::Flags&LvalueBit),
48
- Scalar&, CoeffReturnType>::type NonConstCoeffReturnType;
49
-
50
-
51
- enum {
52
- Flags = Eigen::internal::traits<Derived>::Flags
53
- };
54
-
55
- // typedef typename Matrix<Scalar,4,1> Coefficients;
56
- /** the type of a 3D vector */
57
- typedef Matrix<Scalar,3,1> Vector3;
58
- /** the equivalent rotation matrix type */
59
- typedef Matrix<Scalar,3,3> Matrix3;
60
- /** the equivalent angle-axis type */
61
- typedef AngleAxis<Scalar> AngleAxisType;
62
-
63
-
64
-
65
- /** \returns the \c x coefficient */
66
- EIGEN_DEVICE_FUNC inline CoeffReturnType x() const { return this->derived().coeffs().coeff(0); }
67
- /** \returns the \c y coefficient */
68
- EIGEN_DEVICE_FUNC inline CoeffReturnType y() const { return this->derived().coeffs().coeff(1); }
69
- /** \returns the \c z coefficient */
70
- EIGEN_DEVICE_FUNC inline CoeffReturnType z() const { return this->derived().coeffs().coeff(2); }
71
- /** \returns the \c w coefficient */
72
- EIGEN_DEVICE_FUNC inline CoeffReturnType w() const { return this->derived().coeffs().coeff(3); }
73
-
74
- /** \returns a reference to the \c x coefficient (if Derived is a non-const lvalue) */
75
- EIGEN_DEVICE_FUNC inline NonConstCoeffReturnType x() { return this->derived().coeffs().x(); }
76
- /** \returns a reference to the \c y coefficient (if Derived is a non-const lvalue) */
77
- EIGEN_DEVICE_FUNC inline NonConstCoeffReturnType y() { return this->derived().coeffs().y(); }
78
- /** \returns a reference to the \c z coefficient (if Derived is a non-const lvalue) */
79
- EIGEN_DEVICE_FUNC inline NonConstCoeffReturnType z() { return this->derived().coeffs().z(); }
80
- /** \returns a reference to the \c w coefficient (if Derived is a non-const lvalue) */
81
- EIGEN_DEVICE_FUNC inline NonConstCoeffReturnType w() { return this->derived().coeffs().w(); }
82
-
83
- /** \returns a read-only vector expression of the imaginary part (x,y,z) */
84
- EIGEN_DEVICE_FUNC inline const VectorBlock<const Coefficients,3> vec() const { return coeffs().template head<3>(); }
85
-
86
- /** \returns a vector expression of the imaginary part (x,y,z) */
87
- EIGEN_DEVICE_FUNC inline VectorBlock<Coefficients,3> vec() { return coeffs().template head<3>(); }
88
-
89
- /** \returns a read-only vector expression of the coefficients (x,y,z,w) */
90
- EIGEN_DEVICE_FUNC inline const typename internal::traits<Derived>::Coefficients& coeffs() const { return derived().coeffs(); }
91
-
92
- /** \returns a vector expression of the coefficients (x,y,z,w) */
93
- EIGEN_DEVICE_FUNC inline typename internal::traits<Derived>::Coefficients& coeffs() { return derived().coeffs(); }
94
-
95
- EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE QuaternionBase<Derived>& operator=(const QuaternionBase<Derived>& other);
96
- template<class OtherDerived> EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Derived& operator=(const QuaternionBase<OtherDerived>& other);
97
-
98
- // disabled this copy operator as it is giving very strange compilation errors when compiling
99
- // test_stdvector with GCC 4.4.2. This looks like a GCC bug though, so feel free to re-enable it if it's
100
- // useful; however notice that we already have the templated operator= above and e.g. in MatrixBase
101
- // we didn't have to add, in addition to templated operator=, such a non-templated copy operator.
102
- // Derived& operator=(const QuaternionBase& other)
103
- // { return operator=<Derived>(other); }
104
-
105
- EIGEN_DEVICE_FUNC Derived& operator=(const AngleAxisType& aa);
106
- template<class OtherDerived> EIGEN_DEVICE_FUNC Derived& operator=(const MatrixBase<OtherDerived>& m);
107
-
108
- /** \returns a quaternion representing an identity rotation
109
- * \sa MatrixBase::Identity()
110
- */
111
- EIGEN_DEVICE_FUNC static inline Quaternion<Scalar> Identity() { return Quaternion<Scalar>(Scalar(1), Scalar(0), Scalar(0), Scalar(0)); }
112
-
113
- /** \sa QuaternionBase::Identity(), MatrixBase::setIdentity()
114
- */
115
- EIGEN_DEVICE_FUNC inline QuaternionBase& setIdentity() { coeffs() << Scalar(0), Scalar(0), Scalar(0), Scalar(1); return *this; }
116
-
117
- /** \returns the squared norm of the quaternion's coefficients
118
- * \sa QuaternionBase::norm(), MatrixBase::squaredNorm()
119
- */
120
- EIGEN_DEVICE_FUNC inline Scalar squaredNorm() const { return coeffs().squaredNorm(); }
121
-
122
- /** \returns the norm of the quaternion's coefficients
123
- * \sa QuaternionBase::squaredNorm(), MatrixBase::norm()
124
- */
125
- EIGEN_DEVICE_FUNC inline Scalar norm() const { return coeffs().norm(); }
126
-
127
- /** Normalizes the quaternion \c *this
128
- * \sa normalized(), MatrixBase::normalize() */
129
- EIGEN_DEVICE_FUNC inline void normalize() { coeffs().normalize(); }
130
- /** \returns a normalized copy of \c *this
131
- * \sa normalize(), MatrixBase::normalized() */
132
- EIGEN_DEVICE_FUNC inline Quaternion<Scalar> normalized() const { return Quaternion<Scalar>(coeffs().normalized()); }
133
-
134
- /** \returns the dot product of \c *this and \a other
135
- * Geometrically speaking, the dot product of two unit quaternions
136
- * corresponds to the cosine of half the angle between the two rotations.
137
- * \sa angularDistance()
138
- */
139
- template<class OtherDerived> EIGEN_DEVICE_FUNC inline Scalar dot(const QuaternionBase<OtherDerived>& other) const { return coeffs().dot(other.coeffs()); }
140
-
141
- template<class OtherDerived> EIGEN_DEVICE_FUNC Scalar angularDistance(const QuaternionBase<OtherDerived>& other) const;
142
-
143
- /** \returns an equivalent 3x3 rotation matrix */
144
- EIGEN_DEVICE_FUNC inline Matrix3 toRotationMatrix() const;
145
-
146
- /** \returns the quaternion which transform \a a into \a b through a rotation */
147
- template<typename Derived1, typename Derived2>
148
- EIGEN_DEVICE_FUNC Derived& setFromTwoVectors(const MatrixBase<Derived1>& a, const MatrixBase<Derived2>& b);
149
-
150
- template<class OtherDerived> EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Quaternion<Scalar> operator* (const QuaternionBase<OtherDerived>& q) const;
151
- template<class OtherDerived> EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Derived& operator*= (const QuaternionBase<OtherDerived>& q);
152
-
153
- /** \returns the quaternion describing the inverse rotation */
154
- EIGEN_DEVICE_FUNC Quaternion<Scalar> inverse() const;
155
-
156
- /** \returns the conjugated quaternion */
157
- EIGEN_DEVICE_FUNC Quaternion<Scalar> conjugate() const;
158
-
159
- template<class OtherDerived> EIGEN_DEVICE_FUNC Quaternion<Scalar> slerp(const Scalar& t, const QuaternionBase<OtherDerived>& other) const;
160
-
161
- /** \returns true if each coefficients of \c *this and \a other are all exactly equal.
162
- * \warning When using floating point scalar values you probably should rather use a
163
- * fuzzy comparison such as isApprox()
164
- * \sa isApprox(), operator!= */
165
- template<class OtherDerived>
166
- EIGEN_DEVICE_FUNC inline bool operator==(const QuaternionBase<OtherDerived>& other) const
167
- { return coeffs() == other.coeffs(); }
168
-
169
- /** \returns true if at least one pair of coefficients of \c *this and \a other are not exactly equal to each other.
170
- * \warning When using floating point scalar values you probably should rather use a
171
- * fuzzy comparison such as isApprox()
172
- * \sa isApprox(), operator== */
173
- template<class OtherDerived>
174
- EIGEN_DEVICE_FUNC inline bool operator!=(const QuaternionBase<OtherDerived>& other) const
175
- { return coeffs() != other.coeffs(); }
176
-
177
- /** \returns \c true if \c *this is approximately equal to \a other, within the precision
178
- * determined by \a prec.
179
- *
180
- * \sa MatrixBase::isApprox() */
181
- template<class OtherDerived>
182
- EIGEN_DEVICE_FUNC bool isApprox(const QuaternionBase<OtherDerived>& other, const RealScalar& prec = NumTraits<Scalar>::dummy_precision()) const
183
- { return coeffs().isApprox(other.coeffs(), prec); }
184
-
185
- /** return the result vector of \a v through the rotation*/
186
- EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Vector3 _transformVector(const Vector3& v) const;
187
-
188
- #ifdef EIGEN_PARSED_BY_DOXYGEN
189
- /** \returns \c *this with scalar type casted to \a NewScalarType
190
- *
191
- * Note that if \a NewScalarType is equal to the current scalar type of \c *this
192
- * then this function smartly returns a const reference to \c *this.
193
- */
194
- template<typename NewScalarType>
195
- EIGEN_DEVICE_FUNC inline typename internal::cast_return_type<Derived,Quaternion<NewScalarType> >::type cast() const;
196
-
197
- #else
198
-
199
- template<typename NewScalarType>
200
- EIGEN_DEVICE_FUNC inline
201
- typename internal::enable_if<internal::is_same<Scalar,NewScalarType>::value,const Derived&>::type cast() const
202
- {
203
- return derived();
204
- }
205
-
206
- template<typename NewScalarType>
207
- EIGEN_DEVICE_FUNC inline
208
- typename internal::enable_if<!internal::is_same<Scalar,NewScalarType>::value,Quaternion<NewScalarType> >::type cast() const
209
- {
210
- return Quaternion<NewScalarType>(coeffs().template cast<NewScalarType>());
211
- }
212
- #endif
213
-
214
- #ifndef EIGEN_NO_IO
215
- friend std::ostream& operator<<(std::ostream& s, const QuaternionBase<Derived>& q) {
216
- s << q.x() << "i + " << q.y() << "j + " << q.z() << "k" << " + " << q.w();
217
- return s;
218
- }
219
- #endif
220
-
221
- #ifdef EIGEN_QUATERNIONBASE_PLUGIN
222
- # include EIGEN_QUATERNIONBASE_PLUGIN
223
- #endif
224
- protected:
225
- EIGEN_DEFAULT_COPY_CONSTRUCTOR(QuaternionBase)
226
- EIGEN_DEFAULT_EMPTY_CONSTRUCTOR_AND_DESTRUCTOR(QuaternionBase)
227
- };
228
-
229
- /***************************************************************************
230
- * Definition/implementation of Quaternion<Scalar>
231
- ***************************************************************************/
232
-
233
- /** \geometry_module \ingroup Geometry_Module
234
- *
235
- * \class Quaternion
236
- *
237
- * \brief The quaternion class used to represent 3D orientations and rotations
238
- *
239
- * \tparam _Scalar the scalar type, i.e., the type of the coefficients
240
- * \tparam _Options controls the memory alignment of the coefficients. Can be \# AutoAlign or \# DontAlign. Default is AutoAlign.
241
- *
242
- * This class represents a quaternion \f$ w+xi+yj+zk \f$ that is a convenient representation of
243
- * orientations and rotations of objects in three dimensions. Compared to other representations
244
- * like Euler angles or 3x3 matrices, quaternions offer the following advantages:
245
- * \li \b compact storage (4 scalars)
246
- * \li \b efficient to compose (28 flops),
247
- * \li \b stable spherical interpolation
248
- *
249
- * The following two typedefs are provided for convenience:
250
- * \li \c Quaternionf for \c float
251
- * \li \c Quaterniond for \c double
252
- *
253
- * \warning Operations interpreting the quaternion as rotation have undefined behavior if the quaternion is not normalized.
254
- *
255
- * \sa class AngleAxis, class Transform
256
- */
257
-
258
- namespace internal {
259
- template<typename _Scalar,int _Options>
260
- struct traits<Quaternion<_Scalar,_Options> >
261
- {
262
- typedef Quaternion<_Scalar,_Options> PlainObject;
263
- typedef _Scalar Scalar;
264
- typedef Matrix<_Scalar,4,1,_Options> Coefficients;
265
- enum{
266
- Alignment = internal::traits<Coefficients>::Alignment,
267
- Flags = LvalueBit
268
- };
269
- };
270
- }
271
-
272
- template<typename _Scalar, int _Options>
273
- class Quaternion : public QuaternionBase<Quaternion<_Scalar,_Options> >
274
- {
275
- public:
276
- typedef QuaternionBase<Quaternion<_Scalar,_Options> > Base;
277
- enum { NeedsAlignment = internal::traits<Quaternion>::Alignment>0 };
278
-
279
- typedef _Scalar Scalar;
280
-
281
- EIGEN_INHERIT_ASSIGNMENT_OPERATORS(Quaternion)
282
- using Base::operator*=;
283
-
284
- typedef typename internal::traits<Quaternion>::Coefficients Coefficients;
285
- typedef typename Base::AngleAxisType AngleAxisType;
286
-
287
- /** Default constructor leaving the quaternion uninitialized. */
288
- EIGEN_DEVICE_FUNC inline Quaternion() {}
289
-
290
- /** Constructs and initializes the quaternion \f$ w+xi+yj+zk \f$ from
291
- * its four coefficients \a w, \a x, \a y and \a z.
292
- *
293
- * \warning Note the order of the arguments: the real \a w coefficient first,
294
- * while internally the coefficients are stored in the following order:
295
- * [\c x, \c y, \c z, \c w]
296
- */
297
- EIGEN_DEVICE_FUNC inline Quaternion(const Scalar& w, const Scalar& x, const Scalar& y, const Scalar& z) : m_coeffs(x, y, z, w){}
298
-
299
- /** Constructs and initialize a quaternion from the array data */
300
- EIGEN_DEVICE_FUNC explicit inline Quaternion(const Scalar* data) : m_coeffs(data) {}
301
-
302
- /** Copy constructor */
303
- template<class Derived> EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Quaternion(const QuaternionBase<Derived>& other) { this->Base::operator=(other); }
304
-
305
- /** Constructs and initializes a quaternion from the angle-axis \a aa */
306
- EIGEN_DEVICE_FUNC explicit inline Quaternion(const AngleAxisType& aa) { *this = aa; }
307
-
308
- /** Constructs and initializes a quaternion from either:
309
- * - a rotation matrix expression,
310
- * - a 4D vector expression representing quaternion coefficients.
311
- */
312
- template<typename Derived>
313
- EIGEN_DEVICE_FUNC explicit inline Quaternion(const MatrixBase<Derived>& other) { *this = other; }
314
-
315
- /** Explicit copy constructor with scalar conversion */
316
- template<typename OtherScalar, int OtherOptions>
317
- EIGEN_DEVICE_FUNC explicit inline Quaternion(const Quaternion<OtherScalar, OtherOptions>& other)
318
- { m_coeffs = other.coeffs().template cast<Scalar>(); }
319
-
320
- #if EIGEN_HAS_RVALUE_REFERENCES
321
- // We define a copy constructor, which means we don't get an implicit move constructor or assignment operator.
322
- /** Default move constructor */
323
- EIGEN_DEVICE_FUNC inline Quaternion(Quaternion&& other) EIGEN_NOEXCEPT_IF(std::is_nothrow_move_constructible<Scalar>::value)
324
- : m_coeffs(std::move(other.coeffs()))
325
- {}
326
-
327
- /** Default move assignment operator */
328
- EIGEN_DEVICE_FUNC Quaternion& operator=(Quaternion&& other) EIGEN_NOEXCEPT_IF(std::is_nothrow_move_assignable<Scalar>::value)
329
- {
330
- m_coeffs = std::move(other.coeffs());
331
- return *this;
332
- }
333
- #endif
334
-
335
- EIGEN_DEVICE_FUNC static Quaternion UnitRandom();
336
-
337
- template<typename Derived1, typename Derived2>
338
- EIGEN_DEVICE_FUNC static Quaternion FromTwoVectors(const MatrixBase<Derived1>& a, const MatrixBase<Derived2>& b);
339
-
340
- EIGEN_DEVICE_FUNC inline Coefficients& coeffs() { return m_coeffs;}
341
- EIGEN_DEVICE_FUNC inline const Coefficients& coeffs() const { return m_coeffs;}
342
-
343
- EIGEN_MAKE_ALIGNED_OPERATOR_NEW_IF(bool(NeedsAlignment))
344
-
345
- #ifdef EIGEN_QUATERNION_PLUGIN
346
- # include EIGEN_QUATERNION_PLUGIN
347
- #endif
348
-
349
- protected:
350
- Coefficients m_coeffs;
351
-
352
- #ifndef EIGEN_PARSED_BY_DOXYGEN
353
- static EIGEN_STRONG_INLINE void _check_template_params()
354
- {
355
- EIGEN_STATIC_ASSERT( (_Options & DontAlign) == _Options,
356
- INVALID_MATRIX_TEMPLATE_PARAMETERS)
357
- }
358
- #endif
359
- };
360
-
361
- /** \ingroup Geometry_Module
362
- * single precision quaternion type */
363
- typedef Quaternion<float> Quaternionf;
364
- /** \ingroup Geometry_Module
365
- * double precision quaternion type */
366
- typedef Quaternion<double> Quaterniond;
367
-
368
- /***************************************************************************
369
- * Specialization of Map<Quaternion<Scalar>>
370
- ***************************************************************************/
371
-
372
- namespace internal {
373
- template<typename _Scalar, int _Options>
374
- struct traits<Map<Quaternion<_Scalar>, _Options> > : traits<Quaternion<_Scalar, (int(_Options)&Aligned)==Aligned ? AutoAlign : DontAlign> >
375
- {
376
- typedef Map<Matrix<_Scalar,4,1>, _Options> Coefficients;
377
- };
378
- }
379
-
380
- namespace internal {
381
- template<typename _Scalar, int _Options>
382
- struct traits<Map<const Quaternion<_Scalar>, _Options> > : traits<Quaternion<_Scalar, (int(_Options)&Aligned)==Aligned ? AutoAlign : DontAlign> >
383
- {
384
- typedef Map<const Matrix<_Scalar,4,1>, _Options> Coefficients;
385
- typedef traits<Quaternion<_Scalar, (int(_Options)&Aligned)==Aligned ? AutoAlign : DontAlign> > TraitsBase;
386
- enum {
387
- Flags = TraitsBase::Flags & ~LvalueBit
388
- };
389
- };
390
- }
391
-
392
- /** \ingroup Geometry_Module
393
- * \brief Quaternion expression mapping a constant memory buffer
394
- *
395
- * \tparam _Scalar the type of the Quaternion coefficients
396
- * \tparam _Options see class Map
397
- *
398
- * This is a specialization of class Map for Quaternion. This class allows to view
399
- * a 4 scalar memory buffer as an Eigen's Quaternion object.
400
- *
401
- * \sa class Map, class Quaternion, class QuaternionBase
402
- */
403
- template<typename _Scalar, int _Options>
404
- class Map<const Quaternion<_Scalar>, _Options >
405
- : public QuaternionBase<Map<const Quaternion<_Scalar>, _Options> >
406
- {
407
- public:
408
- typedef QuaternionBase<Map<const Quaternion<_Scalar>, _Options> > Base;
409
-
410
- typedef _Scalar Scalar;
411
- typedef typename internal::traits<Map>::Coefficients Coefficients;
412
- EIGEN_INHERIT_ASSIGNMENT_OPERATORS(Map)
413
- using Base::operator*=;
414
-
415
- /** Constructs a Mapped Quaternion object from the pointer \a coeffs
416
- *
417
- * The pointer \a coeffs must reference the four coefficients of Quaternion in the following order:
418
- * \code *coeffs == {x, y, z, w} \endcode
419
- *
420
- * If the template parameter _Options is set to #Aligned, then the pointer coeffs must be aligned. */
421
- EIGEN_DEVICE_FUNC explicit EIGEN_STRONG_INLINE Map(const Scalar* coeffs) : m_coeffs(coeffs) {}
422
-
423
- EIGEN_DEVICE_FUNC inline const Coefficients& coeffs() const { return m_coeffs;}
424
-
425
- protected:
426
- const Coefficients m_coeffs;
427
- };
428
-
429
- /** \ingroup Geometry_Module
430
- * \brief Expression of a quaternion from a memory buffer
431
- *
432
- * \tparam _Scalar the type of the Quaternion coefficients
433
- * \tparam _Options see class Map
434
- *
435
- * This is a specialization of class Map for Quaternion. This class allows to view
436
- * a 4 scalar memory buffer as an Eigen's Quaternion object.
437
- *
438
- * \sa class Map, class Quaternion, class QuaternionBase
439
- */
440
- template<typename _Scalar, int _Options>
441
- class Map<Quaternion<_Scalar>, _Options >
442
- : public QuaternionBase<Map<Quaternion<_Scalar>, _Options> >
443
- {
444
- public:
445
- typedef QuaternionBase<Map<Quaternion<_Scalar>, _Options> > Base;
446
-
447
- typedef _Scalar Scalar;
448
- typedef typename internal::traits<Map>::Coefficients Coefficients;
449
- EIGEN_INHERIT_ASSIGNMENT_OPERATORS(Map)
450
- using Base::operator*=;
451
-
452
- /** Constructs a Mapped Quaternion object from the pointer \a coeffs
453
- *
454
- * The pointer \a coeffs must reference the four coefficients of Quaternion in the following order:
455
- * \code *coeffs == {x, y, z, w} \endcode
456
- *
457
- * If the template parameter _Options is set to #Aligned, then the pointer coeffs must be aligned. */
458
- EIGEN_DEVICE_FUNC explicit EIGEN_STRONG_INLINE Map(Scalar* coeffs) : m_coeffs(coeffs) {}
459
-
460
- EIGEN_DEVICE_FUNC inline Coefficients& coeffs() { return m_coeffs; }
461
- EIGEN_DEVICE_FUNC inline const Coefficients& coeffs() const { return m_coeffs; }
462
-
463
- protected:
464
- Coefficients m_coeffs;
465
- };
466
-
467
- /** \ingroup Geometry_Module
468
- * Map an unaligned array of single precision scalars as a quaternion */
469
- typedef Map<Quaternion<float>, 0> QuaternionMapf;
470
- /** \ingroup Geometry_Module
471
- * Map an unaligned array of double precision scalars as a quaternion */
472
- typedef Map<Quaternion<double>, 0> QuaternionMapd;
473
- /** \ingroup Geometry_Module
474
- * Map a 16-byte aligned array of single precision scalars as a quaternion */
475
- typedef Map<Quaternion<float>, Aligned> QuaternionMapAlignedf;
476
- /** \ingroup Geometry_Module
477
- * Map a 16-byte aligned array of double precision scalars as a quaternion */
478
- typedef Map<Quaternion<double>, Aligned> QuaternionMapAlignedd;
479
-
480
- /***************************************************************************
481
- * Implementation of QuaternionBase methods
482
- ***************************************************************************/
483
-
484
- // Generic Quaternion * Quaternion product
485
- // This product can be specialized for a given architecture via the Arch template argument.
486
- namespace internal {
487
- template<int Arch, class Derived1, class Derived2, typename Scalar> struct quat_product
488
- {
489
- EIGEN_DEVICE_FUNC static EIGEN_STRONG_INLINE Quaternion<Scalar> run(const QuaternionBase<Derived1>& a, const QuaternionBase<Derived2>& b){
490
- return Quaternion<Scalar>
491
- (
492
- a.w() * b.w() - a.x() * b.x() - a.y() * b.y() - a.z() * b.z(),
493
- a.w() * b.x() + a.x() * b.w() + a.y() * b.z() - a.z() * b.y(),
494
- a.w() * b.y() + a.y() * b.w() + a.z() * b.x() - a.x() * b.z(),
495
- a.w() * b.z() + a.z() * b.w() + a.x() * b.y() - a.y() * b.x()
496
- );
497
- }
498
- };
499
- }
500
-
501
- /** \returns the concatenation of two rotations as a quaternion-quaternion product */
502
- template <class Derived>
503
- template <class OtherDerived>
504
- EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Quaternion<typename internal::traits<Derived>::Scalar>
505
- QuaternionBase<Derived>::operator* (const QuaternionBase<OtherDerived>& other) const
506
- {
507
- EIGEN_STATIC_ASSERT((internal::is_same<typename Derived::Scalar, typename OtherDerived::Scalar>::value),
508
- YOU_MIXED_DIFFERENT_NUMERIC_TYPES__YOU_NEED_TO_USE_THE_CAST_METHOD_OF_MATRIXBASE_TO_CAST_NUMERIC_TYPES_EXPLICITLY)
509
- return internal::quat_product<Architecture::Target, Derived, OtherDerived,
510
- typename internal::traits<Derived>::Scalar>::run(*this, other);
511
- }
512
-
513
- /** \sa operator*(Quaternion) */
514
- template <class Derived>
515
- template <class OtherDerived>
516
- EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Derived& QuaternionBase<Derived>::operator*= (const QuaternionBase<OtherDerived>& other)
517
- {
518
- derived() = derived() * other.derived();
519
- return derived();
520
- }
521
-
522
- /** Rotation of a vector by a quaternion.
523
- * \remarks If the quaternion is used to rotate several points (>1)
524
- * then it is much more efficient to first convert it to a 3x3 Matrix.
525
- * Comparison of the operation cost for n transformations:
526
- * - Quaternion2: 30n
527
- * - Via a Matrix3: 24 + 15n
528
- */
529
- template <class Derived>
530
- EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE typename QuaternionBase<Derived>::Vector3
531
- QuaternionBase<Derived>::_transformVector(const Vector3& v) const
532
- {
533
- // Note that this algorithm comes from the optimization by hand
534
- // of the conversion to a Matrix followed by a Matrix/Vector product.
535
- // It appears to be much faster than the common algorithm found
536
- // in the literature (30 versus 39 flops). It also requires two
537
- // Vector3 as temporaries.
538
- Vector3 uv = this->vec().cross(v);
539
- uv += uv;
540
- return v + this->w() * uv + this->vec().cross(uv);
541
- }
542
-
543
- template<class Derived>
544
- EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE QuaternionBase<Derived>& QuaternionBase<Derived>::operator=(const QuaternionBase<Derived>& other)
545
- {
546
- coeffs() = other.coeffs();
547
- return derived();
548
- }
549
-
550
- template<class Derived>
551
- template<class OtherDerived>
552
- EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Derived& QuaternionBase<Derived>::operator=(const QuaternionBase<OtherDerived>& other)
553
- {
554
- coeffs() = other.coeffs();
555
- return derived();
556
- }
557
-
558
- /** Set \c *this from an angle-axis \a aa and returns a reference to \c *this
559
- */
560
- template<class Derived>
561
- EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Derived& QuaternionBase<Derived>::operator=(const AngleAxisType& aa)
562
- {
563
- EIGEN_USING_STD(cos)
564
- EIGEN_USING_STD(sin)
565
- Scalar ha = Scalar(0.5)*aa.angle(); // Scalar(0.5) to suppress precision loss warnings
566
- this->w() = cos(ha);
567
- this->vec() = sin(ha) * aa.axis();
568
- return derived();
569
- }
570
-
571
- /** Set \c *this from the expression \a xpr:
572
- * - if \a xpr is a 4x1 vector, then \a xpr is assumed to be a quaternion
573
- * - if \a xpr is a 3x3 matrix, then \a xpr is assumed to be rotation matrix
574
- * and \a xpr is converted to a quaternion
575
- */
576
-
577
- template<class Derived>
578
- template<class MatrixDerived>
579
- EIGEN_DEVICE_FUNC inline Derived& QuaternionBase<Derived>::operator=(const MatrixBase<MatrixDerived>& xpr)
580
- {
581
- EIGEN_STATIC_ASSERT((internal::is_same<typename Derived::Scalar, typename MatrixDerived::Scalar>::value),
582
- YOU_MIXED_DIFFERENT_NUMERIC_TYPES__YOU_NEED_TO_USE_THE_CAST_METHOD_OF_MATRIXBASE_TO_CAST_NUMERIC_TYPES_EXPLICITLY)
583
- internal::quaternionbase_assign_impl<MatrixDerived>::run(*this, xpr.derived());
584
- return derived();
585
- }
586
-
587
- /** Convert the quaternion to a 3x3 rotation matrix. The quaternion is required to
588
- * be normalized, otherwise the result is undefined.
589
- */
590
- template<class Derived>
591
- EIGEN_DEVICE_FUNC inline typename QuaternionBase<Derived>::Matrix3
592
- QuaternionBase<Derived>::toRotationMatrix(void) const
593
- {
594
- // NOTE if inlined, then gcc 4.2 and 4.4 get rid of the temporary (not gcc 4.3 !!)
595
- // if not inlined then the cost of the return by value is huge ~ +35%,
596
- // however, not inlining this function is an order of magnitude slower, so
597
- // it has to be inlined, and so the return by value is not an issue
598
- Matrix3 res;
599
-
600
- const Scalar tx = Scalar(2)*this->x();
601
- const Scalar ty = Scalar(2)*this->y();
602
- const Scalar tz = Scalar(2)*this->z();
603
- const Scalar twx = tx*this->w();
604
- const Scalar twy = ty*this->w();
605
- const Scalar twz = tz*this->w();
606
- const Scalar txx = tx*this->x();
607
- const Scalar txy = ty*this->x();
608
- const Scalar txz = tz*this->x();
609
- const Scalar tyy = ty*this->y();
610
- const Scalar tyz = tz*this->y();
611
- const Scalar tzz = tz*this->z();
612
-
613
- res.coeffRef(0,0) = Scalar(1)-(tyy+tzz);
614
- res.coeffRef(0,1) = txy-twz;
615
- res.coeffRef(0,2) = txz+twy;
616
- res.coeffRef(1,0) = txy+twz;
617
- res.coeffRef(1,1) = Scalar(1)-(txx+tzz);
618
- res.coeffRef(1,2) = tyz-twx;
619
- res.coeffRef(2,0) = txz-twy;
620
- res.coeffRef(2,1) = tyz+twx;
621
- res.coeffRef(2,2) = Scalar(1)-(txx+tyy);
622
-
623
- return res;
624
- }
625
-
626
- /** Sets \c *this to be a quaternion representing a rotation between
627
- * the two arbitrary vectors \a a and \a b. In other words, the built
628
- * rotation represent a rotation sending the line of direction \a a
629
- * to the line of direction \a b, both lines passing through the origin.
630
- *
631
- * \returns a reference to \c *this.
632
- *
633
- * Note that the two input vectors do \b not have to be normalized, and
634
- * do not need to have the same norm.
635
- */
636
- template<class Derived>
637
- template<typename Derived1, typename Derived2>
638
- EIGEN_DEVICE_FUNC inline Derived& QuaternionBase<Derived>::setFromTwoVectors(const MatrixBase<Derived1>& a, const MatrixBase<Derived2>& b)
639
- {
640
- EIGEN_USING_STD(sqrt)
641
- Vector3 v0 = a.normalized();
642
- Vector3 v1 = b.normalized();
643
- Scalar c = v1.dot(v0);
644
-
645
- // if dot == -1, vectors are nearly opposites
646
- // => accurately compute the rotation axis by computing the
647
- // intersection of the two planes. This is done by solving:
648
- // x^T v0 = 0
649
- // x^T v1 = 0
650
- // under the constraint:
651
- // ||x|| = 1
652
- // which yields a singular value problem
653
- if (c < Scalar(-1)+NumTraits<Scalar>::dummy_precision())
654
- {
655
- c = numext::maxi(c,Scalar(-1));
656
- Matrix<Scalar,2,3> m; m << v0.transpose(), v1.transpose();
657
- JacobiSVD<Matrix<Scalar,2,3> > svd(m, ComputeFullV);
658
- Vector3 axis = svd.matrixV().col(2);
659
-
660
- Scalar w2 = (Scalar(1)+c)*Scalar(0.5);
661
- this->w() = sqrt(w2);
662
- this->vec() = axis * sqrt(Scalar(1) - w2);
663
- return derived();
664
- }
665
- Vector3 axis = v0.cross(v1);
666
- Scalar s = sqrt((Scalar(1)+c)*Scalar(2));
667
- Scalar invs = Scalar(1)/s;
668
- this->vec() = axis * invs;
669
- this->w() = s * Scalar(0.5);
670
-
671
- return derived();
672
- }
673
-
674
- /** \returns a random unit quaternion following a uniform distribution law on SO(3)
675
- *
676
- * \note The implementation is based on http://planning.cs.uiuc.edu/node198.html
677
- */
678
- template<typename Scalar, int Options>
679
- EIGEN_DEVICE_FUNC Quaternion<Scalar,Options> Quaternion<Scalar,Options>::UnitRandom()
680
- {
681
- EIGEN_USING_STD(sqrt)
682
- EIGEN_USING_STD(sin)
683
- EIGEN_USING_STD(cos)
684
- const Scalar u1 = internal::random<Scalar>(0, 1),
685
- u2 = internal::random<Scalar>(0, 2*EIGEN_PI),
686
- u3 = internal::random<Scalar>(0, 2*EIGEN_PI);
687
- const Scalar a = sqrt(Scalar(1) - u1),
688
- b = sqrt(u1);
689
- return Quaternion (a * sin(u2), a * cos(u2), b * sin(u3), b * cos(u3));
690
- }
691
-
692
-
693
- /** Returns a quaternion representing a rotation between
694
- * the two arbitrary vectors \a a and \a b. In other words, the built
695
- * rotation represent a rotation sending the line of direction \a a
696
- * to the line of direction \a b, both lines passing through the origin.
697
- *
698
- * \returns resulting quaternion
699
- *
700
- * Note that the two input vectors do \b not have to be normalized, and
701
- * do not need to have the same norm.
702
- */
703
- template<typename Scalar, int Options>
704
- template<typename Derived1, typename Derived2>
705
- EIGEN_DEVICE_FUNC Quaternion<Scalar,Options> Quaternion<Scalar,Options>::FromTwoVectors(const MatrixBase<Derived1>& a, const MatrixBase<Derived2>& b)
706
- {
707
- Quaternion quat;
708
- quat.setFromTwoVectors(a, b);
709
- return quat;
710
- }
711
-
712
-
713
- /** \returns the multiplicative inverse of \c *this
714
- * Note that in most cases, i.e., if you simply want the opposite rotation,
715
- * and/or the quaternion is normalized, then it is enough to use the conjugate.
716
- *
717
- * \sa QuaternionBase::conjugate()
718
- */
719
- template <class Derived>
720
- EIGEN_DEVICE_FUNC inline Quaternion<typename internal::traits<Derived>::Scalar> QuaternionBase<Derived>::inverse() const
721
- {
722
- // FIXME should this function be called multiplicativeInverse and conjugate() be called inverse() or opposite() ??
723
- Scalar n2 = this->squaredNorm();
724
- if (n2 > Scalar(0))
725
- return Quaternion<Scalar>(conjugate().coeffs() / n2);
726
- else
727
- {
728
- // return an invalid result to flag the error
729
- return Quaternion<Scalar>(Coefficients::Zero());
730
- }
731
- }
732
-
733
- // Generic conjugate of a Quaternion
734
- namespace internal {
735
- template<int Arch, class Derived, typename Scalar> struct quat_conj
736
- {
737
- EIGEN_DEVICE_FUNC static EIGEN_STRONG_INLINE Quaternion<Scalar> run(const QuaternionBase<Derived>& q){
738
- return Quaternion<Scalar>(q.w(),-q.x(),-q.y(),-q.z());
739
- }
740
- };
741
- }
742
-
743
- /** \returns the conjugate of the \c *this which is equal to the multiplicative inverse
744
- * if the quaternion is normalized.
745
- * The conjugate of a quaternion represents the opposite rotation.
746
- *
747
- * \sa Quaternion2::inverse()
748
- */
749
- template <class Derived>
750
- EIGEN_DEVICE_FUNC inline Quaternion<typename internal::traits<Derived>::Scalar>
751
- QuaternionBase<Derived>::conjugate() const
752
- {
753
- return internal::quat_conj<Architecture::Target, Derived,
754
- typename internal::traits<Derived>::Scalar>::run(*this);
755
-
756
- }
757
-
758
- /** \returns the angle (in radian) between two rotations
759
- * \sa dot()
760
- */
761
- template <class Derived>
762
- template <class OtherDerived>
763
- EIGEN_DEVICE_FUNC inline typename internal::traits<Derived>::Scalar
764
- QuaternionBase<Derived>::angularDistance(const QuaternionBase<OtherDerived>& other) const
765
- {
766
- EIGEN_USING_STD(atan2)
767
- Quaternion<Scalar> d = (*this) * other.conjugate();
768
- return Scalar(2) * atan2( d.vec().norm(), numext::abs(d.w()) );
769
- }
770
-
771
-
772
-
773
- /** \returns the spherical linear interpolation between the two quaternions
774
- * \c *this and \a other at the parameter \a t in [0;1].
775
- *
776
- * This represents an interpolation for a constant motion between \c *this and \a other,
777
- * see also http://en.wikipedia.org/wiki/Slerp.
778
- */
779
- template <class Derived>
780
- template <class OtherDerived>
781
- EIGEN_DEVICE_FUNC Quaternion<typename internal::traits<Derived>::Scalar>
782
- QuaternionBase<Derived>::slerp(const Scalar& t, const QuaternionBase<OtherDerived>& other) const
783
- {
784
- EIGEN_USING_STD(acos)
785
- EIGEN_USING_STD(sin)
786
- const Scalar one = Scalar(1) - NumTraits<Scalar>::epsilon();
787
- Scalar d = this->dot(other);
788
- Scalar absD = numext::abs(d);
789
-
790
- Scalar scale0;
791
- Scalar scale1;
792
-
793
- if(absD>=one)
794
- {
795
- scale0 = Scalar(1) - t;
796
- scale1 = t;
797
- }
798
- else
799
- {
800
- // theta is the angle between the 2 quaternions
801
- Scalar theta = acos(absD);
802
- Scalar sinTheta = sin(theta);
803
-
804
- scale0 = sin( ( Scalar(1) - t ) * theta) / sinTheta;
805
- scale1 = sin( ( t * theta) ) / sinTheta;
806
- }
807
- if(d<Scalar(0)) scale1 = -scale1;
808
-
809
- return Quaternion<Scalar>(scale0 * coeffs() + scale1 * other.coeffs());
810
- }
811
-
812
- namespace internal {
813
-
814
- // set from a rotation matrix
815
- template<typename Other>
816
- struct quaternionbase_assign_impl<Other,3,3>
817
- {
818
- typedef typename Other::Scalar Scalar;
819
- template<class Derived> EIGEN_DEVICE_FUNC static inline void run(QuaternionBase<Derived>& q, const Other& a_mat)
820
- {
821
- const typename internal::nested_eval<Other,2>::type mat(a_mat);
822
- EIGEN_USING_STD(sqrt)
823
- // This algorithm comes from "Quaternion Calculus and Fast Animation",
824
- // Ken Shoemake, 1987 SIGGRAPH course notes
825
- Scalar t = mat.trace();
826
- if (t > Scalar(0))
827
- {
828
- t = sqrt(t + Scalar(1.0));
829
- q.w() = Scalar(0.5)*t;
830
- t = Scalar(0.5)/t;
831
- q.x() = (mat.coeff(2,1) - mat.coeff(1,2)) * t;
832
- q.y() = (mat.coeff(0,2) - mat.coeff(2,0)) * t;
833
- q.z() = (mat.coeff(1,0) - mat.coeff(0,1)) * t;
834
- }
835
- else
836
- {
837
- Index i = 0;
838
- if (mat.coeff(1,1) > mat.coeff(0,0))
839
- i = 1;
840
- if (mat.coeff(2,2) > mat.coeff(i,i))
841
- i = 2;
842
- Index j = (i+1)%3;
843
- Index k = (j+1)%3;
844
-
845
- t = sqrt(mat.coeff(i,i)-mat.coeff(j,j)-mat.coeff(k,k) + Scalar(1.0));
846
- q.coeffs().coeffRef(i) = Scalar(0.5) * t;
847
- t = Scalar(0.5)/t;
848
- q.w() = (mat.coeff(k,j)-mat.coeff(j,k))*t;
849
- q.coeffs().coeffRef(j) = (mat.coeff(j,i)+mat.coeff(i,j))*t;
850
- q.coeffs().coeffRef(k) = (mat.coeff(k,i)+mat.coeff(i,k))*t;
851
- }
852
- }
853
- };
854
-
855
- // set from a vector of coefficients assumed to be a quaternion
856
- template<typename Other>
857
- struct quaternionbase_assign_impl<Other,4,1>
858
- {
859
- typedef typename Other::Scalar Scalar;
860
- template<class Derived> EIGEN_DEVICE_FUNC static inline void run(QuaternionBase<Derived>& q, const Other& vec)
861
- {
862
- q.coeffs() = vec;
863
- }
864
- };
865
-
866
- } // end namespace internal
867
-
868
- } // end namespace Eigen
869
-
870
- #endif // EIGEN_QUATERNION_H