xtgeo 4.10.0__cp313-cp313-macosx_11_0_arm64.whl → 4.10.1__cp313-cp313-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-313-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,1163 +0,0 @@
1
- // This file is part of Eigen, a lightweight C++ template library
2
- // for linear algebra.
3
- //
4
- // Copyright (C) 2008-2015 Gael Guennebaud <gael.guennebaud@inria.fr>
5
- // Copyright (C) 2008-2009 Benoit Jacob <jacob.benoit.1@gmail.com>
6
- // Copyright (C) 2009 Kenneth Riddile <kfriddile@yahoo.com>
7
- // Copyright (C) 2010 Hauke Heibel <hauke.heibel@gmail.com>
8
- // Copyright (C) 2010 Thomas Capricelli <orzel@freehackers.org>
9
- // Copyright (C) 2013 Pavel Holoborodko <pavel@holoborodko.com>
10
- //
11
- // This Source Code Form is subject to the terms of the Mozilla
12
- // Public License v. 2.0. If a copy of the MPL was not distributed
13
- // with this file, You can obtain one at http://mozilla.org/MPL/2.0/.
14
-
15
-
16
- /*****************************************************************************
17
- *** Platform checks for aligned malloc functions ***
18
- *****************************************************************************/
19
-
20
- #ifndef EIGEN_MEMORY_H
21
- #define EIGEN_MEMORY_H
22
-
23
- #ifndef EIGEN_MALLOC_ALREADY_ALIGNED
24
-
25
- // Try to determine automatically if malloc is already aligned.
26
-
27
- // On 64-bit systems, glibc's malloc returns 16-byte-aligned pointers, see:
28
- // http://www.gnu.org/s/libc/manual/html_node/Aligned-Memory-Blocks.html
29
- // This is true at least since glibc 2.8.
30
- // This leaves the question how to detect 64-bit. According to this document,
31
- // http://gcc.fyxm.net/summit/2003/Porting%20to%2064%20bit.pdf
32
- // page 114, "[The] LP64 model [...] is used by all 64-bit UNIX ports" so it's indeed
33
- // quite safe, at least within the context of glibc, to equate 64-bit with LP64.
34
- #if defined(__GLIBC__) && ((__GLIBC__>=2 && __GLIBC_MINOR__ >= 8) || __GLIBC__>2) \
35
- && defined(__LP64__) && ! defined( __SANITIZE_ADDRESS__ ) && (EIGEN_DEFAULT_ALIGN_BYTES == 16)
36
- #define EIGEN_GLIBC_MALLOC_ALREADY_ALIGNED 1
37
- #else
38
- #define EIGEN_GLIBC_MALLOC_ALREADY_ALIGNED 0
39
- #endif
40
-
41
- // FreeBSD 6 seems to have 16-byte aligned malloc
42
- // See http://svn.freebsd.org/viewvc/base/stable/6/lib/libc/stdlib/malloc.c?view=markup
43
- // FreeBSD 7 seems to have 16-byte aligned malloc except on ARM and MIPS architectures
44
- // See http://svn.freebsd.org/viewvc/base/stable/7/lib/libc/stdlib/malloc.c?view=markup
45
- #if defined(__FreeBSD__) && !(EIGEN_ARCH_ARM || EIGEN_ARCH_MIPS) && (EIGEN_DEFAULT_ALIGN_BYTES == 16)
46
- #define EIGEN_FREEBSD_MALLOC_ALREADY_ALIGNED 1
47
- #else
48
- #define EIGEN_FREEBSD_MALLOC_ALREADY_ALIGNED 0
49
- #endif
50
-
51
- #if (EIGEN_OS_MAC && (EIGEN_DEFAULT_ALIGN_BYTES == 16)) \
52
- || (EIGEN_OS_WIN64 && (EIGEN_DEFAULT_ALIGN_BYTES == 16)) \
53
- || EIGEN_GLIBC_MALLOC_ALREADY_ALIGNED \
54
- || EIGEN_FREEBSD_MALLOC_ALREADY_ALIGNED
55
- #define EIGEN_MALLOC_ALREADY_ALIGNED 1
56
- #else
57
- #define EIGEN_MALLOC_ALREADY_ALIGNED 0
58
- #endif
59
-
60
- #endif
61
-
62
- namespace Eigen {
63
-
64
- namespace internal {
65
-
66
- EIGEN_DEVICE_FUNC
67
- inline void throw_std_bad_alloc()
68
- {
69
- #ifdef EIGEN_EXCEPTIONS
70
- throw std::bad_alloc();
71
- #else
72
- std::size_t huge = static_cast<std::size_t>(-1);
73
- #if defined(EIGEN_HIPCC)
74
- //
75
- // calls to "::operator new" are to be treated as opaque function calls (i.e no inlining),
76
- // and as a consequence the code in the #else block triggers the hipcc warning :
77
- // "no overloaded function has restriction specifiers that are compatible with the ambient context"
78
- //
79
- // "throw_std_bad_alloc" has the EIGEN_DEVICE_FUNC attribute, so it seems that hipcc expects
80
- // the same on "operator new"
81
- // Reverting code back to the old version in this #if block for the hipcc compiler
82
- //
83
- new int[huge];
84
- #else
85
- void* unused = ::operator new(huge);
86
- EIGEN_UNUSED_VARIABLE(unused);
87
- #endif
88
- #endif
89
- }
90
-
91
- /*****************************************************************************
92
- *** Implementation of handmade aligned functions ***
93
- *****************************************************************************/
94
-
95
- /* ----- Hand made implementations of aligned malloc/free and realloc ----- */
96
-
97
- /** \internal Like malloc, but the returned pointer is guaranteed to be 16-byte aligned.
98
- * Fast, but wastes 16 additional bytes of memory. Does not throw any exception.
99
- */
100
- EIGEN_DEVICE_FUNC inline void* handmade_aligned_malloc(std::size_t size, std::size_t alignment = EIGEN_DEFAULT_ALIGN_BYTES)
101
- {
102
- eigen_assert(alignment >= sizeof(void*) && (alignment & (alignment-1)) == 0 && "Alignment must be at least sizeof(void*) and a power of 2");
103
-
104
- EIGEN_USING_STD(malloc)
105
- void *original = malloc(size+alignment);
106
-
107
- if (original == 0) return 0;
108
- void *aligned = reinterpret_cast<void*>((reinterpret_cast<std::size_t>(original) & ~(std::size_t(alignment-1))) + alignment);
109
- *(reinterpret_cast<void**>(aligned) - 1) = original;
110
- return aligned;
111
- }
112
-
113
- /** \internal Frees memory allocated with handmade_aligned_malloc */
114
- EIGEN_DEVICE_FUNC inline void handmade_aligned_free(void *ptr)
115
- {
116
- if (ptr) {
117
- EIGEN_USING_STD(free)
118
- free(*(reinterpret_cast<void**>(ptr) - 1));
119
- }
120
- }
121
-
122
- /** \internal
123
- * \brief Reallocates aligned memory.
124
- * Since we know that our handmade version is based on std::malloc
125
- * we can use std::realloc to implement efficient reallocation.
126
- */
127
- inline void* handmade_aligned_realloc(void* ptr, std::size_t size, std::size_t = 0)
128
- {
129
- if (ptr == 0) return handmade_aligned_malloc(size);
130
- void *original = *(reinterpret_cast<void**>(ptr) - 1);
131
- std::ptrdiff_t previous_offset = static_cast<char *>(ptr)-static_cast<char *>(original);
132
- original = std::realloc(original,size+EIGEN_DEFAULT_ALIGN_BYTES);
133
- if (original == 0) return 0;
134
- void *aligned = reinterpret_cast<void*>((reinterpret_cast<std::size_t>(original) & ~(std::size_t(EIGEN_DEFAULT_ALIGN_BYTES-1))) + EIGEN_DEFAULT_ALIGN_BYTES);
135
- void *previous_aligned = static_cast<char *>(original)+previous_offset;
136
- if(aligned!=previous_aligned)
137
- std::memmove(aligned, previous_aligned, size);
138
-
139
- *(reinterpret_cast<void**>(aligned) - 1) = original;
140
- return aligned;
141
- }
142
-
143
- /*****************************************************************************
144
- *** Implementation of portable aligned versions of malloc/free/realloc ***
145
- *****************************************************************************/
146
-
147
- #ifdef EIGEN_NO_MALLOC
148
- EIGEN_DEVICE_FUNC inline void check_that_malloc_is_allowed()
149
- {
150
- eigen_assert(false && "heap allocation is forbidden (EIGEN_NO_MALLOC is defined)");
151
- }
152
- #elif defined EIGEN_RUNTIME_NO_MALLOC
153
- EIGEN_DEVICE_FUNC inline bool is_malloc_allowed_impl(bool update, bool new_value = false)
154
- {
155
- static bool value = true;
156
- if (update == 1)
157
- value = new_value;
158
- return value;
159
- }
160
- EIGEN_DEVICE_FUNC inline bool is_malloc_allowed() { return is_malloc_allowed_impl(false); }
161
- EIGEN_DEVICE_FUNC inline bool set_is_malloc_allowed(bool new_value) { return is_malloc_allowed_impl(true, new_value); }
162
- EIGEN_DEVICE_FUNC inline void check_that_malloc_is_allowed()
163
- {
164
- eigen_assert(is_malloc_allowed() && "heap allocation is forbidden (EIGEN_RUNTIME_NO_MALLOC is defined and g_is_malloc_allowed is false)");
165
- }
166
- #else
167
- EIGEN_DEVICE_FUNC inline void check_that_malloc_is_allowed()
168
- {}
169
- #endif
170
-
171
- /** \internal Allocates \a size bytes. The returned pointer is guaranteed to have 16 or 32 bytes alignment depending on the requirements.
172
- * On allocation error, the returned pointer is null, and std::bad_alloc is thrown.
173
- */
174
- EIGEN_DEVICE_FUNC inline void* aligned_malloc(std::size_t size)
175
- {
176
- check_that_malloc_is_allowed();
177
-
178
- void *result;
179
- #if (EIGEN_DEFAULT_ALIGN_BYTES==0) || EIGEN_MALLOC_ALREADY_ALIGNED
180
-
181
- EIGEN_USING_STD(malloc)
182
- result = malloc(size);
183
-
184
- #if EIGEN_DEFAULT_ALIGN_BYTES==16
185
- eigen_assert((size<16 || (std::size_t(result)%16)==0) && "System's malloc returned an unaligned pointer. Compile with EIGEN_MALLOC_ALREADY_ALIGNED=0 to fallback to handmade aligned memory allocator.");
186
- #endif
187
- #else
188
- result = handmade_aligned_malloc(size);
189
- #endif
190
-
191
- if(!result && size)
192
- throw_std_bad_alloc();
193
-
194
- return result;
195
- }
196
-
197
- /** \internal Frees memory allocated with aligned_malloc. */
198
- EIGEN_DEVICE_FUNC inline void aligned_free(void *ptr)
199
- {
200
- #if (EIGEN_DEFAULT_ALIGN_BYTES==0) || EIGEN_MALLOC_ALREADY_ALIGNED
201
-
202
- EIGEN_USING_STD(free)
203
- free(ptr);
204
-
205
- #else
206
- handmade_aligned_free(ptr);
207
- #endif
208
- }
209
-
210
- /**
211
- * \internal
212
- * \brief Reallocates an aligned block of memory.
213
- * \throws std::bad_alloc on allocation failure
214
- */
215
- inline void* aligned_realloc(void *ptr, std::size_t new_size, std::size_t old_size)
216
- {
217
- EIGEN_UNUSED_VARIABLE(old_size)
218
-
219
- void *result;
220
- #if (EIGEN_DEFAULT_ALIGN_BYTES==0) || EIGEN_MALLOC_ALREADY_ALIGNED
221
- result = std::realloc(ptr,new_size);
222
- #else
223
- result = handmade_aligned_realloc(ptr,new_size,old_size);
224
- #endif
225
-
226
- if (!result && new_size)
227
- throw_std_bad_alloc();
228
-
229
- return result;
230
- }
231
-
232
- /*****************************************************************************
233
- *** Implementation of conditionally aligned functions ***
234
- *****************************************************************************/
235
-
236
- /** \internal Allocates \a size bytes. If Align is true, then the returned ptr is 16-byte-aligned.
237
- * On allocation error, the returned pointer is null, and a std::bad_alloc is thrown.
238
- */
239
- template<bool Align> EIGEN_DEVICE_FUNC inline void* conditional_aligned_malloc(std::size_t size)
240
- {
241
- return aligned_malloc(size);
242
- }
243
-
244
- template<> EIGEN_DEVICE_FUNC inline void* conditional_aligned_malloc<false>(std::size_t size)
245
- {
246
- check_that_malloc_is_allowed();
247
-
248
- EIGEN_USING_STD(malloc)
249
- void *result = malloc(size);
250
-
251
- if(!result && size)
252
- throw_std_bad_alloc();
253
- return result;
254
- }
255
-
256
- /** \internal Frees memory allocated with conditional_aligned_malloc */
257
- template<bool Align> EIGEN_DEVICE_FUNC inline void conditional_aligned_free(void *ptr)
258
- {
259
- aligned_free(ptr);
260
- }
261
-
262
- template<> EIGEN_DEVICE_FUNC inline void conditional_aligned_free<false>(void *ptr)
263
- {
264
- EIGEN_USING_STD(free)
265
- free(ptr);
266
- }
267
-
268
- template<bool Align> inline void* conditional_aligned_realloc(void* ptr, std::size_t new_size, std::size_t old_size)
269
- {
270
- return aligned_realloc(ptr, new_size, old_size);
271
- }
272
-
273
- template<> inline void* conditional_aligned_realloc<false>(void* ptr, std::size_t new_size, std::size_t)
274
- {
275
- return std::realloc(ptr, new_size);
276
- }
277
-
278
- /*****************************************************************************
279
- *** Construction/destruction of array elements ***
280
- *****************************************************************************/
281
-
282
- /** \internal Destructs the elements of an array.
283
- * The \a size parameters tells on how many objects to call the destructor of T.
284
- */
285
- template<typename T> EIGEN_DEVICE_FUNC inline void destruct_elements_of_array(T *ptr, std::size_t size)
286
- {
287
- // always destruct an array starting from the end.
288
- if(ptr)
289
- while(size) ptr[--size].~T();
290
- }
291
-
292
- /** \internal Constructs the elements of an array.
293
- * The \a size parameter tells on how many objects to call the constructor of T.
294
- */
295
- template<typename T> EIGEN_DEVICE_FUNC inline T* construct_elements_of_array(T *ptr, std::size_t size)
296
- {
297
- std::size_t i;
298
- EIGEN_TRY
299
- {
300
- for (i = 0; i < size; ++i) ::new (ptr + i) T;
301
- return ptr;
302
- }
303
- EIGEN_CATCH(...)
304
- {
305
- destruct_elements_of_array(ptr, i);
306
- EIGEN_THROW;
307
- }
308
- return NULL;
309
- }
310
-
311
- /*****************************************************************************
312
- *** Implementation of aligned new/delete-like functions ***
313
- *****************************************************************************/
314
-
315
- template<typename T>
316
- EIGEN_DEVICE_FUNC EIGEN_ALWAYS_INLINE void check_size_for_overflow(std::size_t size)
317
- {
318
- if(size > std::size_t(-1) / sizeof(T))
319
- throw_std_bad_alloc();
320
- }
321
-
322
- /** \internal Allocates \a size objects of type T. The returned pointer is guaranteed to have 16 bytes alignment.
323
- * On allocation error, the returned pointer is undefined, but a std::bad_alloc is thrown.
324
- * The default constructor of T is called.
325
- */
326
- template<typename T> EIGEN_DEVICE_FUNC inline T* aligned_new(std::size_t size)
327
- {
328
- check_size_for_overflow<T>(size);
329
- T *result = reinterpret_cast<T*>(aligned_malloc(sizeof(T)*size));
330
- EIGEN_TRY
331
- {
332
- return construct_elements_of_array(result, size);
333
- }
334
- EIGEN_CATCH(...)
335
- {
336
- aligned_free(result);
337
- EIGEN_THROW;
338
- }
339
- return result;
340
- }
341
-
342
- template<typename T, bool Align> EIGEN_DEVICE_FUNC inline T* conditional_aligned_new(std::size_t size)
343
- {
344
- check_size_for_overflow<T>(size);
345
- T *result = reinterpret_cast<T*>(conditional_aligned_malloc<Align>(sizeof(T)*size));
346
- EIGEN_TRY
347
- {
348
- return construct_elements_of_array(result, size);
349
- }
350
- EIGEN_CATCH(...)
351
- {
352
- conditional_aligned_free<Align>(result);
353
- EIGEN_THROW;
354
- }
355
- return result;
356
- }
357
-
358
- /** \internal Deletes objects constructed with aligned_new
359
- * The \a size parameters tells on how many objects to call the destructor of T.
360
- */
361
- template<typename T> EIGEN_DEVICE_FUNC inline void aligned_delete(T *ptr, std::size_t size)
362
- {
363
- destruct_elements_of_array<T>(ptr, size);
364
- Eigen::internal::aligned_free(ptr);
365
- }
366
-
367
- /** \internal Deletes objects constructed with conditional_aligned_new
368
- * The \a size parameters tells on how many objects to call the destructor of T.
369
- */
370
- template<typename T, bool Align> EIGEN_DEVICE_FUNC inline void conditional_aligned_delete(T *ptr, std::size_t size)
371
- {
372
- destruct_elements_of_array<T>(ptr, size);
373
- conditional_aligned_free<Align>(ptr);
374
- }
375
-
376
- template<typename T, bool Align> EIGEN_DEVICE_FUNC inline T* conditional_aligned_realloc_new(T* pts, std::size_t new_size, std::size_t old_size)
377
- {
378
- check_size_for_overflow<T>(new_size);
379
- check_size_for_overflow<T>(old_size);
380
- if(new_size < old_size)
381
- destruct_elements_of_array(pts+new_size, old_size-new_size);
382
- T *result = reinterpret_cast<T*>(conditional_aligned_realloc<Align>(reinterpret_cast<void*>(pts), sizeof(T)*new_size, sizeof(T)*old_size));
383
- if(new_size > old_size)
384
- {
385
- EIGEN_TRY
386
- {
387
- construct_elements_of_array(result+old_size, new_size-old_size);
388
- }
389
- EIGEN_CATCH(...)
390
- {
391
- conditional_aligned_free<Align>(result);
392
- EIGEN_THROW;
393
- }
394
- }
395
- return result;
396
- }
397
-
398
-
399
- template<typename T, bool Align> EIGEN_DEVICE_FUNC inline T* conditional_aligned_new_auto(std::size_t size)
400
- {
401
- if(size==0)
402
- return 0; // short-cut. Also fixes Bug 884
403
- check_size_for_overflow<T>(size);
404
- T *result = reinterpret_cast<T*>(conditional_aligned_malloc<Align>(sizeof(T)*size));
405
- if(NumTraits<T>::RequireInitialization)
406
- {
407
- EIGEN_TRY
408
- {
409
- construct_elements_of_array(result, size);
410
- }
411
- EIGEN_CATCH(...)
412
- {
413
- conditional_aligned_free<Align>(result);
414
- EIGEN_THROW;
415
- }
416
- }
417
- return result;
418
- }
419
-
420
- template<typename T, bool Align> inline T* conditional_aligned_realloc_new_auto(T* pts, std::size_t new_size, std::size_t old_size)
421
- {
422
- check_size_for_overflow<T>(new_size);
423
- check_size_for_overflow<T>(old_size);
424
- if(NumTraits<T>::RequireInitialization && (new_size < old_size))
425
- destruct_elements_of_array(pts+new_size, old_size-new_size);
426
- T *result = reinterpret_cast<T*>(conditional_aligned_realloc<Align>(reinterpret_cast<void*>(pts), sizeof(T)*new_size, sizeof(T)*old_size));
427
- if(NumTraits<T>::RequireInitialization && (new_size > old_size))
428
- {
429
- EIGEN_TRY
430
- {
431
- construct_elements_of_array(result+old_size, new_size-old_size);
432
- }
433
- EIGEN_CATCH(...)
434
- {
435
- conditional_aligned_free<Align>(result);
436
- EIGEN_THROW;
437
- }
438
- }
439
- return result;
440
- }
441
-
442
- template<typename T, bool Align> EIGEN_DEVICE_FUNC inline void conditional_aligned_delete_auto(T *ptr, std::size_t size)
443
- {
444
- if(NumTraits<T>::RequireInitialization)
445
- destruct_elements_of_array<T>(ptr, size);
446
- conditional_aligned_free<Align>(ptr);
447
- }
448
-
449
- /****************************************************************************/
450
-
451
- /** \internal Returns the index of the first element of the array that is well aligned with respect to the requested \a Alignment.
452
- *
453
- * \tparam Alignment requested alignment in Bytes.
454
- * \param array the address of the start of the array
455
- * \param size the size of the array
456
- *
457
- * \note If no element of the array is well aligned or the requested alignment is not a multiple of a scalar,
458
- * the size of the array is returned. For example with SSE, the requested alignment is typically 16-bytes. If
459
- * packet size for the given scalar type is 1, then everything is considered well-aligned.
460
- *
461
- * \note Otherwise, if the Alignment is larger that the scalar size, we rely on the assumptions that sizeof(Scalar) is a
462
- * power of 2. On the other hand, we do not assume that the array address is a multiple of sizeof(Scalar), as that fails for
463
- * example with Scalar=double on certain 32-bit platforms, see bug #79.
464
- *
465
- * There is also the variant first_aligned(const MatrixBase&) defined in DenseCoeffsBase.h.
466
- * \sa first_default_aligned()
467
- */
468
- template<int Alignment, typename Scalar, typename Index>
469
- EIGEN_DEVICE_FUNC inline Index first_aligned(const Scalar* array, Index size)
470
- {
471
- const Index ScalarSize = sizeof(Scalar);
472
- const Index AlignmentSize = Alignment / ScalarSize;
473
- const Index AlignmentMask = AlignmentSize-1;
474
-
475
- if(AlignmentSize<=1)
476
- {
477
- // Either the requested alignment if smaller than a scalar, or it exactly match a 1 scalar
478
- // so that all elements of the array have the same alignment.
479
- return 0;
480
- }
481
- else if( (UIntPtr(array) & (sizeof(Scalar)-1)) || (Alignment%ScalarSize)!=0)
482
- {
483
- // The array is not aligned to the size of a single scalar, or the requested alignment is not a multiple of the scalar size.
484
- // Consequently, no element of the array is well aligned.
485
- return size;
486
- }
487
- else
488
- {
489
- Index first = (AlignmentSize - (Index((UIntPtr(array)/sizeof(Scalar))) & AlignmentMask)) & AlignmentMask;
490
- return (first < size) ? first : size;
491
- }
492
- }
493
-
494
- /** \internal Returns the index of the first element of the array that is well aligned with respect the largest packet requirement.
495
- * \sa first_aligned(Scalar*,Index) and first_default_aligned(DenseBase<Derived>) */
496
- template<typename Scalar, typename Index>
497
- EIGEN_DEVICE_FUNC inline Index first_default_aligned(const Scalar* array, Index size)
498
- {
499
- typedef typename packet_traits<Scalar>::type DefaultPacketType;
500
- return first_aligned<unpacket_traits<DefaultPacketType>::alignment>(array, size);
501
- }
502
-
503
- /** \internal Returns the smallest integer multiple of \a base and greater or equal to \a size
504
- */
505
- template<typename Index>
506
- inline Index first_multiple(Index size, Index base)
507
- {
508
- return ((size+base-1)/base)*base;
509
- }
510
-
511
- // std::copy is much slower than memcpy, so let's introduce a smart_copy which
512
- // use memcpy on trivial types, i.e., on types that does not require an initialization ctor.
513
- template<typename T, bool UseMemcpy> struct smart_copy_helper;
514
-
515
- template<typename T> EIGEN_DEVICE_FUNC void smart_copy(const T* start, const T* end, T* target)
516
- {
517
- smart_copy_helper<T,!NumTraits<T>::RequireInitialization>::run(start, end, target);
518
- }
519
-
520
- template<typename T> struct smart_copy_helper<T,true> {
521
- EIGEN_DEVICE_FUNC static inline void run(const T* start, const T* end, T* target)
522
- {
523
- IntPtr size = IntPtr(end)-IntPtr(start);
524
- if(size==0) return;
525
- eigen_internal_assert(start!=0 && end!=0 && target!=0);
526
- EIGEN_USING_STD(memcpy)
527
- memcpy(target, start, size);
528
- }
529
- };
530
-
531
- template<typename T> struct smart_copy_helper<T,false> {
532
- EIGEN_DEVICE_FUNC static inline void run(const T* start, const T* end, T* target)
533
- { std::copy(start, end, target); }
534
- };
535
-
536
- // intelligent memmove. falls back to std::memmove for POD types, uses std::copy otherwise.
537
- template<typename T, bool UseMemmove> struct smart_memmove_helper;
538
-
539
- template<typename T> void smart_memmove(const T* start, const T* end, T* target)
540
- {
541
- smart_memmove_helper<T,!NumTraits<T>::RequireInitialization>::run(start, end, target);
542
- }
543
-
544
- template<typename T> struct smart_memmove_helper<T,true> {
545
- static inline void run(const T* start, const T* end, T* target)
546
- {
547
- IntPtr size = IntPtr(end)-IntPtr(start);
548
- if(size==0) return;
549
- eigen_internal_assert(start!=0 && end!=0 && target!=0);
550
- std::memmove(target, start, size);
551
- }
552
- };
553
-
554
- template<typename T> struct smart_memmove_helper<T,false> {
555
- static inline void run(const T* start, const T* end, T* target)
556
- {
557
- if (UIntPtr(target) < UIntPtr(start))
558
- {
559
- std::copy(start, end, target);
560
- }
561
- else
562
- {
563
- std::ptrdiff_t count = (std::ptrdiff_t(end)-std::ptrdiff_t(start)) / sizeof(T);
564
- std::copy_backward(start, end, target + count);
565
- }
566
- }
567
- };
568
-
569
- #if EIGEN_HAS_RVALUE_REFERENCES
570
- template<typename T> EIGEN_DEVICE_FUNC T* smart_move(T* start, T* end, T* target)
571
- {
572
- return std::move(start, end, target);
573
- }
574
- #else
575
- template<typename T> EIGEN_DEVICE_FUNC T* smart_move(T* start, T* end, T* target)
576
- {
577
- return std::copy(start, end, target);
578
- }
579
- #endif
580
-
581
- /*****************************************************************************
582
- *** Implementation of runtime stack allocation (falling back to malloc) ***
583
- *****************************************************************************/
584
-
585
- // you can overwrite Eigen's default behavior regarding alloca by defining EIGEN_ALLOCA
586
- // to the appropriate stack allocation function
587
- #if ! defined EIGEN_ALLOCA && ! defined EIGEN_GPU_COMPILE_PHASE
588
- #if EIGEN_OS_LINUX || EIGEN_OS_MAC || (defined alloca)
589
- #define EIGEN_ALLOCA alloca
590
- #elif EIGEN_COMP_MSVC
591
- #define EIGEN_ALLOCA _alloca
592
- #endif
593
- #endif
594
-
595
- // With clang -Oz -mthumb, alloca changes the stack pointer in a way that is
596
- // not allowed in Thumb2. -DEIGEN_STACK_ALLOCATION_LIMIT=0 doesn't work because
597
- // the compiler still emits bad code because stack allocation checks use "<=".
598
- // TODO: Eliminate after https://bugs.llvm.org/show_bug.cgi?id=23772
599
- // is fixed.
600
- #if defined(__clang__) && defined(__thumb__)
601
- #undef EIGEN_ALLOCA
602
- #endif
603
-
604
- // This helper class construct the allocated memory, and takes care of destructing and freeing the handled data
605
- // at destruction time. In practice this helper class is mainly useful to avoid memory leak in case of exceptions.
606
- template<typename T> class aligned_stack_memory_handler : noncopyable
607
- {
608
- public:
609
- /* Creates a stack_memory_handler responsible for the buffer \a ptr of size \a size.
610
- * Note that \a ptr can be 0 regardless of the other parameters.
611
- * This constructor takes care of constructing/initializing the elements of the buffer if required by the scalar type T (see NumTraits<T>::RequireInitialization).
612
- * In this case, the buffer elements will also be destructed when this handler will be destructed.
613
- * Finally, if \a dealloc is true, then the pointer \a ptr is freed.
614
- **/
615
- EIGEN_DEVICE_FUNC
616
- aligned_stack_memory_handler(T* ptr, std::size_t size, bool dealloc)
617
- : m_ptr(ptr), m_size(size), m_deallocate(dealloc)
618
- {
619
- if(NumTraits<T>::RequireInitialization && m_ptr)
620
- Eigen::internal::construct_elements_of_array(m_ptr, size);
621
- }
622
- EIGEN_DEVICE_FUNC
623
- ~aligned_stack_memory_handler()
624
- {
625
- if(NumTraits<T>::RequireInitialization && m_ptr)
626
- Eigen::internal::destruct_elements_of_array<T>(m_ptr, m_size);
627
- if(m_deallocate)
628
- Eigen::internal::aligned_free(m_ptr);
629
- }
630
- protected:
631
- T* m_ptr;
632
- std::size_t m_size;
633
- bool m_deallocate;
634
- };
635
-
636
- #ifdef EIGEN_ALLOCA
637
-
638
- template<typename Xpr, int NbEvaluations,
639
- bool MapExternalBuffer = nested_eval<Xpr,NbEvaluations>::Evaluate && Xpr::MaxSizeAtCompileTime==Dynamic
640
- >
641
- struct local_nested_eval_wrapper
642
- {
643
- static const bool NeedExternalBuffer = false;
644
- typedef typename Xpr::Scalar Scalar;
645
- typedef typename nested_eval<Xpr,NbEvaluations>::type ObjectType;
646
- ObjectType object;
647
-
648
- EIGEN_DEVICE_FUNC
649
- local_nested_eval_wrapper(const Xpr& xpr, Scalar* ptr) : object(xpr)
650
- {
651
- EIGEN_UNUSED_VARIABLE(ptr);
652
- eigen_internal_assert(ptr==0);
653
- }
654
- };
655
-
656
- template<typename Xpr, int NbEvaluations>
657
- struct local_nested_eval_wrapper<Xpr,NbEvaluations,true>
658
- {
659
- static const bool NeedExternalBuffer = true;
660
- typedef typename Xpr::Scalar Scalar;
661
- typedef typename plain_object_eval<Xpr>::type PlainObject;
662
- typedef Map<PlainObject,EIGEN_DEFAULT_ALIGN_BYTES> ObjectType;
663
- ObjectType object;
664
-
665
- EIGEN_DEVICE_FUNC
666
- local_nested_eval_wrapper(const Xpr& xpr, Scalar* ptr)
667
- : object(ptr==0 ? reinterpret_cast<Scalar*>(Eigen::internal::aligned_malloc(sizeof(Scalar)*xpr.size())) : ptr, xpr.rows(), xpr.cols()),
668
- m_deallocate(ptr==0)
669
- {
670
- if(NumTraits<Scalar>::RequireInitialization && object.data())
671
- Eigen::internal::construct_elements_of_array(object.data(), object.size());
672
- object = xpr;
673
- }
674
-
675
- EIGEN_DEVICE_FUNC
676
- ~local_nested_eval_wrapper()
677
- {
678
- if(NumTraits<Scalar>::RequireInitialization && object.data())
679
- Eigen::internal::destruct_elements_of_array(object.data(), object.size());
680
- if(m_deallocate)
681
- Eigen::internal::aligned_free(object.data());
682
- }
683
-
684
- private:
685
- bool m_deallocate;
686
- };
687
-
688
- #endif // EIGEN_ALLOCA
689
-
690
- template<typename T> class scoped_array : noncopyable
691
- {
692
- T* m_ptr;
693
- public:
694
- explicit scoped_array(std::ptrdiff_t size)
695
- {
696
- m_ptr = new T[size];
697
- }
698
- ~scoped_array()
699
- {
700
- delete[] m_ptr;
701
- }
702
- T& operator[](std::ptrdiff_t i) { return m_ptr[i]; }
703
- const T& operator[](std::ptrdiff_t i) const { return m_ptr[i]; }
704
- T* &ptr() { return m_ptr; }
705
- const T* ptr() const { return m_ptr; }
706
- operator const T*() const { return m_ptr; }
707
- };
708
-
709
- template<typename T> void swap(scoped_array<T> &a,scoped_array<T> &b)
710
- {
711
- std::swap(a.ptr(),b.ptr());
712
- }
713
-
714
- } // end namespace internal
715
-
716
- /** \internal
717
- *
718
- * The macro ei_declare_aligned_stack_constructed_variable(TYPE,NAME,SIZE,BUFFER) declares, allocates,
719
- * and construct an aligned buffer named NAME of SIZE elements of type TYPE on the stack
720
- * if the size in bytes is smaller than EIGEN_STACK_ALLOCATION_LIMIT, and if stack allocation is supported by the platform
721
- * (currently, this is Linux, OSX and Visual Studio only). Otherwise the memory is allocated on the heap.
722
- * The allocated buffer is automatically deleted when exiting the scope of this declaration.
723
- * If BUFFER is non null, then the declared variable is simply an alias for BUFFER, and no allocation/deletion occurs.
724
- * Here is an example:
725
- * \code
726
- * {
727
- * ei_declare_aligned_stack_constructed_variable(float,data,size,0);
728
- * // use data[0] to data[size-1]
729
- * }
730
- * \endcode
731
- * The underlying stack allocation function can controlled with the EIGEN_ALLOCA preprocessor token.
732
- *
733
- * The macro ei_declare_local_nested_eval(XPR_T,XPR,N,NAME) is analogue to
734
- * \code
735
- * typename internal::nested_eval<XPRT_T,N>::type NAME(XPR);
736
- * \endcode
737
- * with the advantage of using aligned stack allocation even if the maximal size of XPR at compile time is unknown.
738
- * This is accomplished through alloca if this later is supported and if the required number of bytes
739
- * is below EIGEN_STACK_ALLOCATION_LIMIT.
740
- */
741
- #ifdef EIGEN_ALLOCA
742
-
743
- #if EIGEN_DEFAULT_ALIGN_BYTES>0
744
- // We always manually re-align the result of EIGEN_ALLOCA.
745
- // If alloca is already aligned, the compiler should be smart enough to optimize away the re-alignment.
746
- #define EIGEN_ALIGNED_ALLOCA(SIZE) reinterpret_cast<void*>((internal::UIntPtr(EIGEN_ALLOCA(SIZE+EIGEN_DEFAULT_ALIGN_BYTES-1)) + EIGEN_DEFAULT_ALIGN_BYTES-1) & ~(std::size_t(EIGEN_DEFAULT_ALIGN_BYTES-1)))
747
- #else
748
- #define EIGEN_ALIGNED_ALLOCA(SIZE) EIGEN_ALLOCA(SIZE)
749
- #endif
750
-
751
- #define ei_declare_aligned_stack_constructed_variable(TYPE,NAME,SIZE,BUFFER) \
752
- Eigen::internal::check_size_for_overflow<TYPE>(SIZE); \
753
- TYPE* NAME = (BUFFER)!=0 ? (BUFFER) \
754
- : reinterpret_cast<TYPE*>( \
755
- (sizeof(TYPE)*SIZE<=EIGEN_STACK_ALLOCATION_LIMIT) ? EIGEN_ALIGNED_ALLOCA(sizeof(TYPE)*SIZE) \
756
- : Eigen::internal::aligned_malloc(sizeof(TYPE)*SIZE) ); \
757
- Eigen::internal::aligned_stack_memory_handler<TYPE> EIGEN_CAT(NAME,_stack_memory_destructor)((BUFFER)==0 ? NAME : 0,SIZE,sizeof(TYPE)*SIZE>EIGEN_STACK_ALLOCATION_LIMIT)
758
-
759
-
760
- #define ei_declare_local_nested_eval(XPR_T,XPR,N,NAME) \
761
- Eigen::internal::local_nested_eval_wrapper<XPR_T,N> EIGEN_CAT(NAME,_wrapper)(XPR, reinterpret_cast<typename XPR_T::Scalar*>( \
762
- ( (Eigen::internal::local_nested_eval_wrapper<XPR_T,N>::NeedExternalBuffer) && ((sizeof(typename XPR_T::Scalar)*XPR.size())<=EIGEN_STACK_ALLOCATION_LIMIT) ) \
763
- ? EIGEN_ALIGNED_ALLOCA( sizeof(typename XPR_T::Scalar)*XPR.size() ) : 0 ) ) ; \
764
- typename Eigen::internal::local_nested_eval_wrapper<XPR_T,N>::ObjectType NAME(EIGEN_CAT(NAME,_wrapper).object)
765
-
766
- #else
767
-
768
- #define ei_declare_aligned_stack_constructed_variable(TYPE,NAME,SIZE,BUFFER) \
769
- Eigen::internal::check_size_for_overflow<TYPE>(SIZE); \
770
- TYPE* NAME = (BUFFER)!=0 ? BUFFER : reinterpret_cast<TYPE*>(Eigen::internal::aligned_malloc(sizeof(TYPE)*SIZE)); \
771
- Eigen::internal::aligned_stack_memory_handler<TYPE> EIGEN_CAT(NAME,_stack_memory_destructor)((BUFFER)==0 ? NAME : 0,SIZE,true)
772
-
773
-
774
- #define ei_declare_local_nested_eval(XPR_T,XPR,N,NAME) typename Eigen::internal::nested_eval<XPR_T,N>::type NAME(XPR)
775
-
776
- #endif
777
-
778
-
779
- /*****************************************************************************
780
- *** Implementation of EIGEN_MAKE_ALIGNED_OPERATOR_NEW [_IF] ***
781
- *****************************************************************************/
782
-
783
- #if EIGEN_HAS_CXX17_OVERALIGN
784
-
785
- // C++17 -> no need to bother about alignment anymore :)
786
-
787
- #define EIGEN_MAKE_ALIGNED_OPERATOR_NEW_NOTHROW(NeedsToAlign)
788
- #define EIGEN_MAKE_ALIGNED_OPERATOR_NEW_IF(NeedsToAlign)
789
- #define EIGEN_MAKE_ALIGNED_OPERATOR_NEW
790
- #define EIGEN_MAKE_ALIGNED_OPERATOR_NEW_IF_VECTORIZABLE_FIXED_SIZE(Scalar,Size)
791
-
792
- #else
793
-
794
- // HIP does not support new/delete on device.
795
- #if EIGEN_MAX_ALIGN_BYTES!=0 && !defined(EIGEN_HIP_DEVICE_COMPILE)
796
- #define EIGEN_MAKE_ALIGNED_OPERATOR_NEW_NOTHROW(NeedsToAlign) \
797
- EIGEN_DEVICE_FUNC \
798
- void* operator new(std::size_t size, const std::nothrow_t&) EIGEN_NO_THROW { \
799
- EIGEN_TRY { return Eigen::internal::conditional_aligned_malloc<NeedsToAlign>(size); } \
800
- EIGEN_CATCH (...) { return 0; } \
801
- }
802
- #define EIGEN_MAKE_ALIGNED_OPERATOR_NEW_IF(NeedsToAlign) \
803
- EIGEN_DEVICE_FUNC \
804
- void *operator new(std::size_t size) { \
805
- return Eigen::internal::conditional_aligned_malloc<NeedsToAlign>(size); \
806
- } \
807
- EIGEN_DEVICE_FUNC \
808
- void *operator new[](std::size_t size) { \
809
- return Eigen::internal::conditional_aligned_malloc<NeedsToAlign>(size); \
810
- } \
811
- EIGEN_DEVICE_FUNC \
812
- void operator delete(void * ptr) EIGEN_NO_THROW { Eigen::internal::conditional_aligned_free<NeedsToAlign>(ptr); } \
813
- EIGEN_DEVICE_FUNC \
814
- void operator delete[](void * ptr) EIGEN_NO_THROW { Eigen::internal::conditional_aligned_free<NeedsToAlign>(ptr); } \
815
- EIGEN_DEVICE_FUNC \
816
- void operator delete(void * ptr, std::size_t /* sz */) EIGEN_NO_THROW { Eigen::internal::conditional_aligned_free<NeedsToAlign>(ptr); } \
817
- EIGEN_DEVICE_FUNC \
818
- void operator delete[](void * ptr, std::size_t /* sz */) EIGEN_NO_THROW { Eigen::internal::conditional_aligned_free<NeedsToAlign>(ptr); } \
819
- /* in-place new and delete. since (at least afaik) there is no actual */ \
820
- /* memory allocated we can safely let the default implementation handle */ \
821
- /* this particular case. */ \
822
- EIGEN_DEVICE_FUNC \
823
- static void *operator new(std::size_t size, void *ptr) { return ::operator new(size,ptr); } \
824
- EIGEN_DEVICE_FUNC \
825
- static void *operator new[](std::size_t size, void* ptr) { return ::operator new[](size,ptr); } \
826
- EIGEN_DEVICE_FUNC \
827
- void operator delete(void * memory, void *ptr) EIGEN_NO_THROW { return ::operator delete(memory,ptr); } \
828
- EIGEN_DEVICE_FUNC \
829
- void operator delete[](void * memory, void *ptr) EIGEN_NO_THROW { return ::operator delete[](memory,ptr); } \
830
- /* nothrow-new (returns zero instead of std::bad_alloc) */ \
831
- EIGEN_MAKE_ALIGNED_OPERATOR_NEW_NOTHROW(NeedsToAlign) \
832
- EIGEN_DEVICE_FUNC \
833
- void operator delete(void *ptr, const std::nothrow_t&) EIGEN_NO_THROW { \
834
- Eigen::internal::conditional_aligned_free<NeedsToAlign>(ptr); \
835
- } \
836
- typedef void eigen_aligned_operator_new_marker_type;
837
- #else
838
- #define EIGEN_MAKE_ALIGNED_OPERATOR_NEW_IF(NeedsToAlign)
839
- #endif
840
-
841
- #define EIGEN_MAKE_ALIGNED_OPERATOR_NEW EIGEN_MAKE_ALIGNED_OPERATOR_NEW_IF(true)
842
- #define EIGEN_MAKE_ALIGNED_OPERATOR_NEW_IF_VECTORIZABLE_FIXED_SIZE(Scalar,Size) \
843
- EIGEN_MAKE_ALIGNED_OPERATOR_NEW_IF(bool( \
844
- ((Size)!=Eigen::Dynamic) && \
845
- (((EIGEN_MAX_ALIGN_BYTES>=16) && ((sizeof(Scalar)*(Size))%(EIGEN_MAX_ALIGN_BYTES )==0)) || \
846
- ((EIGEN_MAX_ALIGN_BYTES>=32) && ((sizeof(Scalar)*(Size))%(EIGEN_MAX_ALIGN_BYTES/2)==0)) || \
847
- ((EIGEN_MAX_ALIGN_BYTES>=64) && ((sizeof(Scalar)*(Size))%(EIGEN_MAX_ALIGN_BYTES/4)==0)) )))
848
-
849
- #endif
850
-
851
- /****************************************************************************/
852
-
853
- /** \class aligned_allocator
854
- * \ingroup Core_Module
855
- *
856
- * \brief STL compatible allocator to use with types requiring a non standrad alignment.
857
- *
858
- * The memory is aligned as for dynamically aligned matrix/array types such as MatrixXd.
859
- * By default, it will thus provide at least 16 bytes alignment and more in following cases:
860
- * - 32 bytes alignment if AVX is enabled.
861
- * - 64 bytes alignment if AVX512 is enabled.
862
- *
863
- * This can be controlled using the \c EIGEN_MAX_ALIGN_BYTES macro as documented
864
- * \link TopicPreprocessorDirectivesPerformance there \endlink.
865
- *
866
- * Example:
867
- * \code
868
- * // Matrix4f requires 16 bytes alignment:
869
- * std::map< int, Matrix4f, std::less<int>,
870
- * aligned_allocator<std::pair<const int, Matrix4f> > > my_map_mat4;
871
- * // Vector3f does not require 16 bytes alignment, no need to use Eigen's allocator:
872
- * std::map< int, Vector3f > my_map_vec3;
873
- * \endcode
874
- *
875
- * \sa \blank \ref TopicStlContainers.
876
- */
877
- template<class T>
878
- class aligned_allocator : public std::allocator<T>
879
- {
880
- public:
881
- typedef std::size_t size_type;
882
- typedef std::ptrdiff_t difference_type;
883
- typedef T* pointer;
884
- typedef const T* const_pointer;
885
- typedef T& reference;
886
- typedef const T& const_reference;
887
- typedef T value_type;
888
-
889
- template<class U>
890
- struct rebind
891
- {
892
- typedef aligned_allocator<U> other;
893
- };
894
-
895
- aligned_allocator() : std::allocator<T>() {}
896
-
897
- aligned_allocator(const aligned_allocator& other) : std::allocator<T>(other) {}
898
-
899
- template<class U>
900
- aligned_allocator(const aligned_allocator<U>& other) : std::allocator<T>(other) {}
901
-
902
- ~aligned_allocator() {}
903
-
904
- #if EIGEN_COMP_GNUC_STRICT && EIGEN_GNUC_AT_LEAST(7,0)
905
- // In gcc std::allocator::max_size() is bugged making gcc triggers a warning:
906
- // eigen/Eigen/src/Core/util/Memory.h:189:12: warning: argument 1 value '18446744073709551612' exceeds maximum object size 9223372036854775807
907
- // See https://gcc.gnu.org/bugzilla/show_bug.cgi?id=87544
908
- size_type max_size() const {
909
- return (std::numeric_limits<std::ptrdiff_t>::max)()/sizeof(T);
910
- }
911
- #endif
912
-
913
- pointer allocate(size_type num, const void* /*hint*/ = 0)
914
- {
915
- internal::check_size_for_overflow<T>(num);
916
- return static_cast<pointer>( internal::aligned_malloc(num * sizeof(T)) );
917
- }
918
-
919
- void deallocate(pointer p, size_type /*num*/)
920
- {
921
- internal::aligned_free(p);
922
- }
923
- };
924
-
925
- //---------- Cache sizes ----------
926
-
927
- #if !defined(EIGEN_NO_CPUID)
928
- # if EIGEN_COMP_GNUC && EIGEN_ARCH_i386_OR_x86_64
929
- # if defined(__PIC__) && EIGEN_ARCH_i386
930
- // Case for x86 with PIC
931
- # define EIGEN_CPUID(abcd,func,id) \
932
- __asm__ __volatile__ ("xchgl %%ebx, %k1;cpuid; xchgl %%ebx,%k1": "=a" (abcd[0]), "=&r" (abcd[1]), "=c" (abcd[2]), "=d" (abcd[3]) : "a" (func), "c" (id));
933
- # elif defined(__PIC__) && EIGEN_ARCH_x86_64
934
- // Case for x64 with PIC. In theory this is only a problem with recent gcc and with medium or large code model, not with the default small code model.
935
- // However, we cannot detect which code model is used, and the xchg overhead is negligible anyway.
936
- # define EIGEN_CPUID(abcd,func,id) \
937
- __asm__ __volatile__ ("xchg{q}\t{%%}rbx, %q1; cpuid; xchg{q}\t{%%}rbx, %q1": "=a" (abcd[0]), "=&r" (abcd[1]), "=c" (abcd[2]), "=d" (abcd[3]) : "0" (func), "2" (id));
938
- # else
939
- // Case for x86_64 or x86 w/o PIC
940
- # define EIGEN_CPUID(abcd,func,id) \
941
- __asm__ __volatile__ ("cpuid": "=a" (abcd[0]), "=b" (abcd[1]), "=c" (abcd[2]), "=d" (abcd[3]) : "0" (func), "2" (id) );
942
- # endif
943
- # elif EIGEN_COMP_MSVC
944
- # if (EIGEN_COMP_MSVC > 1500) && EIGEN_ARCH_i386_OR_x86_64
945
- # define EIGEN_CPUID(abcd,func,id) __cpuidex((int*)abcd,func,id)
946
- # endif
947
- # endif
948
- #endif
949
-
950
- namespace internal {
951
-
952
- #ifdef EIGEN_CPUID
953
-
954
- inline bool cpuid_is_vendor(int abcd[4], const int vendor[3])
955
- {
956
- return abcd[1]==vendor[0] && abcd[3]==vendor[1] && abcd[2]==vendor[2];
957
- }
958
-
959
- inline void queryCacheSizes_intel_direct(int& l1, int& l2, int& l3)
960
- {
961
- int abcd[4];
962
- l1 = l2 = l3 = 0;
963
- int cache_id = 0;
964
- int cache_type = 0;
965
- do {
966
- abcd[0] = abcd[1] = abcd[2] = abcd[3] = 0;
967
- EIGEN_CPUID(abcd,0x4,cache_id);
968
- cache_type = (abcd[0] & 0x0F) >> 0;
969
- if(cache_type==1||cache_type==3) // data or unified cache
970
- {
971
- int cache_level = (abcd[0] & 0xE0) >> 5; // A[7:5]
972
- int ways = (abcd[1] & 0xFFC00000) >> 22; // B[31:22]
973
- int partitions = (abcd[1] & 0x003FF000) >> 12; // B[21:12]
974
- int line_size = (abcd[1] & 0x00000FFF) >> 0; // B[11:0]
975
- int sets = (abcd[2]); // C[31:0]
976
-
977
- int cache_size = (ways+1) * (partitions+1) * (line_size+1) * (sets+1);
978
-
979
- switch(cache_level)
980
- {
981
- case 1: l1 = cache_size; break;
982
- case 2: l2 = cache_size; break;
983
- case 3: l3 = cache_size; break;
984
- default: break;
985
- }
986
- }
987
- cache_id++;
988
- } while(cache_type>0 && cache_id<16);
989
- }
990
-
991
- inline void queryCacheSizes_intel_codes(int& l1, int& l2, int& l3)
992
- {
993
- int abcd[4];
994
- abcd[0] = abcd[1] = abcd[2] = abcd[3] = 0;
995
- l1 = l2 = l3 = 0;
996
- EIGEN_CPUID(abcd,0x00000002,0);
997
- unsigned char * bytes = reinterpret_cast<unsigned char *>(abcd)+2;
998
- bool check_for_p2_core2 = false;
999
- for(int i=0; i<14; ++i)
1000
- {
1001
- switch(bytes[i])
1002
- {
1003
- case 0x0A: l1 = 8; break; // 0Ah data L1 cache, 8 KB, 2 ways, 32 byte lines
1004
- case 0x0C: l1 = 16; break; // 0Ch data L1 cache, 16 KB, 4 ways, 32 byte lines
1005
- case 0x0E: l1 = 24; break; // 0Eh data L1 cache, 24 KB, 6 ways, 64 byte lines
1006
- case 0x10: l1 = 16; break; // 10h data L1 cache, 16 KB, 4 ways, 32 byte lines (IA-64)
1007
- case 0x15: l1 = 16; break; // 15h code L1 cache, 16 KB, 4 ways, 32 byte lines (IA-64)
1008
- case 0x2C: l1 = 32; break; // 2Ch data L1 cache, 32 KB, 8 ways, 64 byte lines
1009
- case 0x30: l1 = 32; break; // 30h code L1 cache, 32 KB, 8 ways, 64 byte lines
1010
- case 0x60: l1 = 16; break; // 60h data L1 cache, 16 KB, 8 ways, 64 byte lines, sectored
1011
- case 0x66: l1 = 8; break; // 66h data L1 cache, 8 KB, 4 ways, 64 byte lines, sectored
1012
- case 0x67: l1 = 16; break; // 67h data L1 cache, 16 KB, 4 ways, 64 byte lines, sectored
1013
- case 0x68: l1 = 32; break; // 68h data L1 cache, 32 KB, 4 ways, 64 byte lines, sectored
1014
- case 0x1A: l2 = 96; break; // code and data L2 cache, 96 KB, 6 ways, 64 byte lines (IA-64)
1015
- case 0x22: l3 = 512; break; // code and data L3 cache, 512 KB, 4 ways (!), 64 byte lines, dual-sectored
1016
- case 0x23: l3 = 1024; break; // code and data L3 cache, 1024 KB, 8 ways, 64 byte lines, dual-sectored
1017
- case 0x25: l3 = 2048; break; // code and data L3 cache, 2048 KB, 8 ways, 64 byte lines, dual-sectored
1018
- case 0x29: l3 = 4096; break; // code and data L3 cache, 4096 KB, 8 ways, 64 byte lines, dual-sectored
1019
- case 0x39: l2 = 128; break; // code and data L2 cache, 128 KB, 4 ways, 64 byte lines, sectored
1020
- case 0x3A: l2 = 192; break; // code and data L2 cache, 192 KB, 6 ways, 64 byte lines, sectored
1021
- case 0x3B: l2 = 128; break; // code and data L2 cache, 128 KB, 2 ways, 64 byte lines, sectored
1022
- case 0x3C: l2 = 256; break; // code and data L2 cache, 256 KB, 4 ways, 64 byte lines, sectored
1023
- case 0x3D: l2 = 384; break; // code and data L2 cache, 384 KB, 6 ways, 64 byte lines, sectored
1024
- case 0x3E: l2 = 512; break; // code and data L2 cache, 512 KB, 4 ways, 64 byte lines, sectored
1025
- case 0x40: l2 = 0; break; // no integrated L2 cache (P6 core) or L3 cache (P4 core)
1026
- case 0x41: l2 = 128; break; // code and data L2 cache, 128 KB, 4 ways, 32 byte lines
1027
- case 0x42: l2 = 256; break; // code and data L2 cache, 256 KB, 4 ways, 32 byte lines
1028
- case 0x43: l2 = 512; break; // code and data L2 cache, 512 KB, 4 ways, 32 byte lines
1029
- case 0x44: l2 = 1024; break; // code and data L2 cache, 1024 KB, 4 ways, 32 byte lines
1030
- case 0x45: l2 = 2048; break; // code and data L2 cache, 2048 KB, 4 ways, 32 byte lines
1031
- case 0x46: l3 = 4096; break; // code and data L3 cache, 4096 KB, 4 ways, 64 byte lines
1032
- case 0x47: l3 = 8192; break; // code and data L3 cache, 8192 KB, 8 ways, 64 byte lines
1033
- case 0x48: l2 = 3072; break; // code and data L2 cache, 3072 KB, 12 ways, 64 byte lines
1034
- case 0x49: if(l2!=0) l3 = 4096; else {check_for_p2_core2=true; l3 = l2 = 4096;} break;// code and data L3 cache, 4096 KB, 16 ways, 64 byte lines (P4) or L2 for core2
1035
- case 0x4A: l3 = 6144; break; // code and data L3 cache, 6144 KB, 12 ways, 64 byte lines
1036
- case 0x4B: l3 = 8192; break; // code and data L3 cache, 8192 KB, 16 ways, 64 byte lines
1037
- case 0x4C: l3 = 12288; break; // code and data L3 cache, 12288 KB, 12 ways, 64 byte lines
1038
- case 0x4D: l3 = 16384; break; // code and data L3 cache, 16384 KB, 16 ways, 64 byte lines
1039
- case 0x4E: l2 = 6144; break; // code and data L2 cache, 6144 KB, 24 ways, 64 byte lines
1040
- case 0x78: l2 = 1024; break; // code and data L2 cache, 1024 KB, 4 ways, 64 byte lines
1041
- case 0x79: l2 = 128; break; // code and data L2 cache, 128 KB, 8 ways, 64 byte lines, dual-sectored
1042
- case 0x7A: l2 = 256; break; // code and data L2 cache, 256 KB, 8 ways, 64 byte lines, dual-sectored
1043
- case 0x7B: l2 = 512; break; // code and data L2 cache, 512 KB, 8 ways, 64 byte lines, dual-sectored
1044
- case 0x7C: l2 = 1024; break; // code and data L2 cache, 1024 KB, 8 ways, 64 byte lines, dual-sectored
1045
- case 0x7D: l2 = 2048; break; // code and data L2 cache, 2048 KB, 8 ways, 64 byte lines
1046
- case 0x7E: l2 = 256; break; // code and data L2 cache, 256 KB, 8 ways, 128 byte lines, sect. (IA-64)
1047
- case 0x7F: l2 = 512; break; // code and data L2 cache, 512 KB, 2 ways, 64 byte lines
1048
- case 0x80: l2 = 512; break; // code and data L2 cache, 512 KB, 8 ways, 64 byte lines
1049
- case 0x81: l2 = 128; break; // code and data L2 cache, 128 KB, 8 ways, 32 byte lines
1050
- case 0x82: l2 = 256; break; // code and data L2 cache, 256 KB, 8 ways, 32 byte lines
1051
- case 0x83: l2 = 512; break; // code and data L2 cache, 512 KB, 8 ways, 32 byte lines
1052
- case 0x84: l2 = 1024; break; // code and data L2 cache, 1024 KB, 8 ways, 32 byte lines
1053
- case 0x85: l2 = 2048; break; // code and data L2 cache, 2048 KB, 8 ways, 32 byte lines
1054
- case 0x86: l2 = 512; break; // code and data L2 cache, 512 KB, 4 ways, 64 byte lines
1055
- case 0x87: l2 = 1024; break; // code and data L2 cache, 1024 KB, 8 ways, 64 byte lines
1056
- case 0x88: l3 = 2048; break; // code and data L3 cache, 2048 KB, 4 ways, 64 byte lines (IA-64)
1057
- case 0x89: l3 = 4096; break; // code and data L3 cache, 4096 KB, 4 ways, 64 byte lines (IA-64)
1058
- case 0x8A: l3 = 8192; break; // code and data L3 cache, 8192 KB, 4 ways, 64 byte lines (IA-64)
1059
- case 0x8D: l3 = 3072; break; // code and data L3 cache, 3072 KB, 12 ways, 128 byte lines (IA-64)
1060
-
1061
- default: break;
1062
- }
1063
- }
1064
- if(check_for_p2_core2 && l2 == l3)
1065
- l3 = 0;
1066
- l1 *= 1024;
1067
- l2 *= 1024;
1068
- l3 *= 1024;
1069
- }
1070
-
1071
- inline void queryCacheSizes_intel(int& l1, int& l2, int& l3, int max_std_funcs)
1072
- {
1073
- if(max_std_funcs>=4)
1074
- queryCacheSizes_intel_direct(l1,l2,l3);
1075
- else if(max_std_funcs>=2)
1076
- queryCacheSizes_intel_codes(l1,l2,l3);
1077
- else
1078
- l1 = l2 = l3 = 0;
1079
- }
1080
-
1081
- inline void queryCacheSizes_amd(int& l1, int& l2, int& l3)
1082
- {
1083
- int abcd[4];
1084
- abcd[0] = abcd[1] = abcd[2] = abcd[3] = 0;
1085
-
1086
- // First query the max supported function.
1087
- EIGEN_CPUID(abcd,0x80000000,0);
1088
- if(static_cast<numext::uint32_t>(abcd[0]) >= static_cast<numext::uint32_t>(0x80000006))
1089
- {
1090
- EIGEN_CPUID(abcd,0x80000005,0);
1091
- l1 = (abcd[2] >> 24) * 1024; // C[31:24] = L1 size in KB
1092
- abcd[0] = abcd[1] = abcd[2] = abcd[3] = 0;
1093
- EIGEN_CPUID(abcd,0x80000006,0);
1094
- l2 = (abcd[2] >> 16) * 1024; // C[31;16] = l2 cache size in KB
1095
- l3 = ((abcd[3] & 0xFFFC000) >> 18) * 512 * 1024; // D[31;18] = l3 cache size in 512KB
1096
- }
1097
- else
1098
- {
1099
- l1 = l2 = l3 = 0;
1100
- }
1101
- }
1102
- #endif
1103
-
1104
- /** \internal
1105
- * Queries and returns the cache sizes in Bytes of the L1, L2, and L3 data caches respectively */
1106
- inline void queryCacheSizes(int& l1, int& l2, int& l3)
1107
- {
1108
- #ifdef EIGEN_CPUID
1109
- int abcd[4];
1110
- const int GenuineIntel[] = {0x756e6547, 0x49656e69, 0x6c65746e};
1111
- const int AuthenticAMD[] = {0x68747541, 0x69746e65, 0x444d4163};
1112
- const int AMDisbetter_[] = {0x69444d41, 0x74656273, 0x21726574}; // "AMDisbetter!"
1113
-
1114
- // identify the CPU vendor
1115
- EIGEN_CPUID(abcd,0x0,0);
1116
- int max_std_funcs = abcd[0];
1117
- if(cpuid_is_vendor(abcd,GenuineIntel))
1118
- queryCacheSizes_intel(l1,l2,l3,max_std_funcs);
1119
- else if(cpuid_is_vendor(abcd,AuthenticAMD) || cpuid_is_vendor(abcd,AMDisbetter_))
1120
- queryCacheSizes_amd(l1,l2,l3);
1121
- else
1122
- // by default let's use Intel's API
1123
- queryCacheSizes_intel(l1,l2,l3,max_std_funcs);
1124
-
1125
- // here is the list of other vendors:
1126
- // ||cpuid_is_vendor(abcd,"VIA VIA VIA ")
1127
- // ||cpuid_is_vendor(abcd,"CyrixInstead")
1128
- // ||cpuid_is_vendor(abcd,"CentaurHauls")
1129
- // ||cpuid_is_vendor(abcd,"GenuineTMx86")
1130
- // ||cpuid_is_vendor(abcd,"TransmetaCPU")
1131
- // ||cpuid_is_vendor(abcd,"RiseRiseRise")
1132
- // ||cpuid_is_vendor(abcd,"Geode by NSC")
1133
- // ||cpuid_is_vendor(abcd,"SiS SiS SiS ")
1134
- // ||cpuid_is_vendor(abcd,"UMC UMC UMC ")
1135
- // ||cpuid_is_vendor(abcd,"NexGenDriven")
1136
- #else
1137
- l1 = l2 = l3 = -1;
1138
- #endif
1139
- }
1140
-
1141
- /** \internal
1142
- * \returns the size in Bytes of the L1 data cache */
1143
- inline int queryL1CacheSize()
1144
- {
1145
- int l1(-1), l2, l3;
1146
- queryCacheSizes(l1,l2,l3);
1147
- return l1;
1148
- }
1149
-
1150
- /** \internal
1151
- * \returns the size in Bytes of the L2 or L3 cache if this later is present */
1152
- inline int queryTopLevelCacheSize()
1153
- {
1154
- int l1, l2(-1), l3(-1);
1155
- queryCacheSizes(l1,l2,l3);
1156
- return (std::max)(l2,l3);
1157
- }
1158
-
1159
- } // end namespace internal
1160
-
1161
- } // end namespace Eigen
1162
-
1163
- #endif // EIGEN_MEMORY_H