@smake/eigen 1.0.2 → 1.1.1

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.
Files changed (435) hide show
  1. package/README.md +1 -1
  2. package/eigen/Eigen/AccelerateSupport +52 -0
  3. package/eigen/Eigen/Cholesky +18 -21
  4. package/eigen/Eigen/CholmodSupport +28 -28
  5. package/eigen/Eigen/Core +235 -326
  6. package/eigen/Eigen/Eigenvalues +16 -14
  7. package/eigen/Eigen/Geometry +21 -24
  8. package/eigen/Eigen/Householder +9 -8
  9. package/eigen/Eigen/IterativeLinearSolvers +8 -4
  10. package/eigen/Eigen/Jacobi +14 -14
  11. package/eigen/Eigen/KLUSupport +43 -0
  12. package/eigen/Eigen/LU +16 -20
  13. package/eigen/Eigen/MetisSupport +12 -12
  14. package/eigen/Eigen/OrderingMethods +54 -54
  15. package/eigen/Eigen/PaStiXSupport +23 -20
  16. package/eigen/Eigen/PardisoSupport +17 -14
  17. package/eigen/Eigen/QR +18 -21
  18. package/eigen/Eigen/QtAlignedMalloc +5 -13
  19. package/eigen/Eigen/SPQRSupport +21 -14
  20. package/eigen/Eigen/SVD +23 -18
  21. package/eigen/Eigen/Sparse +1 -4
  22. package/eigen/Eigen/SparseCholesky +18 -23
  23. package/eigen/Eigen/SparseCore +18 -17
  24. package/eigen/Eigen/SparseLU +12 -8
  25. package/eigen/Eigen/SparseQR +16 -14
  26. package/eigen/Eigen/StdDeque +5 -2
  27. package/eigen/Eigen/StdList +5 -2
  28. package/eigen/Eigen/StdVector +5 -2
  29. package/eigen/Eigen/SuperLUSupport +30 -24
  30. package/eigen/Eigen/ThreadPool +80 -0
  31. package/eigen/Eigen/UmfPackSupport +19 -17
  32. package/eigen/Eigen/Version +14 -0
  33. package/eigen/Eigen/src/AccelerateSupport/AccelerateSupport.h +423 -0
  34. package/eigen/Eigen/src/AccelerateSupport/InternalHeaderCheck.h +3 -0
  35. package/eigen/Eigen/src/Cholesky/InternalHeaderCheck.h +3 -0
  36. package/eigen/Eigen/src/Cholesky/LDLT.h +377 -401
  37. package/eigen/Eigen/src/Cholesky/LLT.h +332 -360
  38. package/eigen/Eigen/src/Cholesky/LLT_LAPACKE.h +81 -56
  39. package/eigen/Eigen/src/CholmodSupport/CholmodSupport.h +620 -521
  40. package/eigen/Eigen/src/CholmodSupport/InternalHeaderCheck.h +3 -0
  41. package/eigen/Eigen/src/Core/ArithmeticSequence.h +239 -0
  42. package/eigen/Eigen/src/Core/Array.h +341 -294
  43. package/eigen/Eigen/src/Core/ArrayBase.h +190 -203
  44. package/eigen/Eigen/src/Core/ArrayWrapper.h +127 -171
  45. package/eigen/Eigen/src/Core/Assign.h +30 -40
  46. package/eigen/Eigen/src/Core/AssignEvaluator.h +711 -589
  47. package/eigen/Eigen/src/Core/Assign_MKL.h +130 -125
  48. package/eigen/Eigen/src/Core/BandMatrix.h +268 -283
  49. package/eigen/Eigen/src/Core/Block.h +375 -398
  50. package/eigen/Eigen/src/Core/CommaInitializer.h +86 -97
  51. package/eigen/Eigen/src/Core/ConditionEstimator.h +51 -53
  52. package/eigen/Eigen/src/Core/CoreEvaluators.h +1356 -1026
  53. package/eigen/Eigen/src/Core/CoreIterators.h +73 -59
  54. package/eigen/Eigen/src/Core/CwiseBinaryOp.h +114 -132
  55. package/eigen/Eigen/src/Core/CwiseNullaryOp.h +726 -617
  56. package/eigen/Eigen/src/Core/CwiseTernaryOp.h +77 -103
  57. package/eigen/Eigen/src/Core/CwiseUnaryOp.h +56 -68
  58. package/eigen/Eigen/src/Core/CwiseUnaryView.h +132 -95
  59. package/eigen/Eigen/src/Core/DenseBase.h +632 -571
  60. package/eigen/Eigen/src/Core/DenseCoeffsBase.h +511 -624
  61. package/eigen/Eigen/src/Core/DenseStorage.h +512 -509
  62. package/eigen/Eigen/src/Core/DeviceWrapper.h +153 -0
  63. package/eigen/Eigen/src/Core/Diagonal.h +169 -210
  64. package/eigen/Eigen/src/Core/DiagonalMatrix.h +351 -274
  65. package/eigen/Eigen/src/Core/DiagonalProduct.h +12 -10
  66. package/eigen/Eigen/src/Core/Dot.h +172 -222
  67. package/eigen/Eigen/src/Core/EigenBase.h +75 -85
  68. package/eigen/Eigen/src/Core/Fill.h +138 -0
  69. package/eigen/Eigen/src/Core/FindCoeff.h +464 -0
  70. package/eigen/Eigen/src/Core/ForceAlignedAccess.h +90 -109
  71. package/eigen/Eigen/src/Core/Fuzzy.h +82 -105
  72. package/eigen/Eigen/src/Core/GeneralProduct.h +327 -263
  73. package/eigen/Eigen/src/Core/GenericPacketMath.h +1472 -360
  74. package/eigen/Eigen/src/Core/GlobalFunctions.h +194 -151
  75. package/eigen/Eigen/src/Core/IO.h +147 -139
  76. package/eigen/Eigen/src/Core/IndexedView.h +321 -0
  77. package/eigen/Eigen/src/Core/InnerProduct.h +260 -0
  78. package/eigen/Eigen/src/Core/InternalHeaderCheck.h +3 -0
  79. package/eigen/Eigen/src/Core/Inverse.h +56 -66
  80. package/eigen/Eigen/src/Core/Map.h +124 -142
  81. package/eigen/Eigen/src/Core/MapBase.h +256 -281
  82. package/eigen/Eigen/src/Core/MathFunctions.h +1620 -938
  83. package/eigen/Eigen/src/Core/MathFunctionsImpl.h +233 -71
  84. package/eigen/Eigen/src/Core/Matrix.h +491 -416
  85. package/eigen/Eigen/src/Core/MatrixBase.h +468 -453
  86. package/eigen/Eigen/src/Core/NestByValue.h +66 -85
  87. package/eigen/Eigen/src/Core/NoAlias.h +79 -85
  88. package/eigen/Eigen/src/Core/NumTraits.h +235 -148
  89. package/eigen/Eigen/src/Core/PartialReduxEvaluator.h +253 -0
  90. package/eigen/Eigen/src/Core/PermutationMatrix.h +461 -511
  91. package/eigen/Eigen/src/Core/PlainObjectBase.h +871 -894
  92. package/eigen/Eigen/src/Core/Product.h +260 -139
  93. package/eigen/Eigen/src/Core/ProductEvaluators.h +863 -714
  94. package/eigen/Eigen/src/Core/Random.h +161 -136
  95. package/eigen/Eigen/src/Core/RandomImpl.h +262 -0
  96. package/eigen/Eigen/src/Core/RealView.h +250 -0
  97. package/eigen/Eigen/src/Core/Redux.h +366 -336
  98. package/eigen/Eigen/src/Core/Ref.h +308 -209
  99. package/eigen/Eigen/src/Core/Replicate.h +94 -106
  100. package/eigen/Eigen/src/Core/Reshaped.h +398 -0
  101. package/eigen/Eigen/src/Core/ReturnByValue.h +49 -55
  102. package/eigen/Eigen/src/Core/Reverse.h +136 -145
  103. package/eigen/Eigen/src/Core/Select.h +70 -140
  104. package/eigen/Eigen/src/Core/SelfAdjointView.h +262 -285
  105. package/eigen/Eigen/src/Core/SelfCwiseBinaryOp.h +23 -20
  106. package/eigen/Eigen/src/Core/SkewSymmetricMatrix3.h +382 -0
  107. package/eigen/Eigen/src/Core/Solve.h +97 -111
  108. package/eigen/Eigen/src/Core/SolveTriangular.h +131 -129
  109. package/eigen/Eigen/src/Core/SolverBase.h +138 -101
  110. package/eigen/Eigen/src/Core/StableNorm.h +156 -160
  111. package/eigen/Eigen/src/Core/StlIterators.h +619 -0
  112. package/eigen/Eigen/src/Core/Stride.h +91 -88
  113. package/eigen/Eigen/src/Core/Swap.h +70 -38
  114. package/eigen/Eigen/src/Core/Transpose.h +295 -273
  115. package/eigen/Eigen/src/Core/Transpositions.h +272 -317
  116. package/eigen/Eigen/src/Core/TriangularMatrix.h +670 -755
  117. package/eigen/Eigen/src/Core/VectorBlock.h +59 -72
  118. package/eigen/Eigen/src/Core/VectorwiseOp.h +668 -630
  119. package/eigen/Eigen/src/Core/Visitor.h +480 -216
  120. package/eigen/Eigen/src/Core/arch/AVX/Complex.h +407 -293
  121. package/eigen/Eigen/src/Core/arch/AVX/MathFunctions.h +79 -388
  122. package/eigen/Eigen/src/Core/arch/AVX/PacketMath.h +2935 -491
  123. package/eigen/Eigen/src/Core/arch/AVX/Reductions.h +353 -0
  124. package/eigen/Eigen/src/Core/arch/AVX/TypeCasting.h +279 -22
  125. package/eigen/Eigen/src/Core/arch/AVX512/Complex.h +472 -0
  126. package/eigen/Eigen/src/Core/arch/AVX512/GemmKernel.h +1245 -0
  127. package/eigen/Eigen/src/Core/arch/AVX512/MathFunctions.h +85 -333
  128. package/eigen/Eigen/src/Core/arch/AVX512/MathFunctionsFP16.h +75 -0
  129. package/eigen/Eigen/src/Core/arch/AVX512/PacketMath.h +2490 -649
  130. package/eigen/Eigen/src/Core/arch/AVX512/PacketMathFP16.h +1413 -0
  131. package/eigen/Eigen/src/Core/arch/AVX512/Reductions.h +297 -0
  132. package/eigen/Eigen/src/Core/arch/AVX512/TrsmKernel.h +1167 -0
  133. package/eigen/Eigen/src/Core/arch/AVX512/TrsmUnrolls.inc +1219 -0
  134. package/eigen/Eigen/src/Core/arch/AVX512/TypeCasting.h +277 -0
  135. package/eigen/Eigen/src/Core/arch/AVX512/TypeCastingFP16.h +130 -0
  136. package/eigen/Eigen/src/Core/arch/AltiVec/Complex.h +521 -298
  137. package/eigen/Eigen/src/Core/arch/AltiVec/MathFunctions.h +39 -280
  138. package/eigen/Eigen/src/Core/arch/AltiVec/MatrixProduct.h +3686 -0
  139. package/eigen/Eigen/src/Core/arch/AltiVec/MatrixProductCommon.h +205 -0
  140. package/eigen/Eigen/src/Core/arch/AltiVec/MatrixProductMMA.h +901 -0
  141. package/eigen/Eigen/src/Core/arch/AltiVec/MatrixProductMMAbfloat16.h +742 -0
  142. package/eigen/Eigen/src/Core/arch/AltiVec/MatrixVectorProduct.inc +2818 -0
  143. package/eigen/Eigen/src/Core/arch/AltiVec/PacketMath.h +3391 -723
  144. package/eigen/Eigen/src/Core/arch/AltiVec/TypeCasting.h +153 -0
  145. package/eigen/Eigen/src/Core/arch/Default/BFloat16.h +866 -0
  146. package/eigen/Eigen/src/Core/arch/Default/ConjHelper.h +113 -14
  147. package/eigen/Eigen/src/Core/arch/Default/GenericPacketMathFunctions.h +2634 -0
  148. package/eigen/Eigen/src/Core/arch/Default/GenericPacketMathFunctionsFwd.h +227 -0
  149. package/eigen/Eigen/src/Core/arch/Default/Half.h +1091 -0
  150. package/eigen/Eigen/src/Core/arch/Default/Settings.h +11 -13
  151. package/eigen/Eigen/src/Core/arch/GPU/Complex.h +244 -0
  152. package/eigen/Eigen/src/Core/arch/GPU/MathFunctions.h +104 -0
  153. package/eigen/Eigen/src/Core/arch/GPU/PacketMath.h +1712 -0
  154. package/eigen/Eigen/src/Core/arch/GPU/Tuple.h +268 -0
  155. package/eigen/Eigen/src/Core/arch/GPU/TypeCasting.h +77 -0
  156. package/eigen/Eigen/src/Core/arch/HIP/hcc/math_constants.h +23 -0
  157. package/eigen/Eigen/src/Core/arch/HVX/PacketMath.h +1088 -0
  158. package/eigen/Eigen/src/Core/arch/LSX/Complex.h +520 -0
  159. package/eigen/Eigen/src/Core/arch/LSX/GeneralBlockPanelKernel.h +23 -0
  160. package/eigen/Eigen/src/Core/arch/LSX/MathFunctions.h +43 -0
  161. package/eigen/Eigen/src/Core/arch/LSX/PacketMath.h +2866 -0
  162. package/eigen/Eigen/src/Core/arch/LSX/TypeCasting.h +526 -0
  163. package/eigen/Eigen/src/Core/arch/MSA/Complex.h +620 -0
  164. package/eigen/Eigen/src/Core/arch/MSA/MathFunctions.h +379 -0
  165. package/eigen/Eigen/src/Core/arch/MSA/PacketMath.h +1237 -0
  166. package/eigen/Eigen/src/Core/arch/NEON/Complex.h +531 -289
  167. package/eigen/Eigen/src/Core/arch/NEON/GeneralBlockPanelKernel.h +243 -0
  168. package/eigen/Eigen/src/Core/arch/NEON/MathFunctions.h +50 -73
  169. package/eigen/Eigen/src/Core/arch/NEON/PacketMath.h +5915 -579
  170. package/eigen/Eigen/src/Core/arch/NEON/TypeCasting.h +1642 -0
  171. package/eigen/Eigen/src/Core/arch/NEON/UnaryFunctors.h +57 -0
  172. package/eigen/Eigen/src/Core/arch/SSE/Complex.h +366 -334
  173. package/eigen/Eigen/src/Core/arch/SSE/MathFunctions.h +40 -514
  174. package/eigen/Eigen/src/Core/arch/SSE/PacketMath.h +2164 -675
  175. package/eigen/Eigen/src/Core/arch/SSE/Reductions.h +324 -0
  176. package/eigen/Eigen/src/Core/arch/SSE/TypeCasting.h +188 -35
  177. package/eigen/Eigen/src/Core/arch/SVE/MathFunctions.h +48 -0
  178. package/eigen/Eigen/src/Core/arch/SVE/PacketMath.h +674 -0
  179. package/eigen/Eigen/src/Core/arch/SVE/TypeCasting.h +52 -0
  180. package/eigen/Eigen/src/Core/arch/SYCL/InteropHeaders.h +227 -0
  181. package/eigen/Eigen/src/Core/arch/SYCL/MathFunctions.h +303 -0
  182. package/eigen/Eigen/src/Core/arch/SYCL/PacketMath.h +576 -0
  183. package/eigen/Eigen/src/Core/arch/SYCL/TypeCasting.h +83 -0
  184. package/eigen/Eigen/src/Core/arch/ZVector/Complex.h +434 -261
  185. package/eigen/Eigen/src/Core/arch/ZVector/MathFunctions.h +160 -53
  186. package/eigen/Eigen/src/Core/arch/ZVector/PacketMath.h +1073 -605
  187. package/eigen/Eigen/src/Core/functors/AssignmentFunctors.h +123 -117
  188. package/eigen/Eigen/src/Core/functors/BinaryFunctors.h +594 -322
  189. package/eigen/Eigen/src/Core/functors/NullaryFunctors.h +204 -118
  190. package/eigen/Eigen/src/Core/functors/StlFunctors.h +110 -97
  191. package/eigen/Eigen/src/Core/functors/TernaryFunctors.h +34 -7
  192. package/eigen/Eigen/src/Core/functors/UnaryFunctors.h +1158 -530
  193. package/eigen/Eigen/src/Core/products/GeneralBlockPanelKernel.h +2329 -1333
  194. package/eigen/Eigen/src/Core/products/GeneralMatrixMatrix.h +328 -364
  195. package/eigen/Eigen/src/Core/products/GeneralMatrixMatrixTriangular.h +191 -178
  196. package/eigen/Eigen/src/Core/products/GeneralMatrixMatrixTriangular_BLAS.h +85 -82
  197. package/eigen/Eigen/src/Core/products/GeneralMatrixMatrix_BLAS.h +154 -73
  198. package/eigen/Eigen/src/Core/products/GeneralMatrixVector.h +396 -542
  199. package/eigen/Eigen/src/Core/products/GeneralMatrixVector_BLAS.h +80 -77
  200. package/eigen/Eigen/src/Core/products/Parallelizer.h +208 -92
  201. package/eigen/Eigen/src/Core/products/SelfadjointMatrixMatrix.h +331 -375
  202. package/eigen/Eigen/src/Core/products/SelfadjointMatrixMatrix_BLAS.h +206 -224
  203. package/eigen/Eigen/src/Core/products/SelfadjointMatrixVector.h +139 -146
  204. package/eigen/Eigen/src/Core/products/SelfadjointMatrixVector_BLAS.h +58 -61
  205. package/eigen/Eigen/src/Core/products/SelfadjointProduct.h +71 -71
  206. package/eigen/Eigen/src/Core/products/SelfadjointRank2Update.h +48 -46
  207. package/eigen/Eigen/src/Core/products/TriangularMatrixMatrix.h +294 -369
  208. package/eigen/Eigen/src/Core/products/TriangularMatrixMatrix_BLAS.h +246 -238
  209. package/eigen/Eigen/src/Core/products/TriangularMatrixVector.h +244 -247
  210. package/eigen/Eigen/src/Core/products/TriangularMatrixVector_BLAS.h +212 -192
  211. package/eigen/Eigen/src/Core/products/TriangularSolverMatrix.h +328 -275
  212. package/eigen/Eigen/src/Core/products/TriangularSolverMatrix_BLAS.h +108 -109
  213. package/eigen/Eigen/src/Core/products/TriangularSolverVector.h +70 -93
  214. package/eigen/Eigen/src/Core/util/Assert.h +158 -0
  215. package/eigen/Eigen/src/Core/util/BlasUtil.h +413 -290
  216. package/eigen/Eigen/src/Core/util/ConfigureVectorization.h +543 -0
  217. package/eigen/Eigen/src/Core/util/Constants.h +314 -263
  218. package/eigen/Eigen/src/Core/util/DisableStupidWarnings.h +130 -78
  219. package/eigen/Eigen/src/Core/util/EmulateArray.h +270 -0
  220. package/eigen/Eigen/src/Core/util/ForwardDeclarations.h +450 -224
  221. package/eigen/Eigen/src/Core/util/GpuHipCudaDefines.inc +101 -0
  222. package/eigen/Eigen/src/Core/util/GpuHipCudaUndefines.inc +45 -0
  223. package/eigen/Eigen/src/Core/util/IndexedViewHelper.h +487 -0
  224. package/eigen/Eigen/src/Core/util/IntegralConstant.h +279 -0
  225. package/eigen/Eigen/src/Core/util/MKL_support.h +39 -30
  226. package/eigen/Eigen/src/Core/util/Macros.h +939 -646
  227. package/eigen/Eigen/src/Core/util/MaxSizeVector.h +139 -0
  228. package/eigen/Eigen/src/Core/util/Memory.h +1042 -650
  229. package/eigen/Eigen/src/Core/util/Meta.h +618 -426
  230. package/eigen/Eigen/src/Core/util/MoreMeta.h +638 -0
  231. package/eigen/Eigen/src/Core/util/ReenableStupidWarnings.h +32 -19
  232. package/eigen/Eigen/src/Core/util/ReshapedHelper.h +51 -0
  233. package/eigen/Eigen/src/Core/util/Serializer.h +209 -0
  234. package/eigen/Eigen/src/Core/util/StaticAssert.h +51 -164
  235. package/eigen/Eigen/src/Core/util/SymbolicIndex.h +445 -0
  236. package/eigen/Eigen/src/Core/util/XprHelper.h +793 -538
  237. package/eigen/Eigen/src/Eigenvalues/ComplexEigenSolver.h +246 -277
  238. package/eigen/Eigen/src/Eigenvalues/ComplexSchur.h +299 -319
  239. package/eigen/Eigen/src/Eigenvalues/ComplexSchur_LAPACKE.h +52 -48
  240. package/eigen/Eigen/src/Eigenvalues/EigenSolver.h +413 -456
  241. package/eigen/Eigen/src/Eigenvalues/GeneralizedEigenSolver.h +309 -325
  242. package/eigen/Eigen/src/Eigenvalues/GeneralizedSelfAdjointEigenSolver.h +157 -171
  243. package/eigen/Eigen/src/Eigenvalues/HessenbergDecomposition.h +292 -310
  244. package/eigen/Eigen/src/Eigenvalues/InternalHeaderCheck.h +3 -0
  245. package/eigen/Eigen/src/Eigenvalues/MatrixBaseEigenvalues.h +91 -107
  246. package/eigen/Eigen/src/Eigenvalues/RealQZ.h +539 -606
  247. package/eigen/Eigen/src/Eigenvalues/RealSchur.h +348 -382
  248. package/eigen/Eigen/src/Eigenvalues/RealSchur_LAPACKE.h +41 -35
  249. package/eigen/Eigen/src/Eigenvalues/SelfAdjointEigenSolver.h +579 -600
  250. package/eigen/Eigen/src/Eigenvalues/SelfAdjointEigenSolver_LAPACKE.h +47 -44
  251. package/eigen/Eigen/src/Eigenvalues/Tridiagonalization.h +434 -461
  252. package/eigen/Eigen/src/Geometry/AlignedBox.h +307 -214
  253. package/eigen/Eigen/src/Geometry/AngleAxis.h +135 -137
  254. package/eigen/Eigen/src/Geometry/EulerAngles.h +163 -74
  255. package/eigen/Eigen/src/Geometry/Homogeneous.h +289 -333
  256. package/eigen/Eigen/src/Geometry/Hyperplane.h +152 -161
  257. package/eigen/Eigen/src/Geometry/InternalHeaderCheck.h +3 -0
  258. package/eigen/Eigen/src/Geometry/OrthoMethods.h +168 -145
  259. package/eigen/Eigen/src/Geometry/ParametrizedLine.h +141 -104
  260. package/eigen/Eigen/src/Geometry/Quaternion.h +595 -497
  261. package/eigen/Eigen/src/Geometry/Rotation2D.h +110 -108
  262. package/eigen/Eigen/src/Geometry/RotationBase.h +148 -145
  263. package/eigen/Eigen/src/Geometry/Scaling.h +115 -90
  264. package/eigen/Eigen/src/Geometry/Transform.h +896 -953
  265. package/eigen/Eigen/src/Geometry/Translation.h +100 -98
  266. package/eigen/Eigen/src/Geometry/Umeyama.h +79 -84
  267. package/eigen/Eigen/src/Geometry/arch/Geometry_SIMD.h +154 -0
  268. package/eigen/Eigen/src/Householder/BlockHouseholder.h +54 -42
  269. package/eigen/Eigen/src/Householder/Householder.h +104 -122
  270. package/eigen/Eigen/src/Householder/HouseholderSequence.h +416 -382
  271. package/eigen/Eigen/src/Householder/InternalHeaderCheck.h +3 -0
  272. package/eigen/Eigen/src/IterativeLinearSolvers/BasicPreconditioners.h +153 -166
  273. package/eigen/Eigen/src/IterativeLinearSolvers/BiCGSTAB.h +127 -138
  274. package/eigen/Eigen/src/IterativeLinearSolvers/ConjugateGradient.h +95 -124
  275. package/eigen/Eigen/src/IterativeLinearSolvers/IncompleteCholesky.h +269 -267
  276. package/eigen/Eigen/src/IterativeLinearSolvers/IncompleteLUT.h +246 -259
  277. package/eigen/Eigen/src/IterativeLinearSolvers/InternalHeaderCheck.h +3 -0
  278. package/eigen/Eigen/src/IterativeLinearSolvers/IterativeSolverBase.h +218 -217
  279. package/eigen/Eigen/src/IterativeLinearSolvers/LeastSquareConjugateGradient.h +80 -103
  280. package/eigen/Eigen/src/IterativeLinearSolvers/SolveWithGuess.h +59 -63
  281. package/eigen/Eigen/src/Jacobi/InternalHeaderCheck.h +3 -0
  282. package/eigen/Eigen/src/Jacobi/Jacobi.h +256 -291
  283. package/eigen/Eigen/src/KLUSupport/InternalHeaderCheck.h +3 -0
  284. package/eigen/Eigen/src/KLUSupport/KLUSupport.h +339 -0
  285. package/eigen/Eigen/src/LU/Determinant.h +60 -63
  286. package/eigen/Eigen/src/LU/FullPivLU.h +561 -626
  287. package/eigen/Eigen/src/LU/InternalHeaderCheck.h +3 -0
  288. package/eigen/Eigen/src/LU/InverseImpl.h +213 -275
  289. package/eigen/Eigen/src/LU/PartialPivLU.h +407 -435
  290. package/eigen/Eigen/src/LU/PartialPivLU_LAPACKE.h +54 -40
  291. package/eigen/Eigen/src/LU/arch/InverseSize4.h +353 -0
  292. package/eigen/Eigen/src/MetisSupport/InternalHeaderCheck.h +3 -0
  293. package/eigen/Eigen/src/MetisSupport/MetisSupport.h +81 -93
  294. package/eigen/Eigen/src/OrderingMethods/Amd.h +250 -282
  295. package/eigen/Eigen/src/OrderingMethods/Eigen_Colamd.h +950 -1103
  296. package/eigen/Eigen/src/OrderingMethods/InternalHeaderCheck.h +3 -0
  297. package/eigen/Eigen/src/OrderingMethods/Ordering.h +111 -122
  298. package/eigen/Eigen/src/PaStiXSupport/InternalHeaderCheck.h +3 -0
  299. package/eigen/Eigen/src/PaStiXSupport/PaStiXSupport.h +524 -570
  300. package/eigen/Eigen/src/PardisoSupport/InternalHeaderCheck.h +3 -0
  301. package/eigen/Eigen/src/PardisoSupport/PardisoSupport.h +385 -429
  302. package/eigen/Eigen/src/QR/ColPivHouseholderQR.h +494 -473
  303. package/eigen/Eigen/src/QR/ColPivHouseholderQR_LAPACKE.h +120 -56
  304. package/eigen/Eigen/src/QR/CompleteOrthogonalDecomposition.h +223 -137
  305. package/eigen/Eigen/src/QR/FullPivHouseholderQR.h +517 -460
  306. package/eigen/Eigen/src/QR/HouseholderQR.h +412 -278
  307. package/eigen/Eigen/src/QR/HouseholderQR_LAPACKE.h +32 -23
  308. package/eigen/Eigen/src/QR/InternalHeaderCheck.h +3 -0
  309. package/eigen/Eigen/src/SPQRSupport/InternalHeaderCheck.h +3 -0
  310. package/eigen/Eigen/src/SPQRSupport/SuiteSparseQRSupport.h +263 -261
  311. package/eigen/Eigen/src/SVD/BDCSVD.h +872 -679
  312. package/eigen/Eigen/src/SVD/BDCSVD_LAPACKE.h +174 -0
  313. package/eigen/Eigen/src/SVD/InternalHeaderCheck.h +3 -0
  314. package/eigen/Eigen/src/SVD/JacobiSVD.h +585 -543
  315. package/eigen/Eigen/src/SVD/JacobiSVD_LAPACKE.h +85 -49
  316. package/eigen/Eigen/src/SVD/SVDBase.h +281 -160
  317. package/eigen/Eigen/src/SVD/UpperBidiagonalization.h +202 -237
  318. package/eigen/Eigen/src/SparseCholesky/InternalHeaderCheck.h +3 -0
  319. package/eigen/Eigen/src/SparseCholesky/SimplicialCholesky.h +769 -590
  320. package/eigen/Eigen/src/SparseCholesky/SimplicialCholesky_impl.h +318 -129
  321. package/eigen/Eigen/src/SparseCore/AmbiVector.h +202 -251
  322. package/eigen/Eigen/src/SparseCore/CompressedStorage.h +184 -236
  323. package/eigen/Eigen/src/SparseCore/ConservativeSparseSparseProduct.h +140 -184
  324. package/eigen/Eigen/src/SparseCore/InternalHeaderCheck.h +3 -0
  325. package/eigen/Eigen/src/SparseCore/SparseAssign.h +174 -111
  326. package/eigen/Eigen/src/SparseCore/SparseBlock.h +408 -477
  327. package/eigen/Eigen/src/SparseCore/SparseColEtree.h +100 -112
  328. package/eigen/Eigen/src/SparseCore/SparseCompressedBase.h +531 -280
  329. package/eigen/Eigen/src/SparseCore/SparseCwiseBinaryOp.h +559 -347
  330. package/eigen/Eigen/src/SparseCore/SparseCwiseUnaryOp.h +100 -108
  331. package/eigen/Eigen/src/SparseCore/SparseDenseProduct.h +185 -191
  332. package/eigen/Eigen/src/SparseCore/SparseDiagonalProduct.h +71 -71
  333. package/eigen/Eigen/src/SparseCore/SparseDot.h +49 -47
  334. package/eigen/Eigen/src/SparseCore/SparseFuzzy.h +13 -11
  335. package/eigen/Eigen/src/SparseCore/SparseMap.h +243 -253
  336. package/eigen/Eigen/src/SparseCore/SparseMatrix.h +1614 -1142
  337. package/eigen/Eigen/src/SparseCore/SparseMatrixBase.h +403 -357
  338. package/eigen/Eigen/src/SparseCore/SparsePermutation.h +186 -115
  339. package/eigen/Eigen/src/SparseCore/SparseProduct.h +100 -91
  340. package/eigen/Eigen/src/SparseCore/SparseRedux.h +22 -24
  341. package/eigen/Eigen/src/SparseCore/SparseRef.h +268 -295
  342. package/eigen/Eigen/src/SparseCore/SparseSelfAdjointView.h +371 -414
  343. package/eigen/Eigen/src/SparseCore/SparseSolverBase.h +78 -87
  344. package/eigen/Eigen/src/SparseCore/SparseSparseProductWithPruning.h +81 -95
  345. package/eigen/Eigen/src/SparseCore/SparseTranspose.h +62 -71
  346. package/eigen/Eigen/src/SparseCore/SparseTriangularView.h +132 -144
  347. package/eigen/Eigen/src/SparseCore/SparseUtil.h +146 -115
  348. package/eigen/Eigen/src/SparseCore/SparseVector.h +426 -372
  349. package/eigen/Eigen/src/SparseCore/SparseView.h +164 -193
  350. package/eigen/Eigen/src/SparseCore/TriangularSolver.h +129 -170
  351. package/eigen/Eigen/src/SparseLU/InternalHeaderCheck.h +3 -0
  352. package/eigen/Eigen/src/SparseLU/SparseLU.h +814 -618
  353. package/eigen/Eigen/src/SparseLU/SparseLUImpl.h +61 -48
  354. package/eigen/Eigen/src/SparseLU/SparseLU_Memory.h +102 -118
  355. package/eigen/Eigen/src/SparseLU/SparseLU_Structs.h +38 -35
  356. package/eigen/Eigen/src/SparseLU/SparseLU_SupernodalMatrix.h +273 -255
  357. package/eigen/Eigen/src/SparseLU/SparseLU_Utils.h +44 -49
  358. package/eigen/Eigen/src/SparseLU/SparseLU_column_bmod.h +104 -108
  359. package/eigen/Eigen/src/SparseLU/SparseLU_column_dfs.h +90 -101
  360. package/eigen/Eigen/src/SparseLU/SparseLU_copy_to_ucol.h +57 -58
  361. package/eigen/Eigen/src/SparseLU/SparseLU_heap_relax_snode.h +43 -55
  362. package/eigen/Eigen/src/SparseLU/SparseLU_kernel_bmod.h +74 -71
  363. package/eigen/Eigen/src/SparseLU/SparseLU_panel_bmod.h +125 -133
  364. package/eigen/Eigen/src/SparseLU/SparseLU_panel_dfs.h +136 -159
  365. package/eigen/Eigen/src/SparseLU/SparseLU_pivotL.h +51 -52
  366. package/eigen/Eigen/src/SparseLU/SparseLU_pruneL.h +67 -73
  367. package/eigen/Eigen/src/SparseLU/SparseLU_relax_snode.h +24 -26
  368. package/eigen/Eigen/src/SparseQR/InternalHeaderCheck.h +3 -0
  369. package/eigen/Eigen/src/SparseQR/SparseQR.h +451 -490
  370. package/eigen/Eigen/src/StlSupport/StdDeque.h +28 -105
  371. package/eigen/Eigen/src/StlSupport/StdList.h +28 -84
  372. package/eigen/Eigen/src/StlSupport/StdVector.h +28 -108
  373. package/eigen/Eigen/src/StlSupport/details.h +48 -50
  374. package/eigen/Eigen/src/SuperLUSupport/InternalHeaderCheck.h +3 -0
  375. package/eigen/Eigen/src/SuperLUSupport/SuperLUSupport.h +634 -732
  376. package/eigen/Eigen/src/ThreadPool/Barrier.h +70 -0
  377. package/eigen/Eigen/src/ThreadPool/CoreThreadPoolDevice.h +336 -0
  378. package/eigen/Eigen/src/ThreadPool/EventCount.h +241 -0
  379. package/eigen/Eigen/src/ThreadPool/ForkJoin.h +140 -0
  380. package/eigen/Eigen/src/ThreadPool/InternalHeaderCheck.h +4 -0
  381. package/eigen/Eigen/src/ThreadPool/NonBlockingThreadPool.h +587 -0
  382. package/eigen/Eigen/src/ThreadPool/RunQueue.h +230 -0
  383. package/eigen/Eigen/src/ThreadPool/ThreadCancel.h +21 -0
  384. package/eigen/Eigen/src/ThreadPool/ThreadEnvironment.h +43 -0
  385. package/eigen/Eigen/src/ThreadPool/ThreadLocal.h +289 -0
  386. package/eigen/Eigen/src/ThreadPool/ThreadPoolInterface.h +50 -0
  387. package/eigen/Eigen/src/ThreadPool/ThreadYield.h +16 -0
  388. package/eigen/Eigen/src/UmfPackSupport/InternalHeaderCheck.h +3 -0
  389. package/eigen/Eigen/src/UmfPackSupport/UmfPackSupport.h +480 -380
  390. package/eigen/Eigen/src/misc/Image.h +41 -43
  391. package/eigen/Eigen/src/misc/InternalHeaderCheck.h +3 -0
  392. package/eigen/Eigen/src/misc/Kernel.h +39 -41
  393. package/eigen/Eigen/src/misc/RealSvd2x2.h +19 -21
  394. package/eigen/Eigen/src/misc/blas.h +83 -426
  395. package/eigen/Eigen/src/misc/lapacke.h +9976 -16182
  396. package/eigen/Eigen/src/misc/lapacke_helpers.h +163 -0
  397. package/eigen/Eigen/src/misc/lapacke_mangling.h +4 -5
  398. package/eigen/Eigen/src/plugins/ArrayCwiseBinaryOps.inc +344 -0
  399. package/eigen/Eigen/src/plugins/ArrayCwiseUnaryOps.inc +544 -0
  400. package/eigen/Eigen/src/plugins/BlockMethods.inc +1370 -0
  401. package/eigen/Eigen/src/plugins/CommonCwiseBinaryOps.inc +116 -0
  402. package/eigen/Eigen/src/plugins/CommonCwiseUnaryOps.inc +167 -0
  403. package/eigen/Eigen/src/plugins/IndexedViewMethods.inc +192 -0
  404. package/eigen/Eigen/src/plugins/InternalHeaderCheck.inc +3 -0
  405. package/eigen/Eigen/src/plugins/MatrixCwiseBinaryOps.inc +331 -0
  406. package/eigen/Eigen/src/plugins/MatrixCwiseUnaryOps.inc +118 -0
  407. package/eigen/Eigen/src/plugins/ReshapedMethods.inc +133 -0
  408. package/lib/LibEigen.d.ts +4 -0
  409. package/lib/LibEigen.js +14 -0
  410. package/lib/index.d.ts +1 -1
  411. package/lib/index.js +7 -3
  412. package/package.json +2 -10
  413. package/eigen/Eigen/CMakeLists.txt +0 -19
  414. package/eigen/Eigen/src/Core/BooleanRedux.h +0 -164
  415. package/eigen/Eigen/src/Core/arch/CUDA/Complex.h +0 -103
  416. package/eigen/Eigen/src/Core/arch/CUDA/Half.h +0 -675
  417. package/eigen/Eigen/src/Core/arch/CUDA/MathFunctions.h +0 -91
  418. package/eigen/Eigen/src/Core/arch/CUDA/PacketMath.h +0 -333
  419. package/eigen/Eigen/src/Core/arch/CUDA/PacketMathHalf.h +0 -1124
  420. package/eigen/Eigen/src/Core/arch/CUDA/TypeCasting.h +0 -212
  421. package/eigen/Eigen/src/Core/util/NonMPL2.h +0 -3
  422. package/eigen/Eigen/src/Geometry/arch/Geometry_SSE.h +0 -161
  423. package/eigen/Eigen/src/LU/arch/Inverse_SSE.h +0 -338
  424. package/eigen/Eigen/src/SparseCore/MappedSparseMatrix.h +0 -67
  425. package/eigen/Eigen/src/SparseLU/SparseLU_gemm_kernel.h +0 -280
  426. package/eigen/Eigen/src/misc/lapack.h +0 -152
  427. package/eigen/Eigen/src/plugins/ArrayCwiseBinaryOps.h +0 -332
  428. package/eigen/Eigen/src/plugins/ArrayCwiseUnaryOps.h +0 -552
  429. package/eigen/Eigen/src/plugins/BlockMethods.h +0 -1058
  430. package/eigen/Eigen/src/plugins/CommonCwiseBinaryOps.h +0 -115
  431. package/eigen/Eigen/src/plugins/CommonCwiseUnaryOps.h +0 -163
  432. package/eigen/Eigen/src/plugins/MatrixCwiseBinaryOps.h +0 -152
  433. package/eigen/Eigen/src/plugins/MatrixCwiseUnaryOps.h +0 -85
  434. package/lib/eigen.d.ts +0 -2
  435. package/lib/eigen.js +0 -15
@@ -11,6 +11,9 @@
11
11
  #ifndef EIGEN_MATRIXBASE_H
12
12
  #define EIGEN_MATRIXBASE_H
13
13
 
14
+ // IWYU pragma: private
15
+ #include "./InternalHeaderCheck.h"
16
+
14
17
  namespace Eigen {
15
18
 
16
19
  /** \class MatrixBase
@@ -45,486 +48,498 @@ namespace Eigen {
45
48
  *
46
49
  * \sa \blank \ref TopicClassHierarchy
47
50
  */
48
- template<typename Derived> class MatrixBase
49
- : public DenseBase<Derived>
50
- {
51
- public:
51
+ template <typename Derived>
52
+ class MatrixBase : public DenseBase<Derived> {
53
+ public:
52
54
  #ifndef EIGEN_PARSED_BY_DOXYGEN
53
- typedef MatrixBase StorageBaseType;
54
- typedef typename internal::traits<Derived>::StorageKind StorageKind;
55
- typedef typename internal::traits<Derived>::StorageIndex StorageIndex;
56
- typedef typename internal::traits<Derived>::Scalar Scalar;
57
- typedef typename internal::packet_traits<Scalar>::type PacketScalar;
58
- typedef typename NumTraits<Scalar>::Real RealScalar;
59
-
60
- typedef DenseBase<Derived> Base;
61
- using Base::RowsAtCompileTime;
62
- using Base::ColsAtCompileTime;
63
- using Base::SizeAtCompileTime;
64
- using Base::MaxRowsAtCompileTime;
65
- using Base::MaxColsAtCompileTime;
66
- using Base::MaxSizeAtCompileTime;
67
- using Base::IsVectorAtCompileTime;
68
- using Base::Flags;
69
-
70
- using Base::derived;
71
- using Base::const_cast_derived;
72
- using Base::rows;
73
- using Base::cols;
74
- using Base::size;
75
- using Base::coeff;
76
- using Base::coeffRef;
77
- using Base::lazyAssign;
78
- using Base::eval;
79
- using Base::operator+=;
80
- using Base::operator-=;
81
- using Base::operator*=;
82
- using Base::operator/=;
83
-
84
- typedef typename Base::CoeffReturnType CoeffReturnType;
85
- typedef typename Base::ConstTransposeReturnType ConstTransposeReturnType;
86
- typedef typename Base::RowXpr RowXpr;
87
- typedef typename Base::ColXpr ColXpr;
88
- #endif // not EIGEN_PARSED_BY_DOXYGEN
89
-
90
-
55
+ typedef MatrixBase StorageBaseType;
56
+ typedef typename internal::traits<Derived>::StorageKind StorageKind;
57
+ typedef typename internal::traits<Derived>::StorageIndex StorageIndex;
58
+ typedef typename internal::traits<Derived>::Scalar Scalar;
59
+ typedef typename internal::packet_traits<Scalar>::type PacketScalar;
60
+ typedef typename NumTraits<Scalar>::Real RealScalar;
61
+
62
+ typedef DenseBase<Derived> Base;
63
+ using Base::ColsAtCompileTime;
64
+ using Base::Flags;
65
+ using Base::IsVectorAtCompileTime;
66
+ using Base::MaxColsAtCompileTime;
67
+ using Base::MaxRowsAtCompileTime;
68
+ using Base::MaxSizeAtCompileTime;
69
+ using Base::RowsAtCompileTime;
70
+ using Base::SizeAtCompileTime;
71
+
72
+ using Base::coeff;
73
+ using Base::coeffRef;
74
+ using Base::cols;
75
+ using Base::const_cast_derived;
76
+ using Base::derived;
77
+ using Base::eval;
78
+ using Base::lazyAssign;
79
+ using Base::rows;
80
+ using Base::size;
81
+ using Base::operator-;
82
+ using Base::operator+=;
83
+ using Base::operator-=;
84
+ using Base::operator*=;
85
+ using Base::operator/=;
86
+
87
+ typedef typename Base::CoeffReturnType CoeffReturnType;
88
+ typedef typename Base::ConstTransposeReturnType ConstTransposeReturnType;
89
+ typedef typename Base::RowXpr RowXpr;
90
+ typedef typename Base::ColXpr ColXpr;
91
+ #endif // not EIGEN_PARSED_BY_DOXYGEN
91
92
 
92
93
  #ifndef EIGEN_PARSED_BY_DOXYGEN
93
- /** type of the equivalent square matrix */
94
- typedef Matrix<Scalar,EIGEN_SIZE_MAX(RowsAtCompileTime,ColsAtCompileTime),
95
- EIGEN_SIZE_MAX(RowsAtCompileTime,ColsAtCompileTime)> SquareMatrixType;
96
- #endif // not EIGEN_PARSED_BY_DOXYGEN
94
+ /** type of the equivalent square matrix */
95
+ typedef Matrix<Scalar, internal::max_size_prefer_dynamic(RowsAtCompileTime, ColsAtCompileTime),
96
+ internal::max_size_prefer_dynamic(RowsAtCompileTime, ColsAtCompileTime)>
97
+ SquareMatrixType;
98
+ #endif // not EIGEN_PARSED_BY_DOXYGEN
97
99
 
98
- /** \returns the size of the main diagonal, which is min(rows(),cols()).
99
- * \sa rows(), cols(), SizeAtCompileTime. */
100
- EIGEN_DEVICE_FUNC
101
- inline Index diagonalSize() const { return (numext::mini)(rows(),cols()); }
100
+ /** \returns the size of the main diagonal, which is min(rows(),cols()).
101
+ * \sa rows(), cols(), SizeAtCompileTime. */
102
+ EIGEN_DEVICE_FUNC inline Index diagonalSize() const { return (numext::mini)(rows(), cols()); }
102
103
 
103
- typedef typename Base::PlainObject PlainObject;
104
+ typedef typename Base::PlainObject PlainObject;
104
105
 
105
106
  #ifndef EIGEN_PARSED_BY_DOXYGEN
106
- /** \internal Represents a matrix with all coefficients equal to one another*/
107
- typedef CwiseNullaryOp<internal::scalar_constant_op<Scalar>,PlainObject> ConstantReturnType;
108
- /** \internal the return type of MatrixBase::adjoint() */
109
- typedef typename internal::conditional<NumTraits<Scalar>::IsComplex,
110
- CwiseUnaryOp<internal::scalar_conjugate_op<Scalar>, ConstTransposeReturnType>,
111
- ConstTransposeReturnType
112
- >::type AdjointReturnType;
113
- /** \internal Return type of eigenvalues() */
114
- typedef Matrix<std::complex<RealScalar>, internal::traits<Derived>::ColsAtCompileTime, 1, ColMajor> EigenvaluesReturnType;
115
- /** \internal the return type of identity */
116
- typedef CwiseNullaryOp<internal::scalar_identity_op<Scalar>,PlainObject> IdentityReturnType;
117
- /** \internal the return type of unit vectors */
118
- typedef Block<const CwiseNullaryOp<internal::scalar_identity_op<Scalar>, SquareMatrixType>,
119
- internal::traits<Derived>::RowsAtCompileTime,
120
- internal::traits<Derived>::ColsAtCompileTime> BasisReturnType;
121
- #endif // not EIGEN_PARSED_BY_DOXYGEN
107
+ /** \internal Represents a matrix with all coefficients equal to one another*/
108
+ typedef CwiseNullaryOp<internal::scalar_constant_op<Scalar>, PlainObject> ConstantReturnType;
109
+ /** \internal the return type of MatrixBase::adjoint() */
110
+ typedef std::conditional_t<NumTraits<Scalar>::IsComplex,
111
+ CwiseUnaryOp<internal::scalar_conjugate_op<Scalar>, ConstTransposeReturnType>,
112
+ ConstTransposeReturnType>
113
+ AdjointReturnType;
114
+ /** \internal Return type of eigenvalues() */
115
+ typedef Matrix<internal::make_complex_t<Scalar>, internal::traits<Derived>::ColsAtCompileTime, 1, ColMajor>
116
+ EigenvaluesReturnType;
117
+ /** \internal the return type of identity */
118
+ typedef CwiseNullaryOp<internal::scalar_identity_op<Scalar>, PlainObject> IdentityReturnType;
119
+ /** \internal the return type of unit vectors */
120
+ typedef Block<const CwiseNullaryOp<internal::scalar_identity_op<Scalar>, SquareMatrixType>,
121
+ internal::traits<Derived>::RowsAtCompileTime, internal::traits<Derived>::ColsAtCompileTime>
122
+ BasisReturnType;
123
+ #endif // not EIGEN_PARSED_BY_DOXYGEN
122
124
 
123
125
  #define EIGEN_CURRENT_STORAGE_BASE_CLASS Eigen::MatrixBase
124
- #define EIGEN_DOC_UNARY_ADDONS(X,Y)
125
- # include "../plugins/CommonCwiseUnaryOps.h"
126
- # include "../plugins/CommonCwiseBinaryOps.h"
127
- # include "../plugins/MatrixCwiseUnaryOps.h"
128
- # include "../plugins/MatrixCwiseBinaryOps.h"
129
- # ifdef EIGEN_MATRIXBASE_PLUGIN
130
- # include EIGEN_MATRIXBASE_PLUGIN
131
- # endif
126
+ #define EIGEN_DOC_UNARY_ADDONS(X, Y)
127
+ #include "../plugins/CommonCwiseBinaryOps.inc"
128
+ #include "../plugins/MatrixCwiseUnaryOps.inc"
129
+ #include "../plugins/MatrixCwiseBinaryOps.inc"
130
+ #ifdef EIGEN_MATRIXBASE_PLUGIN
131
+ #include EIGEN_MATRIXBASE_PLUGIN
132
+ #endif
132
133
  #undef EIGEN_CURRENT_STORAGE_BASE_CLASS
133
134
  #undef EIGEN_DOC_UNARY_ADDONS
134
135
 
135
- /** Special case of the template operator=, in order to prevent the compiler
136
- * from generating a default operator= (issue hit with g++ 4.1)
137
- */
138
- EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE
139
- Derived& operator=(const MatrixBase& other);
140
-
141
- // We cannot inherit here via Base::operator= since it is causing
142
- // trouble with MSVC.
143
-
144
- template <typename OtherDerived>
145
- EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE
146
- Derived& operator=(const DenseBase<OtherDerived>& other);
147
-
148
- template <typename OtherDerived>
149
- EIGEN_DEVICE_FUNC
150
- Derived& operator=(const EigenBase<OtherDerived>& other);
151
-
152
- template<typename OtherDerived>
153
- EIGEN_DEVICE_FUNC
154
- Derived& operator=(const ReturnByValue<OtherDerived>& other);
155
-
156
- template<typename OtherDerived>
157
- EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE
158
- Derived& operator+=(const MatrixBase<OtherDerived>& other);
159
- template<typename OtherDerived>
160
- EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE
161
- Derived& operator-=(const MatrixBase<OtherDerived>& other);
162
-
163
- template<typename OtherDerived>
164
- EIGEN_DEVICE_FUNC
165
- const Product<Derived,OtherDerived>
166
- operator*(const MatrixBase<OtherDerived> &other) const;
167
-
168
- template<typename OtherDerived>
169
- EIGEN_DEVICE_FUNC
170
- const Product<Derived,OtherDerived,LazyProduct>
171
- lazyProduct(const MatrixBase<OtherDerived> &other) const;
172
-
173
- template<typename OtherDerived>
174
- Derived& operator*=(const EigenBase<OtherDerived>& other);
175
-
176
- template<typename OtherDerived>
177
- void applyOnTheLeft(const EigenBase<OtherDerived>& other);
178
-
179
- template<typename OtherDerived>
180
- void applyOnTheRight(const EigenBase<OtherDerived>& other);
181
-
182
- template<typename DiagonalDerived>
183
- EIGEN_DEVICE_FUNC
184
- const Product<Derived, DiagonalDerived, LazyProduct>
185
- operator*(const DiagonalBase<DiagonalDerived> &diagonal) const;
186
-
187
- template<typename OtherDerived>
188
- EIGEN_DEVICE_FUNC
189
- typename ScalarBinaryOpTraits<typename internal::traits<Derived>::Scalar,typename internal::traits<OtherDerived>::Scalar>::ReturnType
190
- dot(const MatrixBase<OtherDerived>& other) const;
191
-
192
- EIGEN_DEVICE_FUNC RealScalar squaredNorm() const;
193
- EIGEN_DEVICE_FUNC RealScalar norm() const;
194
- RealScalar stableNorm() const;
195
- RealScalar blueNorm() const;
196
- RealScalar hypotNorm() const;
197
- EIGEN_DEVICE_FUNC const PlainObject normalized() const;
198
- EIGEN_DEVICE_FUNC const PlainObject stableNormalized() const;
199
- EIGEN_DEVICE_FUNC void normalize();
200
- EIGEN_DEVICE_FUNC void stableNormalize();
201
-
202
- EIGEN_DEVICE_FUNC const AdjointReturnType adjoint() const;
203
- EIGEN_DEVICE_FUNC void adjointInPlace();
204
-
205
- typedef Diagonal<Derived> DiagonalReturnType;
206
- EIGEN_DEVICE_FUNC
207
- DiagonalReturnType diagonal();
208
-
209
- typedef typename internal::add_const<Diagonal<const Derived> >::type ConstDiagonalReturnType;
210
- EIGEN_DEVICE_FUNC
211
- ConstDiagonalReturnType diagonal() const;
212
-
213
- template<int Index> struct DiagonalIndexReturnType { typedef Diagonal<Derived,Index> Type; };
214
- template<int Index> struct ConstDiagonalIndexReturnType { typedef const Diagonal<const Derived,Index> Type; };
215
-
216
- template<int Index>
217
- EIGEN_DEVICE_FUNC
218
- typename DiagonalIndexReturnType<Index>::Type diagonal();
219
-
220
- template<int Index>
221
- EIGEN_DEVICE_FUNC
222
- typename ConstDiagonalIndexReturnType<Index>::Type diagonal() const;
223
-
224
- typedef Diagonal<Derived,DynamicIndex> DiagonalDynamicIndexReturnType;
225
- typedef typename internal::add_const<Diagonal<const Derived,DynamicIndex> >::type ConstDiagonalDynamicIndexReturnType;
226
-
227
- EIGEN_DEVICE_FUNC
228
- DiagonalDynamicIndexReturnType diagonal(Index index);
229
- EIGEN_DEVICE_FUNC
230
- ConstDiagonalDynamicIndexReturnType diagonal(Index index) const;
231
-
232
- template<unsigned int Mode> struct TriangularViewReturnType { typedef TriangularView<Derived, Mode> Type; };
233
- template<unsigned int Mode> struct ConstTriangularViewReturnType { typedef const TriangularView<const Derived, Mode> Type; };
234
-
235
- template<unsigned int Mode>
236
- EIGEN_DEVICE_FUNC
237
- typename TriangularViewReturnType<Mode>::Type triangularView();
238
- template<unsigned int Mode>
239
- EIGEN_DEVICE_FUNC
240
- typename ConstTriangularViewReturnType<Mode>::Type triangularView() const;
241
-
242
- template<unsigned int UpLo> struct SelfAdjointViewReturnType { typedef SelfAdjointView<Derived, UpLo> Type; };
243
- template<unsigned int UpLo> struct ConstSelfAdjointViewReturnType { typedef const SelfAdjointView<const Derived, UpLo> Type; };
244
-
245
- template<unsigned int UpLo>
246
- EIGEN_DEVICE_FUNC
247
- typename SelfAdjointViewReturnType<UpLo>::Type selfadjointView();
248
- template<unsigned int UpLo>
249
- EIGEN_DEVICE_FUNC
250
- typename ConstSelfAdjointViewReturnType<UpLo>::Type selfadjointView() const;
251
-
252
- const SparseView<Derived> sparseView(const Scalar& m_reference = Scalar(0),
253
- const typename NumTraits<Scalar>::Real& m_epsilon = NumTraits<Scalar>::dummy_precision()) const;
254
- EIGEN_DEVICE_FUNC static const IdentityReturnType Identity();
255
- EIGEN_DEVICE_FUNC static const IdentityReturnType Identity(Index rows, Index cols);
256
- EIGEN_DEVICE_FUNC static const BasisReturnType Unit(Index size, Index i);
257
- EIGEN_DEVICE_FUNC static const BasisReturnType Unit(Index i);
258
- EIGEN_DEVICE_FUNC static const BasisReturnType UnitX();
259
- EIGEN_DEVICE_FUNC static const BasisReturnType UnitY();
260
- EIGEN_DEVICE_FUNC static const BasisReturnType UnitZ();
261
- EIGEN_DEVICE_FUNC static const BasisReturnType UnitW();
262
-
263
- EIGEN_DEVICE_FUNC
264
- const DiagonalWrapper<const Derived> asDiagonal() const;
265
- const PermutationWrapper<const Derived> asPermutation() const;
266
-
267
- EIGEN_DEVICE_FUNC
268
- Derived& setIdentity();
269
- EIGEN_DEVICE_FUNC
270
- Derived& setIdentity(Index rows, Index cols);
271
-
272
- bool isIdentity(const RealScalar& prec = NumTraits<Scalar>::dummy_precision()) const;
273
- bool isDiagonal(const RealScalar& prec = NumTraits<Scalar>::dummy_precision()) const;
274
-
275
- bool isUpperTriangular(const RealScalar& prec = NumTraits<Scalar>::dummy_precision()) const;
276
- bool isLowerTriangular(const RealScalar& prec = NumTraits<Scalar>::dummy_precision()) const;
277
-
278
- template<typename OtherDerived>
279
- bool isOrthogonal(const MatrixBase<OtherDerived>& other,
280
- const RealScalar& prec = NumTraits<Scalar>::dummy_precision()) const;
281
- bool isUnitary(const RealScalar& prec = NumTraits<Scalar>::dummy_precision()) const;
282
-
283
- /** \returns true if each coefficients of \c *this and \a other are all exactly equal.
284
- * \warning When using floating point scalar values you probably should rather use a
285
- * fuzzy comparison such as isApprox()
286
- * \sa isApprox(), operator!= */
287
- template<typename OtherDerived>
288
- EIGEN_DEVICE_FUNC inline bool operator==(const MatrixBase<OtherDerived>& other) const
289
- { return cwiseEqual(other).all(); }
290
-
291
- /** \returns true if at least one pair of coefficients of \c *this and \a other are not exactly equal to each other.
292
- * \warning When using floating point scalar values you probably should rather use a
293
- * fuzzy comparison such as isApprox()
294
- * \sa isApprox(), operator== */
295
- template<typename OtherDerived>
296
- EIGEN_DEVICE_FUNC inline bool operator!=(const MatrixBase<OtherDerived>& other) const
297
- { return cwiseNotEqual(other).any(); }
298
-
299
- NoAlias<Derived,Eigen::MatrixBase > noalias();
300
-
301
- // TODO forceAlignedAccess is temporarily disabled
302
- // Need to find a nicer workaround.
303
- inline const Derived& forceAlignedAccess() const { return derived(); }
304
- inline Derived& forceAlignedAccess() { return derived(); }
305
- template<bool Enable> inline const Derived& forceAlignedAccessIf() const { return derived(); }
306
- template<bool Enable> inline Derived& forceAlignedAccessIf() { return derived(); }
307
-
308
- EIGEN_DEVICE_FUNC Scalar trace() const;
309
-
310
- template<int p> EIGEN_DEVICE_FUNC RealScalar lpNorm() const;
311
-
312
- EIGEN_DEVICE_FUNC MatrixBase<Derived>& matrix() { return *this; }
313
- EIGEN_DEVICE_FUNC const MatrixBase<Derived>& matrix() const { return *this; }
314
-
315
- /** \returns an \link Eigen::ArrayBase Array \endlink expression of this matrix
316
- * \sa ArrayBase::matrix() */
317
- EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE ArrayWrapper<Derived> array() { return ArrayWrapper<Derived>(derived()); }
318
- /** \returns a const \link Eigen::ArrayBase Array \endlink expression of this matrix
319
- * \sa ArrayBase::matrix() */
320
- EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const ArrayWrapper<const Derived> array() const { return ArrayWrapper<const Derived>(derived()); }
321
-
322
- /////////// LU module ///////////
323
-
324
- inline const FullPivLU<PlainObject> fullPivLu() const;
325
- inline const PartialPivLU<PlainObject> partialPivLu() const;
326
-
327
- inline const PartialPivLU<PlainObject> lu() const;
328
-
329
- inline const Inverse<Derived> inverse() const;
330
-
331
- template<typename ResultType>
332
- inline void computeInverseAndDetWithCheck(
333
- ResultType& inverse,
334
- typename ResultType::Scalar& determinant,
335
- bool& invertible,
336
- const RealScalar& absDeterminantThreshold = NumTraits<Scalar>::dummy_precision()
337
- ) const;
338
- template<typename ResultType>
339
- inline void computeInverseWithCheck(
340
- ResultType& inverse,
341
- bool& invertible,
342
- const RealScalar& absDeterminantThreshold = NumTraits<Scalar>::dummy_precision()
343
- ) const;
344
- Scalar determinant() const;
345
-
346
- /////////// Cholesky module ///////////
347
-
348
- inline const LLT<PlainObject> llt() const;
349
- inline const LDLT<PlainObject> ldlt() const;
350
-
351
- /////////// QR module ///////////
352
-
353
- inline const HouseholderQR<PlainObject> householderQr() const;
354
- inline const ColPivHouseholderQR<PlainObject> colPivHouseholderQr() const;
355
- inline const FullPivHouseholderQR<PlainObject> fullPivHouseholderQr() const;
356
- inline const CompleteOrthogonalDecomposition<PlainObject> completeOrthogonalDecomposition() const;
357
-
358
- /////////// Eigenvalues module ///////////
359
-
360
- inline EigenvaluesReturnType eigenvalues() const;
361
- inline RealScalar operatorNorm() const;
362
-
363
- /////////// SVD module ///////////
364
-
365
- inline JacobiSVD<PlainObject> jacobiSvd(unsigned int computationOptions = 0) const;
366
- inline BDCSVD<PlainObject> bdcSvd(unsigned int computationOptions = 0) const;
367
-
368
- /////////// Geometry module ///////////
369
-
370
- #ifndef EIGEN_PARSED_BY_DOXYGEN
371
- /// \internal helper struct to form the return type of the cross product
372
- template<typename OtherDerived> struct cross_product_return_type {
373
- typedef typename ScalarBinaryOpTraits<typename internal::traits<Derived>::Scalar,typename internal::traits<OtherDerived>::Scalar>::ReturnType Scalar;
374
- typedef Matrix<Scalar,MatrixBase::RowsAtCompileTime,MatrixBase::ColsAtCompileTime> type;
375
- };
376
- #endif // EIGEN_PARSED_BY_DOXYGEN
377
- template<typename OtherDerived>
378
- EIGEN_DEVICE_FUNC
379
- #ifndef EIGEN_PARSED_BY_DOXYGEN
380
- inline typename cross_product_return_type<OtherDerived>::type
381
- #else
382
- inline PlainObject
383
- #endif
384
- cross(const MatrixBase<OtherDerived>& other) const;
385
-
386
- template<typename OtherDerived>
387
- EIGEN_DEVICE_FUNC
388
- inline PlainObject cross3(const MatrixBase<OtherDerived>& other) const;
389
-
390
- EIGEN_DEVICE_FUNC
391
- inline PlainObject unitOrthogonal(void) const;
392
-
393
- EIGEN_DEVICE_FUNC
394
- inline Matrix<Scalar,3,1> eulerAngles(Index a0, Index a1, Index a2) const;
395
-
396
- // put this as separate enum value to work around possible GCC 4.3 bug (?)
397
- enum { HomogeneousReturnTypeDirection = ColsAtCompileTime==1&&RowsAtCompileTime==1 ? ((internal::traits<Derived>::Flags&RowMajorBit)==RowMajorBit ? Horizontal : Vertical)
398
- : ColsAtCompileTime==1 ? Vertical : Horizontal };
399
- typedef Homogeneous<Derived, HomogeneousReturnTypeDirection> HomogeneousReturnType;
400
- EIGEN_DEVICE_FUNC
401
- inline HomogeneousReturnType homogeneous() const;
402
-
403
- enum {
404
- SizeMinusOne = SizeAtCompileTime==Dynamic ? Dynamic : SizeAtCompileTime-1
405
- };
406
- typedef Block<const Derived,
407
- internal::traits<Derived>::ColsAtCompileTime==1 ? SizeMinusOne : 1,
408
- internal::traits<Derived>::ColsAtCompileTime==1 ? 1 : SizeMinusOne> ConstStartMinusOne;
409
- typedef EIGEN_EXPR_BINARYOP_SCALAR_RETURN_TYPE(ConstStartMinusOne,Scalar,quotient) HNormalizedReturnType;
410
- EIGEN_DEVICE_FUNC
411
- inline const HNormalizedReturnType hnormalized() const;
412
-
413
- ////////// Householder module ///////////
414
-
415
- void makeHouseholderInPlace(Scalar& tau, RealScalar& beta);
416
- template<typename EssentialPart>
417
- void makeHouseholder(EssentialPart& essential,
418
- Scalar& tau, RealScalar& beta) const;
419
- template<typename EssentialPart>
420
- void applyHouseholderOnTheLeft(const EssentialPart& essential,
421
- const Scalar& tau,
422
- Scalar* workspace);
423
- template<typename EssentialPart>
424
- void applyHouseholderOnTheRight(const EssentialPart& essential,
425
- const Scalar& tau,
426
- Scalar* workspace);
427
-
428
- ///////// Jacobi module /////////
429
-
430
- template<typename OtherScalar>
431
- void applyOnTheLeft(Index p, Index q, const JacobiRotation<OtherScalar>& j);
432
- template<typename OtherScalar>
433
- void applyOnTheRight(Index p, Index q, const JacobiRotation<OtherScalar>& j);
434
-
435
- ///////// SparseCore module /////////
436
-
437
- template<typename OtherDerived>
438
- EIGEN_STRONG_INLINE const typename SparseMatrixBase<OtherDerived>::template CwiseProductDenseReturnType<Derived>::Type
439
- cwiseProduct(const SparseMatrixBase<OtherDerived> &other) const
440
- {
441
- return other.cwiseProduct(derived());
442
- }
443
-
444
- ///////// MatrixFunctions module /////////
445
-
446
- typedef typename internal::stem_function<Scalar>::type StemFunction;
447
- #define EIGEN_MATRIX_FUNCTION(ReturnType, Name, Description) \
448
- /** \returns an expression of the matrix Description of \c *this. \brief This function requires the <a href="unsupported/group__MatrixFunctions__Module.html"> unsupported MatrixFunctions module</a>. To compute the coefficient-wise Description use ArrayBase::##Name . */ \
449
- const ReturnType<Derived> Name() const;
450
- #define EIGEN_MATRIX_FUNCTION_1(ReturnType, Name, Description, Argument) \
451
- /** \returns an expression of the matrix Description of \c *this. \brief This function requires the <a href="unsupported/group__MatrixFunctions__Module.html"> unsupported MatrixFunctions module</a>. To compute the coefficient-wise Description use ArrayBase::##Name . */ \
452
- const ReturnType<Derived> Name(Argument) const;
453
-
454
- EIGEN_MATRIX_FUNCTION(MatrixExponentialReturnValue, exp, exponential)
455
- /** \brief Helper function for the <a href="unsupported/group__MatrixFunctions__Module.html"> unsupported MatrixFunctions module</a>.*/
456
- const MatrixFunctionReturnValue<Derived> matrixFunction(StemFunction f) const;
457
- EIGEN_MATRIX_FUNCTION(MatrixFunctionReturnValue, cosh, hyperbolic cosine)
458
- EIGEN_MATRIX_FUNCTION(MatrixFunctionReturnValue, sinh, hyperbolic sine)
459
- EIGEN_MATRIX_FUNCTION(MatrixFunctionReturnValue, cos, cosine)
460
- EIGEN_MATRIX_FUNCTION(MatrixFunctionReturnValue, sin, sine)
461
- EIGEN_MATRIX_FUNCTION(MatrixSquareRootReturnValue, sqrt, square root)
462
- EIGEN_MATRIX_FUNCTION(MatrixLogarithmReturnValue, log, logarithm)
463
- EIGEN_MATRIX_FUNCTION_1(MatrixPowerReturnValue, pow, power to \c p, const RealScalar& p)
464
- EIGEN_MATRIX_FUNCTION_1(MatrixComplexPowerReturnValue, pow, power to \c p, const std::complex<RealScalar>& p)
465
-
466
- protected:
467
- EIGEN_DEFAULT_COPY_CONSTRUCTOR(MatrixBase)
468
- EIGEN_DEFAULT_EMPTY_CONSTRUCTOR_AND_DESTRUCTOR(MatrixBase)
469
-
470
- private:
471
- EIGEN_DEVICE_FUNC explicit MatrixBase(int);
472
- EIGEN_DEVICE_FUNC MatrixBase(int,int);
473
- template<typename OtherDerived> EIGEN_DEVICE_FUNC explicit MatrixBase(const MatrixBase<OtherDerived>&);
474
- protected:
475
- // mixing arrays and matrices is not legal
476
- template<typename OtherDerived> Derived& operator+=(const ArrayBase<OtherDerived>& )
477
- {EIGEN_STATIC_ASSERT(std::ptrdiff_t(sizeof(typename OtherDerived::Scalar))==-1,YOU_CANNOT_MIX_ARRAYS_AND_MATRICES); return *this;}
478
- // mixing arrays and matrices is not legal
479
- template<typename OtherDerived> Derived& operator-=(const ArrayBase<OtherDerived>& )
480
- {EIGEN_STATIC_ASSERT(std::ptrdiff_t(sizeof(typename OtherDerived::Scalar))==-1,YOU_CANNOT_MIX_ARRAYS_AND_MATRICES); return *this;}
136
+ /** Special case of the template operator=, in order to prevent the compiler
137
+ * from generating a default operator= (issue hit with g++ 4.1)
138
+ */
139
+ EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Derived& operator=(const MatrixBase& other);
140
+
141
+ // We cannot inherit here via Base::operator= since it is causing
142
+ // trouble with MSVC.
143
+
144
+ template <typename OtherDerived>
145
+ EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Derived& operator=(const DenseBase<OtherDerived>& other);
146
+
147
+ template <typename OtherDerived>
148
+ EIGEN_DEVICE_FUNC Derived& operator=(const EigenBase<OtherDerived>& other);
149
+
150
+ template <typename OtherDerived>
151
+ EIGEN_DEVICE_FUNC Derived& operator=(const ReturnByValue<OtherDerived>& other);
152
+
153
+ template <typename OtherDerived>
154
+ EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Derived& operator+=(const MatrixBase<OtherDerived>& other);
155
+ template <typename OtherDerived>
156
+ EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Derived& operator-=(const MatrixBase<OtherDerived>& other);
157
+
158
+ template <typename OtherDerived>
159
+ EIGEN_DEVICE_FUNC const Product<Derived, OtherDerived> operator*(const MatrixBase<OtherDerived>& other) const;
160
+
161
+ template <typename OtherDerived>
162
+ EIGEN_DEVICE_FUNC const Product<Derived, OtherDerived, LazyProduct> lazyProduct(
163
+ const MatrixBase<OtherDerived>& other) const;
164
+
165
+ template <typename OtherDerived>
166
+ Derived& operator*=(const EigenBase<OtherDerived>& other);
167
+
168
+ template <typename OtherDerived>
169
+ void applyOnTheLeft(const EigenBase<OtherDerived>& other);
170
+
171
+ template <typename OtherDerived>
172
+ void applyOnTheRight(const EigenBase<OtherDerived>& other);
173
+
174
+ template <typename DiagonalDerived>
175
+ EIGEN_DEVICE_FUNC const Product<Derived, DiagonalDerived, LazyProduct> operator*(
176
+ const DiagonalBase<DiagonalDerived>& diagonal) const;
177
+
178
+ template <typename SkewDerived>
179
+ EIGEN_DEVICE_FUNC const Product<Derived, SkewDerived, LazyProduct> operator*(
180
+ const SkewSymmetricBase<SkewDerived>& skew) const;
181
+
182
+ template <typename OtherDerived>
183
+ EIGEN_DEVICE_FUNC typename ScalarBinaryOpTraits<typename internal::traits<Derived>::Scalar,
184
+ typename internal::traits<OtherDerived>::Scalar>::ReturnType
185
+ dot(const MatrixBase<OtherDerived>& other) const;
186
+
187
+ EIGEN_DEVICE_FUNC RealScalar squaredNorm() const;
188
+ EIGEN_DEVICE_FUNC RealScalar norm() const;
189
+ RealScalar stableNorm() const;
190
+ RealScalar blueNorm() const;
191
+ RealScalar hypotNorm() const;
192
+ EIGEN_DEVICE_FUNC const PlainObject normalized() const;
193
+ EIGEN_DEVICE_FUNC const PlainObject stableNormalized() const;
194
+ EIGEN_DEVICE_FUNC void normalize();
195
+ EIGEN_DEVICE_FUNC void stableNormalize();
196
+
197
+ EIGEN_DEVICE_FUNC const AdjointReturnType adjoint() const;
198
+ EIGEN_DEVICE_FUNC void adjointInPlace();
199
+
200
+ typedef Diagonal<Derived> DiagonalReturnType;
201
+ EIGEN_DEVICE_FUNC DiagonalReturnType diagonal();
202
+
203
+ typedef Diagonal<const Derived> ConstDiagonalReturnType;
204
+ EIGEN_DEVICE_FUNC const ConstDiagonalReturnType diagonal() const;
205
+
206
+ template <int Index>
207
+ EIGEN_DEVICE_FUNC Diagonal<Derived, Index> diagonal();
208
+
209
+ template <int Index>
210
+ EIGEN_DEVICE_FUNC const Diagonal<const Derived, Index> diagonal() const;
211
+
212
+ EIGEN_DEVICE_FUNC Diagonal<Derived, DynamicIndex> diagonal(Index index);
213
+ EIGEN_DEVICE_FUNC const Diagonal<const Derived, DynamicIndex> diagonal(Index index) const;
214
+
215
+ template <unsigned int Mode>
216
+ struct TriangularViewReturnType {
217
+ typedef TriangularView<Derived, Mode> Type;
218
+ };
219
+ template <unsigned int Mode>
220
+ struct ConstTriangularViewReturnType {
221
+ typedef const TriangularView<const Derived, Mode> Type;
222
+ };
223
+
224
+ template <unsigned int Mode>
225
+ EIGEN_DEVICE_FUNC typename TriangularViewReturnType<Mode>::Type triangularView();
226
+ template <unsigned int Mode>
227
+ EIGEN_DEVICE_FUNC typename ConstTriangularViewReturnType<Mode>::Type triangularView() const;
228
+
229
+ template <unsigned int UpLo>
230
+ struct SelfAdjointViewReturnType {
231
+ typedef SelfAdjointView<Derived, UpLo> Type;
232
+ };
233
+ template <unsigned int UpLo>
234
+ struct ConstSelfAdjointViewReturnType {
235
+ typedef const SelfAdjointView<const Derived, UpLo> Type;
236
+ };
237
+
238
+ template <unsigned int UpLo>
239
+ EIGEN_DEVICE_FUNC typename SelfAdjointViewReturnType<UpLo>::Type selfadjointView();
240
+ template <unsigned int UpLo>
241
+ EIGEN_DEVICE_FUNC typename ConstSelfAdjointViewReturnType<UpLo>::Type selfadjointView() const;
242
+
243
+ const SparseView<Derived> sparseView(
244
+ const Scalar& m_reference = Scalar(0),
245
+ const typename NumTraits<Scalar>::Real& m_epsilon = NumTraits<Scalar>::dummy_precision()) const;
246
+ EIGEN_DEVICE_FUNC static const IdentityReturnType Identity();
247
+ EIGEN_DEVICE_FUNC static const IdentityReturnType Identity(Index rows, Index cols);
248
+ EIGEN_DEVICE_FUNC static const BasisReturnType Unit(Index size, Index i);
249
+ EIGEN_DEVICE_FUNC static const BasisReturnType Unit(Index i);
250
+ EIGEN_DEVICE_FUNC static const BasisReturnType UnitX();
251
+ EIGEN_DEVICE_FUNC static const BasisReturnType UnitY();
252
+ EIGEN_DEVICE_FUNC static const BasisReturnType UnitZ();
253
+ EIGEN_DEVICE_FUNC static const BasisReturnType UnitW();
254
+
255
+ EIGEN_DEVICE_FUNC const DiagonalWrapper<const Derived> asDiagonal() const;
256
+ const PermutationWrapper<const Derived> asPermutation() const;
257
+ EIGEN_DEVICE_FUNC const SkewSymmetricWrapper<const Derived> asSkewSymmetric() const;
258
+
259
+ EIGEN_DEVICE_FUNC Derived& setIdentity();
260
+ EIGEN_DEVICE_FUNC Derived& setIdentity(Index rows, Index cols);
261
+ EIGEN_DEVICE_FUNC Derived& setUnit(Index i);
262
+ EIGEN_DEVICE_FUNC Derived& setUnit(Index newSize, Index i);
263
+
264
+ bool isIdentity(const RealScalar& prec = NumTraits<Scalar>::dummy_precision()) const;
265
+ bool isDiagonal(const RealScalar& prec = NumTraits<Scalar>::dummy_precision()) const;
266
+
267
+ bool isUpperTriangular(const RealScalar& prec = NumTraits<Scalar>::dummy_precision()) const;
268
+ bool isLowerTriangular(const RealScalar& prec = NumTraits<Scalar>::dummy_precision()) const;
269
+
270
+ bool isSkewSymmetric(const RealScalar& prec = NumTraits<Scalar>::dummy_precision()) const;
271
+
272
+ template <typename OtherDerived>
273
+ bool isOrthogonal(const MatrixBase<OtherDerived>& other,
274
+ const RealScalar& prec = NumTraits<Scalar>::dummy_precision()) const;
275
+ bool isUnitary(const RealScalar& prec = NumTraits<Scalar>::dummy_precision()) const;
276
+
277
+ /** \returns true if each coefficients of \c *this and \a other are all exactly equal.
278
+ * \warning When using floating point scalar values you probably should rather use a
279
+ * fuzzy comparison such as isApprox()
280
+ * \sa isApprox(), operator!= */
281
+ template <typename OtherDerived>
282
+ EIGEN_DEVICE_FUNC inline bool operator==(const MatrixBase<OtherDerived>& other) const {
283
+ return (this->rows() == other.rows()) && (this->cols() == other.cols()) && cwiseEqual(other).all();
284
+ }
285
+
286
+ /** \returns true if at least one pair of coefficients of \c *this and \a other are not exactly equal to each other.
287
+ * \warning When using floating point scalar values you probably should rather use a
288
+ * fuzzy comparison such as isApprox()
289
+ * \sa isApprox(), operator== */
290
+ template <typename OtherDerived>
291
+ EIGEN_DEVICE_FUNC inline bool operator!=(const MatrixBase<OtherDerived>& other) const {
292
+ return !(*this == other);
293
+ }
294
+
295
+ NoAlias<Derived, Eigen::MatrixBase> EIGEN_DEVICE_FUNC noalias();
296
+
297
+ // TODO forceAlignedAccess is temporarily disabled
298
+ // Need to find a nicer workaround.
299
+ inline const Derived& forceAlignedAccess() const { return derived(); }
300
+ inline Derived& forceAlignedAccess() { return derived(); }
301
+ template <bool Enable>
302
+ inline const Derived& forceAlignedAccessIf() const {
303
+ return derived();
304
+ }
305
+ template <bool Enable>
306
+ inline Derived& forceAlignedAccessIf() {
307
+ return derived();
308
+ }
309
+
310
+ EIGEN_DEVICE_FUNC Scalar trace() const;
311
+
312
+ template <int p>
313
+ EIGEN_DEVICE_FUNC RealScalar lpNorm() const;
314
+
315
+ EIGEN_DEVICE_FUNC MatrixBase<Derived>& matrix() { return *this; }
316
+ EIGEN_DEVICE_FUNC const MatrixBase<Derived>& matrix() const { return *this; }
317
+
318
+ /** \returns an \link Eigen::ArrayBase Array \endlink expression of this matrix
319
+ * \sa ArrayBase::matrix() */
320
+ EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE ArrayWrapper<Derived> array() { return ArrayWrapper<Derived>(derived()); }
321
+ /** \returns a const \link Eigen::ArrayBase Array \endlink expression of this matrix
322
+ * \sa ArrayBase::matrix() */
323
+ EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const ArrayWrapper<const Derived> array() const {
324
+ return ArrayWrapper<const Derived>(derived());
325
+ }
326
+
327
+ /////////// LU module ///////////
328
+
329
+ template <typename PermutationIndex = DefaultPermutationIndex>
330
+ inline const FullPivLU<PlainObject, PermutationIndex> fullPivLu() const;
331
+ template <typename PermutationIndex = DefaultPermutationIndex>
332
+ inline const PartialPivLU<PlainObject, PermutationIndex> partialPivLu() const;
333
+
334
+ template <typename PermutationIndex = DefaultPermutationIndex>
335
+ inline const PartialPivLU<PlainObject, PermutationIndex> lu() const;
336
+
337
+ EIGEN_DEVICE_FUNC inline const Inverse<Derived> inverse() const;
338
+
339
+ template <typename ResultType>
340
+ inline void computeInverseAndDetWithCheck(
341
+ ResultType& inverse, typename ResultType::Scalar& determinant, bool& invertible,
342
+ const RealScalar& absDeterminantThreshold = NumTraits<Scalar>::dummy_precision()) const;
343
+
344
+ template <typename ResultType>
345
+ inline void computeInverseWithCheck(
346
+ ResultType& inverse, bool& invertible,
347
+ const RealScalar& absDeterminantThreshold = NumTraits<Scalar>::dummy_precision()) const;
348
+
349
+ EIGEN_DEVICE_FUNC Scalar determinant() const;
350
+
351
+ /////////// Cholesky module ///////////
352
+
353
+ inline const LLT<PlainObject> llt() const;
354
+ inline const LDLT<PlainObject> ldlt() const;
355
+
356
+ /////////// QR module ///////////
357
+
358
+ inline const HouseholderQR<PlainObject> householderQr() const;
359
+ template <typename PermutationIndex = DefaultPermutationIndex>
360
+ inline const ColPivHouseholderQR<PlainObject, PermutationIndex> colPivHouseholderQr() const;
361
+ template <typename PermutationIndex = DefaultPermutationIndex>
362
+ inline const FullPivHouseholderQR<PlainObject, PermutationIndex> fullPivHouseholderQr() const;
363
+ template <typename PermutationIndex = DefaultPermutationIndex>
364
+ inline const CompleteOrthogonalDecomposition<PlainObject, PermutationIndex> completeOrthogonalDecomposition() const;
365
+
366
+ /////////// Eigenvalues module ///////////
367
+
368
+ inline EigenvaluesReturnType eigenvalues() const;
369
+ inline RealScalar operatorNorm() const;
370
+
371
+ /////////// SVD module ///////////
372
+
373
+ template <int Options = 0>
374
+ inline JacobiSVD<PlainObject, Options> jacobiSvd() const;
375
+ template <int Options = 0>
376
+ EIGEN_DEPRECATED_WITH_REASON("Options should be specified using method's template parameter.")
377
+ inline JacobiSVD<PlainObject, Options> jacobiSvd(unsigned int computationOptions) const;
378
+
379
+ template <int Options = 0>
380
+ inline BDCSVD<PlainObject, Options> bdcSvd() const;
381
+ template <int Options = 0>
382
+ EIGEN_DEPRECATED_WITH_REASON("Options should be specified using method's template parameter.")
383
+ inline BDCSVD<PlainObject, Options> bdcSvd(unsigned int computationOptions) const;
384
+
385
+ /////////// Geometry module ///////////
386
+
387
+ template <typename OtherDerived>
388
+ EIGEN_DEVICE_FUNC inline typename internal::cross_impl<Derived, OtherDerived>::return_type cross(
389
+ const MatrixBase<OtherDerived>& other) const;
390
+
391
+ template <typename OtherDerived>
392
+ EIGEN_DEVICE_FUNC inline PlainObject cross3(const MatrixBase<OtherDerived>& other) const;
393
+
394
+ EIGEN_DEVICE_FUNC inline PlainObject unitOrthogonal(void) const;
395
+
396
+ EIGEN_DEPRECATED_WITH_REASON("Use .canonicalEulerAngles() instead.")
397
+ EIGEN_DEVICE_FUNC inline Matrix<Scalar, 3, 1> eulerAngles(Index a0, Index a1, Index a2) const;
398
+
399
+ EIGEN_DEVICE_FUNC inline Matrix<Scalar, 3, 1> canonicalEulerAngles(Index a0, Index a1, Index a2) const;
400
+
401
+ // put this as separate enum value to work around possible GCC 4.3 bug (?)
402
+ enum {
403
+ HomogeneousReturnTypeDirection =
404
+ ColsAtCompileTime == 1 && RowsAtCompileTime == 1
405
+ ? ((internal::traits<Derived>::Flags & RowMajorBit) == RowMajorBit ? Horizontal : Vertical)
406
+ : ColsAtCompileTime == 1 ? Vertical
407
+ : Horizontal
408
+ };
409
+ typedef Homogeneous<Derived, HomogeneousReturnTypeDirection> HomogeneousReturnType;
410
+ EIGEN_DEVICE_FUNC inline HomogeneousReturnType homogeneous() const;
411
+
412
+ enum { SizeMinusOne = SizeAtCompileTime == Dynamic ? Dynamic : SizeAtCompileTime - 1 };
413
+ typedef Block<const Derived, internal::traits<Derived>::ColsAtCompileTime == 1 ? SizeMinusOne : 1,
414
+ internal::traits<Derived>::ColsAtCompileTime == 1 ? 1 : SizeMinusOne>
415
+ ConstStartMinusOne;
416
+ typedef EIGEN_EXPR_BINARYOP_SCALAR_RETURN_TYPE(ConstStartMinusOne, Scalar, quotient) HNormalizedReturnType;
417
+ EIGEN_DEVICE_FUNC inline const HNormalizedReturnType hnormalized() const;
418
+
419
+ ////////// Householder module ///////////
420
+
421
+ EIGEN_DEVICE_FUNC void makeHouseholderInPlace(Scalar& tau, RealScalar& beta);
422
+ template <typename EssentialPart>
423
+ EIGEN_DEVICE_FUNC void makeHouseholder(EssentialPart& essential, Scalar& tau, RealScalar& beta) const;
424
+ template <typename EssentialPart>
425
+ EIGEN_DEVICE_FUNC void applyHouseholderOnTheLeft(const EssentialPart& essential, const Scalar& tau,
426
+ Scalar* workspace);
427
+ template <typename EssentialPart>
428
+ EIGEN_DEVICE_FUNC void applyHouseholderOnTheRight(const EssentialPart& essential, const Scalar& tau,
429
+ Scalar* workspace);
430
+
431
+ ///////// Jacobi module /////////
432
+
433
+ template <typename OtherScalar>
434
+ EIGEN_DEVICE_FUNC void applyOnTheLeft(Index p, Index q, const JacobiRotation<OtherScalar>& j);
435
+ template <typename OtherScalar>
436
+ EIGEN_DEVICE_FUNC void applyOnTheRight(Index p, Index q, const JacobiRotation<OtherScalar>& j);
437
+
438
+ ///////// SparseCore module /////////
439
+
440
+ template <typename OtherDerived>
441
+ EIGEN_STRONG_INLINE const typename SparseMatrixBase<OtherDerived>::template CwiseProductDenseReturnType<Derived>::Type
442
+ cwiseProduct(const SparseMatrixBase<OtherDerived>& other) const {
443
+ return other.cwiseProduct(derived());
444
+ }
445
+
446
+ ///////// MatrixFunctions module /////////
447
+
448
+ typedef typename internal::stem_function<Scalar>::type StemFunction;
449
+ #define EIGEN_MATRIX_FUNCTION(ReturnType, Name, Description) \
450
+ /** \returns an expression of the matrix Description of \c *this. \brief This function requires the <a \
451
+ * href="unsupported/group__MatrixFunctions__Module.html"> unsupported MatrixFunctions module</a>. To compute the \
452
+ * coefficient-wise Description use ArrayBase::##Name . */ \
453
+ const ReturnType<Derived> Name() const;
454
+ #define EIGEN_MATRIX_FUNCTION_1(ReturnType, Name, Description, Argument) \
455
+ /** \returns an expression of the matrix Description of \c *this. \brief This function requires the <a \
456
+ * href="unsupported/group__MatrixFunctions__Module.html"> unsupported MatrixFunctions module</a>. To compute the \
457
+ * coefficient-wise Description use ArrayBase::##Name . */ \
458
+ const ReturnType<Derived> Name(Argument) const;
459
+
460
+ EIGEN_MATRIX_FUNCTION(MatrixExponentialReturnValue, exp, exponential)
461
+ /** \brief Helper function for the <a href="unsupported/group__MatrixFunctions__Module.html"> unsupported
462
+ * MatrixFunctions module</a>.*/
463
+ const MatrixFunctionReturnValue<Derived> matrixFunction(StemFunction f) const;
464
+ EIGEN_MATRIX_FUNCTION(MatrixFunctionReturnValue, cosh, hyperbolic cosine)
465
+ EIGEN_MATRIX_FUNCTION(MatrixFunctionReturnValue, sinh, hyperbolic sine)
466
+ EIGEN_MATRIX_FUNCTION(MatrixFunctionReturnValue, atanh, inverse hyperbolic cosine)
467
+ EIGEN_MATRIX_FUNCTION(MatrixFunctionReturnValue, acosh, inverse hyperbolic cosine)
468
+ EIGEN_MATRIX_FUNCTION(MatrixFunctionReturnValue, asinh, inverse hyperbolic sine)
469
+ EIGEN_MATRIX_FUNCTION(MatrixFunctionReturnValue, cos, cosine)
470
+ EIGEN_MATRIX_FUNCTION(MatrixFunctionReturnValue, sin, sine)
471
+ EIGEN_MATRIX_FUNCTION(MatrixSquareRootReturnValue, sqrt, square root)
472
+ EIGEN_MATRIX_FUNCTION(MatrixLogarithmReturnValue, log, logarithm)
473
+ EIGEN_MATRIX_FUNCTION_1(MatrixPowerReturnValue, pow, power to \c p, const RealScalar& p)
474
+ EIGEN_MATRIX_FUNCTION_1(MatrixComplexPowerReturnValue, pow, power to \c p, const internal::make_complex_t<Scalar>& p)
475
+
476
+ protected:
477
+ EIGEN_DEFAULT_COPY_CONSTRUCTOR(MatrixBase)
478
+ EIGEN_DEFAULT_EMPTY_CONSTRUCTOR_AND_DESTRUCTOR(MatrixBase)
479
+
480
+ private:
481
+ EIGEN_DEVICE_FUNC explicit MatrixBase(int);
482
+ EIGEN_DEVICE_FUNC MatrixBase(int, int);
483
+ template <typename OtherDerived>
484
+ EIGEN_DEVICE_FUNC explicit MatrixBase(const MatrixBase<OtherDerived>&);
485
+
486
+ protected:
487
+ // mixing arrays and matrices is not legal
488
+ template <typename OtherDerived>
489
+ Derived& operator+=(const ArrayBase<OtherDerived>&) {
490
+ EIGEN_STATIC_ASSERT(std::ptrdiff_t(sizeof(typename OtherDerived::Scalar)) == -1,
491
+ YOU_CANNOT_MIX_ARRAYS_AND_MATRICES);
492
+ return *this;
493
+ }
494
+ // mixing arrays and matrices is not legal
495
+ template <typename OtherDerived>
496
+ Derived& operator-=(const ArrayBase<OtherDerived>&) {
497
+ EIGEN_STATIC_ASSERT(std::ptrdiff_t(sizeof(typename OtherDerived::Scalar)) == -1,
498
+ YOU_CANNOT_MIX_ARRAYS_AND_MATRICES);
499
+ return *this;
500
+ }
481
501
  };
482
502
 
483
-
484
503
  /***************************************************************************
485
- * Implementation of matrix base methods
486
- ***************************************************************************/
504
+ * Implementation of matrix base methods
505
+ ***************************************************************************/
487
506
 
488
507
  /** replaces \c *this by \c *this * \a other.
489
- *
490
- * \returns a reference to \c *this
491
- *
492
- * Example: \include MatrixBase_applyOnTheRight.cpp
493
- * Output: \verbinclude MatrixBase_applyOnTheRight.out
494
- */
495
- template<typename Derived>
496
- template<typename OtherDerived>
497
- inline Derived&
498
- MatrixBase<Derived>::operator*=(const EigenBase<OtherDerived> &other)
499
- {
508
+ *
509
+ * \returns a reference to \c *this
510
+ *
511
+ * Example: \include MatrixBase_applyOnTheRight.cpp
512
+ * Output: \verbinclude MatrixBase_applyOnTheRight.out
513
+ */
514
+ template <typename Derived>
515
+ template <typename OtherDerived>
516
+ inline Derived& MatrixBase<Derived>::operator*=(const EigenBase<OtherDerived>& other) {
500
517
  other.derived().applyThisOnTheRight(derived());
501
518
  return derived();
502
519
  }
503
520
 
504
521
  /** replaces \c *this by \c *this * \a other. It is equivalent to MatrixBase::operator*=().
505
- *
506
- * Example: \include MatrixBase_applyOnTheRight.cpp
507
- * Output: \verbinclude MatrixBase_applyOnTheRight.out
508
- */
509
- template<typename Derived>
510
- template<typename OtherDerived>
511
- inline void MatrixBase<Derived>::applyOnTheRight(const EigenBase<OtherDerived> &other)
512
- {
522
+ *
523
+ * Example: \include MatrixBase_applyOnTheRight.cpp
524
+ * Output: \verbinclude MatrixBase_applyOnTheRight.out
525
+ */
526
+ template <typename Derived>
527
+ template <typename OtherDerived>
528
+ inline void MatrixBase<Derived>::applyOnTheRight(const EigenBase<OtherDerived>& other) {
513
529
  other.derived().applyThisOnTheRight(derived());
514
530
  }
515
531
 
516
532
  /** replaces \c *this by \a other * \c *this.
517
- *
518
- * Example: \include MatrixBase_applyOnTheLeft.cpp
519
- * Output: \verbinclude MatrixBase_applyOnTheLeft.out
520
- */
521
- template<typename Derived>
522
- template<typename OtherDerived>
523
- inline void MatrixBase<Derived>::applyOnTheLeft(const EigenBase<OtherDerived> &other)
524
- {
533
+ *
534
+ * Example: \include MatrixBase_applyOnTheLeft.cpp
535
+ * Output: \verbinclude MatrixBase_applyOnTheLeft.out
536
+ */
537
+ template <typename Derived>
538
+ template <typename OtherDerived>
539
+ inline void MatrixBase<Derived>::applyOnTheLeft(const EigenBase<OtherDerived>& other) {
525
540
  other.derived().applyThisOnTheLeft(derived());
526
541
  }
527
542
 
528
- } // end namespace Eigen
543
+ } // end namespace Eigen
529
544
 
530
- #endif // EIGEN_MATRIXBASE_H
545
+ #endif // EIGEN_MATRIXBASE_H