@smake/eigen 1.1.0 → 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 (431) hide show
  1. package/README.md +1 -1
  2. package/eigen/Eigen/AccelerateSupport +52 -0
  3. package/eigen/Eigen/Cholesky +18 -20
  4. package/eigen/Eigen/CholmodSupport +28 -28
  5. package/eigen/Eigen/Core +187 -120
  6. package/eigen/Eigen/Eigenvalues +16 -13
  7. package/eigen/Eigen/Geometry +18 -18
  8. package/eigen/Eigen/Householder +9 -7
  9. package/eigen/Eigen/IterativeLinearSolvers +8 -4
  10. package/eigen/Eigen/Jacobi +14 -13
  11. package/eigen/Eigen/KLUSupport +23 -21
  12. package/eigen/Eigen/LU +15 -16
  13. package/eigen/Eigen/MetisSupport +12 -12
  14. package/eigen/Eigen/OrderingMethods +54 -51
  15. package/eigen/Eigen/PaStiXSupport +23 -21
  16. package/eigen/Eigen/PardisoSupport +17 -14
  17. package/eigen/Eigen/QR +18 -20
  18. package/eigen/Eigen/QtAlignedMalloc +5 -12
  19. package/eigen/Eigen/SPQRSupport +21 -14
  20. package/eigen/Eigen/SVD +23 -17
  21. package/eigen/Eigen/Sparse +1 -2
  22. package/eigen/Eigen/SparseCholesky +18 -15
  23. package/eigen/Eigen/SparseCore +18 -17
  24. package/eigen/Eigen/SparseLU +9 -9
  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 +366 -405
  37. package/eigen/Eigen/src/Cholesky/LLT.h +323 -367
  38. package/eigen/Eigen/src/Cholesky/LLT_LAPACKE.h +81 -56
  39. package/eigen/Eigen/src/CholmodSupport/CholmodSupport.h +585 -529
  40. package/eigen/Eigen/src/CholmodSupport/InternalHeaderCheck.h +3 -0
  41. package/eigen/Eigen/src/Core/ArithmeticSequence.h +143 -317
  42. package/eigen/Eigen/src/Core/Array.h +329 -370
  43. package/eigen/Eigen/src/Core/ArrayBase.h +190 -203
  44. package/eigen/Eigen/src/Core/ArrayWrapper.h +126 -170
  45. package/eigen/Eigen/src/Core/Assign.h +30 -40
  46. package/eigen/Eigen/src/Core/AssignEvaluator.h +651 -604
  47. package/eigen/Eigen/src/Core/Assign_MKL.h +125 -120
  48. package/eigen/Eigen/src/Core/BandMatrix.h +267 -282
  49. package/eigen/Eigen/src/Core/Block.h +371 -390
  50. package/eigen/Eigen/src/Core/CommaInitializer.h +85 -100
  51. package/eigen/Eigen/src/Core/ConditionEstimator.h +51 -53
  52. package/eigen/Eigen/src/Core/CoreEvaluators.h +1214 -937
  53. package/eigen/Eigen/src/Core/CoreIterators.h +72 -63
  54. package/eigen/Eigen/src/Core/CwiseBinaryOp.h +112 -129
  55. package/eigen/Eigen/src/Core/CwiseNullaryOp.h +676 -702
  56. package/eigen/Eigen/src/Core/CwiseTernaryOp.h +77 -103
  57. package/eigen/Eigen/src/Core/CwiseUnaryOp.h +55 -67
  58. package/eigen/Eigen/src/Core/CwiseUnaryView.h +127 -92
  59. package/eigen/Eigen/src/Core/DenseBase.h +630 -658
  60. package/eigen/Eigen/src/Core/DenseCoeffsBase.h +511 -628
  61. package/eigen/Eigen/src/Core/DenseStorage.h +511 -590
  62. package/eigen/Eigen/src/Core/DeviceWrapper.h +153 -0
  63. package/eigen/Eigen/src/Core/Diagonal.h +168 -207
  64. package/eigen/Eigen/src/Core/DiagonalMatrix.h +346 -317
  65. package/eigen/Eigen/src/Core/DiagonalProduct.h +12 -10
  66. package/eigen/Eigen/src/Core/Dot.h +167 -217
  67. package/eigen/Eigen/src/Core/EigenBase.h +74 -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 -113
  71. package/eigen/Eigen/src/Core/Fuzzy.h +82 -105
  72. package/eigen/Eigen/src/Core/GeneralProduct.h +315 -261
  73. package/eigen/Eigen/src/Core/GenericPacketMath.h +1182 -520
  74. package/eigen/Eigen/src/Core/GlobalFunctions.h +193 -157
  75. package/eigen/Eigen/src/Core/IO.h +131 -156
  76. package/eigen/Eigen/src/Core/IndexedView.h +209 -125
  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 +50 -59
  80. package/eigen/Eigen/src/Core/Map.h +123 -141
  81. package/eigen/Eigen/src/Core/MapBase.h +255 -282
  82. package/eigen/Eigen/src/Core/MathFunctions.h +1247 -1201
  83. package/eigen/Eigen/src/Core/MathFunctionsImpl.h +162 -99
  84. package/eigen/Eigen/src/Core/Matrix.h +463 -494
  85. package/eigen/Eigen/src/Core/MatrixBase.h +468 -470
  86. package/eigen/Eigen/src/Core/NestByValue.h +58 -52
  87. package/eigen/Eigen/src/Core/NoAlias.h +79 -86
  88. package/eigen/Eigen/src/Core/NumTraits.h +206 -206
  89. package/eigen/Eigen/src/Core/PartialReduxEvaluator.h +163 -142
  90. package/eigen/Eigen/src/Core/PermutationMatrix.h +461 -511
  91. package/eigen/Eigen/src/Core/PlainObjectBase.h +858 -972
  92. package/eigen/Eigen/src/Core/Product.h +246 -130
  93. package/eigen/Eigen/src/Core/ProductEvaluators.h +779 -671
  94. package/eigen/Eigen/src/Core/Random.h +153 -164
  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 +334 -314
  98. package/eigen/Eigen/src/Core/Ref.h +259 -257
  99. package/eigen/Eigen/src/Core/Replicate.h +92 -104
  100. package/eigen/Eigen/src/Core/Reshaped.h +215 -271
  101. package/eigen/Eigen/src/Core/ReturnByValue.h +47 -55
  102. package/eigen/Eigen/src/Core/Reverse.h +133 -148
  103. package/eigen/Eigen/src/Core/Select.h +68 -140
  104. package/eigen/Eigen/src/Core/SelfAdjointView.h +254 -290
  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 +88 -102
  108. package/eigen/Eigen/src/Core/SolveTriangular.h +126 -124
  109. package/eigen/Eigen/src/Core/SolverBase.h +132 -133
  110. package/eigen/Eigen/src/Core/StableNorm.h +113 -147
  111. package/eigen/Eigen/src/Core/StlIterators.h +404 -248
  112. package/eigen/Eigen/src/Core/Stride.h +90 -92
  113. package/eigen/Eigen/src/Core/Swap.h +70 -39
  114. package/eigen/Eigen/src/Core/Transpose.h +258 -295
  115. package/eigen/Eigen/src/Core/Transpositions.h +270 -333
  116. package/eigen/Eigen/src/Core/TriangularMatrix.h +642 -743
  117. package/eigen/Eigen/src/Core/VectorBlock.h +59 -72
  118. package/eigen/Eigen/src/Core/VectorwiseOp.h +653 -704
  119. package/eigen/Eigen/src/Core/Visitor.h +464 -308
  120. package/eigen/Eigen/src/Core/arch/AVX/Complex.h +380 -187
  121. package/eigen/Eigen/src/Core/arch/AVX/MathFunctions.h +65 -163
  122. package/eigen/Eigen/src/Core/arch/AVX/PacketMath.h +2145 -638
  123. package/eigen/Eigen/src/Core/arch/AVX/Reductions.h +353 -0
  124. package/eigen/Eigen/src/Core/arch/AVX/TypeCasting.h +253 -60
  125. package/eigen/Eigen/src/Core/arch/AVX512/Complex.h +278 -228
  126. package/eigen/Eigen/src/Core/arch/AVX512/GemmKernel.h +1245 -0
  127. package/eigen/Eigen/src/Core/arch/AVX512/MathFunctions.h +48 -269
  128. package/eigen/Eigen/src/Core/arch/AVX512/MathFunctionsFP16.h +75 -0
  129. package/eigen/Eigen/src/Core/arch/AVX512/PacketMath.h +1597 -754
  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 +229 -41
  135. package/eigen/Eigen/src/Core/arch/AVX512/TypeCastingFP16.h +130 -0
  136. package/eigen/Eigen/src/Core/arch/AltiVec/Complex.h +420 -184
  137. package/eigen/Eigen/src/Core/arch/AltiVec/MathFunctions.h +40 -49
  138. package/eigen/Eigen/src/Core/arch/AltiVec/MatrixProduct.h +2962 -2213
  139. package/eigen/Eigen/src/Core/arch/AltiVec/MatrixProductCommon.h +196 -212
  140. package/eigen/Eigen/src/Core/arch/AltiVec/MatrixProductMMA.h +713 -441
  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 +2380 -1362
  144. package/eigen/Eigen/src/Core/arch/AltiVec/TypeCasting.h +153 -0
  145. package/eigen/Eigen/src/Core/arch/Default/BFloat16.h +390 -224
  146. package/eigen/Eigen/src/Core/arch/Default/ConjHelper.h +78 -67
  147. package/eigen/Eigen/src/Core/arch/Default/GenericPacketMathFunctions.h +1784 -799
  148. package/eigen/Eigen/src/Core/arch/Default/GenericPacketMathFunctionsFwd.h +167 -50
  149. package/eigen/Eigen/src/Core/arch/Default/Half.h +528 -379
  150. package/eigen/Eigen/src/Core/arch/Default/Settings.h +10 -12
  151. package/eigen/Eigen/src/Core/arch/GPU/Complex.h +244 -0
  152. package/eigen/Eigen/src/Core/arch/GPU/MathFunctions.h +41 -40
  153. package/eigen/Eigen/src/Core/arch/GPU/PacketMath.h +550 -523
  154. package/eigen/Eigen/src/Core/arch/GPU/Tuple.h +268 -0
  155. package/eigen/Eigen/src/Core/arch/GPU/TypeCasting.h +27 -30
  156. package/eigen/Eigen/src/Core/arch/HIP/hcc/math_constants.h +8 -8
  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 +54 -82
  164. package/eigen/Eigen/src/Core/arch/MSA/MathFunctions.h +84 -92
  165. package/eigen/Eigen/src/Core/arch/MSA/PacketMath.h +51 -47
  166. package/eigen/Eigen/src/Core/arch/NEON/Complex.h +454 -306
  167. package/eigen/Eigen/src/Core/arch/NEON/GeneralBlockPanelKernel.h +175 -115
  168. package/eigen/Eigen/src/Core/arch/NEON/MathFunctions.h +23 -30
  169. package/eigen/Eigen/src/Core/arch/NEON/PacketMath.h +4366 -2857
  170. package/eigen/Eigen/src/Core/arch/NEON/TypeCasting.h +616 -393
  171. package/eigen/Eigen/src/Core/arch/NEON/UnaryFunctors.h +57 -0
  172. package/eigen/Eigen/src/Core/arch/SSE/Complex.h +350 -198
  173. package/eigen/Eigen/src/Core/arch/SSE/MathFunctions.h +38 -149
  174. package/eigen/Eigen/src/Core/arch/SSE/PacketMath.h +1791 -912
  175. package/eigen/Eigen/src/Core/arch/SSE/Reductions.h +324 -0
  176. package/eigen/Eigen/src/Core/arch/SSE/TypeCasting.h +128 -40
  177. package/eigen/Eigen/src/Core/arch/SVE/MathFunctions.h +10 -6
  178. package/eigen/Eigen/src/Core/arch/SVE/PacketMath.h +156 -234
  179. package/eigen/Eigen/src/Core/arch/SVE/TypeCasting.h +6 -3
  180. package/eigen/Eigen/src/Core/arch/SYCL/InteropHeaders.h +27 -32
  181. package/eigen/Eigen/src/Core/arch/SYCL/MathFunctions.h +119 -117
  182. package/eigen/Eigen/src/Core/arch/SYCL/PacketMath.h +325 -419
  183. package/eigen/Eigen/src/Core/arch/SYCL/TypeCasting.h +15 -17
  184. package/eigen/Eigen/src/Core/arch/ZVector/Complex.h +325 -181
  185. package/eigen/Eigen/src/Core/arch/ZVector/MathFunctions.h +94 -83
  186. package/eigen/Eigen/src/Core/arch/ZVector/PacketMath.h +811 -458
  187. package/eigen/Eigen/src/Core/functors/AssignmentFunctors.h +121 -124
  188. package/eigen/Eigen/src/Core/functors/BinaryFunctors.h +576 -370
  189. package/eigen/Eigen/src/Core/functors/NullaryFunctors.h +194 -109
  190. package/eigen/Eigen/src/Core/functors/StlFunctors.h +95 -112
  191. package/eigen/Eigen/src/Core/functors/TernaryFunctors.h +34 -7
  192. package/eigen/Eigen/src/Core/functors/UnaryFunctors.h +1038 -749
  193. package/eigen/Eigen/src/Core/products/GeneralBlockPanelKernel.h +1883 -1375
  194. package/eigen/Eigen/src/Core/products/GeneralMatrixMatrix.h +312 -370
  195. package/eigen/Eigen/src/Core/products/GeneralMatrixMatrixTriangular.h +189 -176
  196. package/eigen/Eigen/src/Core/products/GeneralMatrixMatrixTriangular_BLAS.h +84 -81
  197. package/eigen/Eigen/src/Core/products/GeneralMatrixMatrix_BLAS.h +154 -73
  198. package/eigen/Eigen/src/Core/products/GeneralMatrixVector.h +292 -337
  199. package/eigen/Eigen/src/Core/products/GeneralMatrixVector_BLAS.h +80 -77
  200. package/eigen/Eigen/src/Core/products/Parallelizer.h +207 -105
  201. package/eigen/Eigen/src/Core/products/SelfadjointMatrixMatrix.h +327 -388
  202. package/eigen/Eigen/src/Core/products/SelfadjointMatrixMatrix_BLAS.h +206 -224
  203. package/eigen/Eigen/src/Core/products/SelfadjointMatrixVector.h +138 -147
  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 -47
  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 -277
  212. package/eigen/Eigen/src/Core/products/TriangularSolverMatrix_BLAS.h +108 -109
  213. package/eigen/Eigen/src/Core/products/TriangularSolverVector.h +68 -94
  214. package/eigen/Eigen/src/Core/util/Assert.h +158 -0
  215. package/eigen/Eigen/src/Core/util/BlasUtil.h +342 -303
  216. package/eigen/Eigen/src/Core/util/ConfigureVectorization.h +348 -317
  217. package/eigen/Eigen/src/Core/util/Constants.h +297 -262
  218. package/eigen/Eigen/src/Core/util/DisableStupidWarnings.h +130 -90
  219. package/eigen/Eigen/src/Core/util/EmulateArray.h +270 -0
  220. package/eigen/Eigen/src/Core/util/ForwardDeclarations.h +449 -247
  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 +417 -116
  224. package/eigen/Eigen/src/Core/util/IntegralConstant.h +211 -204
  225. package/eigen/Eigen/src/Core/util/MKL_support.h +39 -37
  226. package/eigen/Eigen/src/Core/util/Macros.h +655 -773
  227. package/eigen/Eigen/src/Core/util/MaxSizeVector.h +139 -0
  228. package/eigen/Eigen/src/Core/util/Memory.h +970 -748
  229. package/eigen/Eigen/src/Core/util/Meta.h +581 -633
  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 +17 -17
  233. package/eigen/Eigen/src/Core/util/Serializer.h +209 -0
  234. package/eigen/Eigen/src/Core/util/StaticAssert.h +50 -166
  235. package/eigen/Eigen/src/Core/util/SymbolicIndex.h +377 -225
  236. package/eigen/Eigen/src/Core/util/XprHelper.h +784 -547
  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 +89 -105
  246. package/eigen/Eigen/src/Eigenvalues/RealQZ.h +537 -607
  247. package/eigen/Eigen/src/Eigenvalues/RealSchur.h +342 -381
  248. package/eigen/Eigen/src/Eigenvalues/RealSchur_LAPACKE.h +41 -35
  249. package/eigen/Eigen/src/Eigenvalues/SelfAdjointEigenSolver.h +541 -595
  250. package/eigen/Eigen/src/Eigenvalues/SelfAdjointEigenSolver_LAPACKE.h +47 -44
  251. package/eigen/Eigen/src/Eigenvalues/Tridiagonalization.h +430 -462
  252. package/eigen/Eigen/src/Geometry/AlignedBox.h +226 -227
  253. package/eigen/Eigen/src/Geometry/AngleAxis.h +131 -133
  254. package/eigen/Eigen/src/Geometry/EulerAngles.h +163 -74
  255. package/eigen/Eigen/src/Geometry/Homogeneous.h +285 -333
  256. package/eigen/Eigen/src/Geometry/Hyperplane.h +151 -160
  257. package/eigen/Eigen/src/Geometry/InternalHeaderCheck.h +3 -0
  258. package/eigen/Eigen/src/Geometry/OrthoMethods.h +168 -146
  259. package/eigen/Eigen/src/Geometry/ParametrizedLine.h +127 -127
  260. package/eigen/Eigen/src/Geometry/Quaternion.h +566 -506
  261. package/eigen/Eigen/src/Geometry/Rotation2D.h +107 -105
  262. package/eigen/Eigen/src/Geometry/RotationBase.h +148 -145
  263. package/eigen/Eigen/src/Geometry/Scaling.h +113 -106
  264. package/eigen/Eigen/src/Geometry/Transform.h +858 -936
  265. package/eigen/Eigen/src/Geometry/Translation.h +94 -92
  266. package/eigen/Eigen/src/Geometry/Umeyama.h +79 -84
  267. package/eigen/Eigen/src/Geometry/arch/Geometry_SIMD.h +90 -104
  268. package/eigen/Eigen/src/Householder/BlockHouseholder.h +51 -46
  269. package/eigen/Eigen/src/Householder/Householder.h +102 -124
  270. package/eigen/Eigen/src/Householder/HouseholderSequence.h +412 -453
  271. package/eigen/Eigen/src/Householder/InternalHeaderCheck.h +3 -0
  272. package/eigen/Eigen/src/IterativeLinearSolvers/BasicPreconditioners.h +149 -162
  273. package/eigen/Eigen/src/IterativeLinearSolvers/BiCGSTAB.h +124 -119
  274. package/eigen/Eigen/src/IterativeLinearSolvers/ConjugateGradient.h +92 -104
  275. package/eigen/Eigen/src/IterativeLinearSolvers/IncompleteCholesky.h +251 -243
  276. package/eigen/Eigen/src/IterativeLinearSolvers/IncompleteLUT.h +224 -228
  277. package/eigen/Eigen/src/IterativeLinearSolvers/InternalHeaderCheck.h +3 -0
  278. package/eigen/Eigen/src/IterativeLinearSolvers/IterativeSolverBase.h +178 -227
  279. package/eigen/Eigen/src/IterativeLinearSolvers/LeastSquareConjugateGradient.h +79 -84
  280. package/eigen/Eigen/src/IterativeLinearSolvers/SolveWithGuess.h +54 -60
  281. package/eigen/Eigen/src/Jacobi/InternalHeaderCheck.h +3 -0
  282. package/eigen/Eigen/src/Jacobi/Jacobi.h +252 -308
  283. package/eigen/Eigen/src/KLUSupport/InternalHeaderCheck.h +3 -0
  284. package/eigen/Eigen/src/KLUSupport/KLUSupport.h +208 -227
  285. package/eigen/Eigen/src/LU/Determinant.h +50 -69
  286. package/eigen/Eigen/src/LU/FullPivLU.h +545 -596
  287. package/eigen/Eigen/src/LU/InternalHeaderCheck.h +3 -0
  288. package/eigen/Eigen/src/LU/InverseImpl.h +206 -285
  289. package/eigen/Eigen/src/LU/PartialPivLU.h +390 -428
  290. package/eigen/Eigen/src/LU/PartialPivLU_LAPACKE.h +54 -40
  291. package/eigen/Eigen/src/LU/arch/InverseSize4.h +72 -70
  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 +243 -265
  295. package/eigen/Eigen/src/OrderingMethods/Eigen_Colamd.h +831 -1004
  296. package/eigen/Eigen/src/OrderingMethods/InternalHeaderCheck.h +3 -0
  297. package/eigen/Eigen/src/OrderingMethods/Ordering.h +112 -119
  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 -430
  302. package/eigen/Eigen/src/QR/ColPivHouseholderQR.h +479 -479
  303. package/eigen/Eigen/src/QR/ColPivHouseholderQR_LAPACKE.h +120 -56
  304. package/eigen/Eigen/src/QR/CompleteOrthogonalDecomposition.h +166 -153
  305. package/eigen/Eigen/src/QR/FullPivHouseholderQR.h +495 -475
  306. package/eigen/Eigen/src/QR/HouseholderQR.h +394 -285
  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 +244 -264
  311. package/eigen/Eigen/src/SVD/BDCSVD.h +817 -713
  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 +577 -543
  315. package/eigen/Eigen/src/SVD/JacobiSVD_LAPACKE.h +85 -49
  316. package/eigen/Eigen/src/SVD/SVDBase.h +242 -182
  317. package/eigen/Eigen/src/SVD/UpperBidiagonalization.h +200 -235
  318. package/eigen/Eigen/src/SparseCholesky/InternalHeaderCheck.h +3 -0
  319. package/eigen/Eigen/src/SparseCholesky/SimplicialCholesky.h +765 -594
  320. package/eigen/Eigen/src/SparseCholesky/SimplicialCholesky_impl.h +308 -94
  321. package/eigen/Eigen/src/SparseCore/AmbiVector.h +202 -251
  322. package/eigen/Eigen/src/SparseCore/CompressedStorage.h +184 -252
  323. package/eigen/Eigen/src/SparseCore/ConservativeSparseSparseProduct.h +134 -178
  324. package/eigen/Eigen/src/SparseCore/InternalHeaderCheck.h +3 -0
  325. package/eigen/Eigen/src/SparseCore/SparseAssign.h +149 -140
  326. package/eigen/Eigen/src/SparseCore/SparseBlock.h +403 -440
  327. package/eigen/Eigen/src/SparseCore/SparseColEtree.h +100 -112
  328. package/eigen/Eigen/src/SparseCore/SparseCompressedBase.h +525 -303
  329. package/eigen/Eigen/src/SparseCore/SparseCwiseBinaryOp.h +555 -339
  330. package/eigen/Eigen/src/SparseCore/SparseCwiseUnaryOp.h +100 -108
  331. package/eigen/Eigen/src/SparseCore/SparseDenseProduct.h +169 -197
  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 +1603 -1245
  337. package/eigen/Eigen/src/SparseCore/SparseMatrixBase.h +403 -350
  338. package/eigen/Eigen/src/SparseCore/SparsePermutation.h +186 -115
  339. package/eigen/Eigen/src/SparseCore/SparseProduct.h +94 -97
  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 +370 -416
  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 +138 -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 +756 -710
  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 +245 -301
  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 +89 -100
  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 +124 -132
  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 +450 -502
  370. package/eigen/Eigen/src/StlSupport/StdDeque.h +28 -93
  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 -730
  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 +428 -464
  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 +9972 -16179
  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.h → BlockMethods.inc} +434 -506
  401. package/eigen/Eigen/src/plugins/CommonCwiseBinaryOps.inc +116 -0
  402. package/eigen/Eigen/src/plugins/{CommonCwiseUnaryOps.h → CommonCwiseUnaryOps.inc} +58 -68
  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/package.json +1 -1
  409. package/eigen/COPYING.APACHE +0 -203
  410. package/eigen/COPYING.BSD +0 -26
  411. package/eigen/COPYING.GPL +0 -674
  412. package/eigen/COPYING.LGPL +0 -502
  413. package/eigen/COPYING.MINPACK +0 -51
  414. package/eigen/COPYING.MPL2 +0 -373
  415. package/eigen/COPYING.README +0 -18
  416. package/eigen/Eigen/src/Core/BooleanRedux.h +0 -162
  417. package/eigen/Eigen/src/Core/arch/CUDA/Complex.h +0 -258
  418. package/eigen/Eigen/src/Core/arch/Default/TypeCasting.h +0 -120
  419. package/eigen/Eigen/src/Core/arch/SYCL/SyclMemoryModel.h +0 -694
  420. package/eigen/Eigen/src/Core/util/NonMPL2.h +0 -3
  421. package/eigen/Eigen/src/SparseCore/MappedSparseMatrix.h +0 -67
  422. package/eigen/Eigen/src/SparseLU/SparseLU_gemm_kernel.h +0 -280
  423. package/eigen/Eigen/src/misc/lapack.h +0 -152
  424. package/eigen/Eigen/src/plugins/ArrayCwiseBinaryOps.h +0 -358
  425. package/eigen/Eigen/src/plugins/ArrayCwiseUnaryOps.h +0 -696
  426. package/eigen/Eigen/src/plugins/CommonCwiseBinaryOps.h +0 -115
  427. package/eigen/Eigen/src/plugins/IndexedViewMethods.h +0 -262
  428. package/eigen/Eigen/src/plugins/MatrixCwiseBinaryOps.h +0 -152
  429. package/eigen/Eigen/src/plugins/MatrixCwiseUnaryOps.h +0 -95
  430. package/eigen/Eigen/src/plugins/ReshapedMethods.h +0 -149
  431. package/eigen/README.md +0 -5
@@ -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,503 +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
- using Base::operator/=;
84
-
85
- typedef typename Base::CoeffReturnType CoeffReturnType;
86
- typedef typename Base::ConstTransposeReturnType ConstTransposeReturnType;
87
- typedef typename Base::RowXpr RowXpr;
88
- typedef typename Base::ColXpr ColXpr;
89
- #endif // not EIGEN_PARSED_BY_DOXYGEN
90
-
91
-
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
92
92
 
93
93
  #ifndef EIGEN_PARSED_BY_DOXYGEN
94
- /** type of the equivalent square matrix */
95
- typedef Matrix<Scalar,EIGEN_SIZE_MAX(RowsAtCompileTime,ColsAtCompileTime),
96
- EIGEN_SIZE_MAX(RowsAtCompileTime,ColsAtCompileTime)> SquareMatrixType;
97
- #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
98
99
 
99
- /** \returns the size of the main diagonal, which is min(rows(),cols()).
100
- * \sa rows(), cols(), SizeAtCompileTime. */
101
- EIGEN_DEVICE_FUNC
102
- 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()); }
103
103
 
104
- typedef typename Base::PlainObject PlainObject;
104
+ typedef typename Base::PlainObject PlainObject;
105
105
 
106
106
  #ifndef 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 typename internal::conditional<NumTraits<Scalar>::IsComplex,
111
- CwiseUnaryOp<internal::scalar_conjugate_op<Scalar>, ConstTransposeReturnType>,
112
- ConstTransposeReturnType
113
- >::type AdjointReturnType;
114
- /** \internal Return type of eigenvalues() */
115
- typedef Matrix<std::complex<RealScalar>, internal::traits<Derived>::ColsAtCompileTime, 1, ColMajor> EigenvaluesReturnType;
116
- /** \internal the return type of identity */
117
- typedef CwiseNullaryOp<internal::scalar_identity_op<Scalar>,PlainObject> IdentityReturnType;
118
- /** \internal the return type of unit vectors */
119
- typedef Block<const CwiseNullaryOp<internal::scalar_identity_op<Scalar>, SquareMatrixType>,
120
- internal::traits<Derived>::RowsAtCompileTime,
121
- internal::traits<Derived>::ColsAtCompileTime> BasisReturnType;
122
- #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
123
124
 
124
125
  #define EIGEN_CURRENT_STORAGE_BASE_CLASS Eigen::MatrixBase
125
- #define EIGEN_DOC_UNARY_ADDONS(X,Y)
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
- EIGEN_DEVICE_FUNC Derived& setUnit(Index i);
272
- EIGEN_DEVICE_FUNC Derived& setUnit(Index newSize, Index i);
273
-
274
- bool isIdentity(const RealScalar& prec = NumTraits<Scalar>::dummy_precision()) const;
275
- bool isDiagonal(const RealScalar& prec = NumTraits<Scalar>::dummy_precision()) const;
276
-
277
- bool isUpperTriangular(const RealScalar& prec = NumTraits<Scalar>::dummy_precision()) const;
278
- bool isLowerTriangular(const RealScalar& prec = NumTraits<Scalar>::dummy_precision()) const;
279
-
280
- template<typename OtherDerived>
281
- bool isOrthogonal(const MatrixBase<OtherDerived>& other,
282
- const RealScalar& prec = NumTraits<Scalar>::dummy_precision()) const;
283
- bool isUnitary(const RealScalar& prec = NumTraits<Scalar>::dummy_precision()) const;
284
-
285
- /** \returns true if each coefficients of \c *this and \a other are all exactly equal.
286
- * \warning When using floating point scalar values you probably should rather use a
287
- * fuzzy comparison such as isApprox()
288
- * \sa isApprox(), operator!= */
289
- template<typename OtherDerived>
290
- EIGEN_DEVICE_FUNC inline bool operator==(const MatrixBase<OtherDerived>& other) const
291
- { return cwiseEqual(other).all(); }
292
-
293
- /** \returns true if at least one pair of coefficients of \c *this and \a other are not exactly equal to each other.
294
- * \warning When using floating point scalar values you probably should rather use a
295
- * fuzzy comparison such as isApprox()
296
- * \sa isApprox(), operator== */
297
- template<typename OtherDerived>
298
- EIGEN_DEVICE_FUNC inline bool operator!=(const MatrixBase<OtherDerived>& other) const
299
- { return cwiseNotEqual(other).any(); }
300
-
301
- NoAlias<Derived,Eigen::MatrixBase > EIGEN_DEVICE_FUNC noalias();
302
-
303
- // TODO forceAlignedAccess is temporarily disabled
304
- // Need to find a nicer workaround.
305
- inline const Derived& forceAlignedAccess() const { return derived(); }
306
- inline Derived& forceAlignedAccess() { return derived(); }
307
- template<bool Enable> inline const Derived& forceAlignedAccessIf() const { return derived(); }
308
- template<bool Enable> inline Derived& forceAlignedAccessIf() { return derived(); }
309
-
310
- EIGEN_DEVICE_FUNC Scalar trace() const;
311
-
312
- template<int p> EIGEN_DEVICE_FUNC RealScalar lpNorm() const;
313
-
314
- EIGEN_DEVICE_FUNC MatrixBase<Derived>& matrix() { return *this; }
315
- EIGEN_DEVICE_FUNC const MatrixBase<Derived>& matrix() const { return *this; }
316
-
317
- /** \returns an \link Eigen::ArrayBase Array \endlink expression of this matrix
318
- * \sa ArrayBase::matrix() */
319
- EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE ArrayWrapper<Derived> array() { return ArrayWrapper<Derived>(derived()); }
320
- /** \returns a const \link Eigen::ArrayBase Array \endlink expression of this matrix
321
- * \sa ArrayBase::matrix() */
322
- EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const ArrayWrapper<const Derived> array() const { return ArrayWrapper<const Derived>(derived()); }
323
-
324
- /////////// LU module ///////////
325
-
326
- inline const FullPivLU<PlainObject> fullPivLu() const;
327
- inline const PartialPivLU<PlainObject> partialPivLu() const;
328
-
329
- inline const PartialPivLU<PlainObject> lu() const;
330
-
331
- EIGEN_DEVICE_FUNC
332
- inline const Inverse<Derived> inverse() const;
333
-
334
- template<typename ResultType>
335
- inline void computeInverseAndDetWithCheck(
336
- ResultType& inverse,
337
- typename ResultType::Scalar& determinant,
338
- bool& invertible,
339
- const RealScalar& absDeterminantThreshold = NumTraits<Scalar>::dummy_precision()
340
- ) const;
341
-
342
- template<typename ResultType>
343
- inline void computeInverseWithCheck(
344
- ResultType& inverse,
345
- bool& invertible,
346
- const RealScalar& absDeterminantThreshold = NumTraits<Scalar>::dummy_precision()
347
- ) const;
348
-
349
- EIGEN_DEVICE_FUNC
350
- Scalar determinant() const;
351
-
352
- /////////// Cholesky module ///////////
353
-
354
- inline const LLT<PlainObject> llt() const;
355
- inline const LDLT<PlainObject> ldlt() const;
356
-
357
- /////////// QR module ///////////
358
-
359
- inline const HouseholderQR<PlainObject> householderQr() const;
360
- inline const ColPivHouseholderQR<PlainObject> colPivHouseholderQr() const;
361
- inline const FullPivHouseholderQR<PlainObject> fullPivHouseholderQr() const;
362
- inline const CompleteOrthogonalDecomposition<PlainObject> completeOrthogonalDecomposition() const;
363
-
364
- /////////// Eigenvalues module ///////////
365
-
366
- inline EigenvaluesReturnType eigenvalues() const;
367
- inline RealScalar operatorNorm() const;
368
-
369
- /////////// SVD module ///////////
370
-
371
- inline JacobiSVD<PlainObject> jacobiSvd(unsigned int computationOptions = 0) const;
372
- inline BDCSVD<PlainObject> bdcSvd(unsigned int computationOptions = 0) const;
373
-
374
- /////////// Geometry module ///////////
375
-
376
- #ifndef EIGEN_PARSED_BY_DOXYGEN
377
- /// \internal helper struct to form the return type of the cross product
378
- template<typename OtherDerived> struct cross_product_return_type {
379
- typedef typename ScalarBinaryOpTraits<typename internal::traits<Derived>::Scalar,typename internal::traits<OtherDerived>::Scalar>::ReturnType Scalar;
380
- typedef Matrix<Scalar,MatrixBase::RowsAtCompileTime,MatrixBase::ColsAtCompileTime> type;
381
- };
382
- #endif // EIGEN_PARSED_BY_DOXYGEN
383
- template<typename OtherDerived>
384
- EIGEN_DEVICE_FUNC
385
- #ifndef EIGEN_PARSED_BY_DOXYGEN
386
- inline typename cross_product_return_type<OtherDerived>::type
387
- #else
388
- inline PlainObject
389
- #endif
390
- cross(const MatrixBase<OtherDerived>& other) const;
391
-
392
- template<typename OtherDerived>
393
- EIGEN_DEVICE_FUNC
394
- inline PlainObject cross3(const MatrixBase<OtherDerived>& other) const;
395
-
396
- EIGEN_DEVICE_FUNC
397
- inline PlainObject unitOrthogonal(void) const;
398
-
399
- EIGEN_DEVICE_FUNC
400
- inline Matrix<Scalar,3,1> eulerAngles(Index a0, Index a1, Index a2) const;
401
-
402
- // put this as separate enum value to work around possible GCC 4.3 bug (?)
403
- enum { HomogeneousReturnTypeDirection = ColsAtCompileTime==1&&RowsAtCompileTime==1 ? ((internal::traits<Derived>::Flags&RowMajorBit)==RowMajorBit ? Horizontal : Vertical)
404
- : ColsAtCompileTime==1 ? Vertical : Horizontal };
405
- typedef Homogeneous<Derived, HomogeneousReturnTypeDirection> HomogeneousReturnType;
406
- EIGEN_DEVICE_FUNC
407
- inline HomogeneousReturnType homogeneous() const;
408
-
409
- enum {
410
- SizeMinusOne = SizeAtCompileTime==Dynamic ? Dynamic : SizeAtCompileTime-1
411
- };
412
- typedef Block<const Derived,
413
- internal::traits<Derived>::ColsAtCompileTime==1 ? SizeMinusOne : 1,
414
- internal::traits<Derived>::ColsAtCompileTime==1 ? 1 : SizeMinusOne> ConstStartMinusOne;
415
- typedef EIGEN_EXPR_BINARYOP_SCALAR_RETURN_TYPE(ConstStartMinusOne,Scalar,quotient) HNormalizedReturnType;
416
- EIGEN_DEVICE_FUNC
417
- inline const HNormalizedReturnType hnormalized() const;
418
-
419
- ////////// Householder module ///////////
420
-
421
- EIGEN_DEVICE_FUNC
422
- void makeHouseholderInPlace(Scalar& tau, RealScalar& beta);
423
- template<typename EssentialPart>
424
- EIGEN_DEVICE_FUNC
425
- void makeHouseholder(EssentialPart& essential,
426
- Scalar& tau, RealScalar& beta) const;
427
- template<typename EssentialPart>
428
- EIGEN_DEVICE_FUNC
429
- void applyHouseholderOnTheLeft(const EssentialPart& essential,
430
- const Scalar& tau,
431
- Scalar* workspace);
432
- template<typename EssentialPart>
433
- EIGEN_DEVICE_FUNC
434
- void applyHouseholderOnTheRight(const EssentialPart& essential,
435
- const Scalar& tau,
436
- Scalar* workspace);
437
-
438
- ///////// Jacobi module /////////
439
-
440
- template<typename OtherScalar>
441
- EIGEN_DEVICE_FUNC
442
- void applyOnTheLeft(Index p, Index q, const JacobiRotation<OtherScalar>& j);
443
- template<typename OtherScalar>
444
- EIGEN_DEVICE_FUNC
445
- void applyOnTheRight(Index p, Index q, const JacobiRotation<OtherScalar>& j);
446
-
447
- ///////// SparseCore module /////////
448
-
449
- template<typename OtherDerived>
450
- EIGEN_STRONG_INLINE const typename SparseMatrixBase<OtherDerived>::template CwiseProductDenseReturnType<Derived>::Type
451
- cwiseProduct(const SparseMatrixBase<OtherDerived> &other) const
452
- {
453
- return other.cwiseProduct(derived());
454
- }
455
-
456
- ///////// MatrixFunctions module /////////
457
-
458
- typedef typename internal::stem_function<Scalar>::type StemFunction;
459
- #define EIGEN_MATRIX_FUNCTION(ReturnType, Name, Description) \
460
- /** \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 . */ \
461
- const ReturnType<Derived> Name() const;
462
- #define EIGEN_MATRIX_FUNCTION_1(ReturnType, Name, Description, Argument) \
463
- /** \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 . */ \
464
- const ReturnType<Derived> Name(Argument) const;
465
-
466
- EIGEN_MATRIX_FUNCTION(MatrixExponentialReturnValue, exp, exponential)
467
- /** \brief Helper function for the <a href="unsupported/group__MatrixFunctions__Module.html"> unsupported MatrixFunctions module</a>.*/
468
- const MatrixFunctionReturnValue<Derived> matrixFunction(StemFunction f) const;
469
- EIGEN_MATRIX_FUNCTION(MatrixFunctionReturnValue, cosh, hyperbolic cosine)
470
- EIGEN_MATRIX_FUNCTION(MatrixFunctionReturnValue, sinh, hyperbolic sine)
471
- #if EIGEN_HAS_CXX11_MATH
472
- EIGEN_MATRIX_FUNCTION(MatrixFunctionReturnValue, atanh, inverse hyperbolic cosine)
473
- EIGEN_MATRIX_FUNCTION(MatrixFunctionReturnValue, acosh, inverse hyperbolic cosine)
474
- EIGEN_MATRIX_FUNCTION(MatrixFunctionReturnValue, asinh, inverse hyperbolic sine)
475
- #endif
476
- EIGEN_MATRIX_FUNCTION(MatrixFunctionReturnValue, cos, cosine)
477
- EIGEN_MATRIX_FUNCTION(MatrixFunctionReturnValue, sin, sine)
478
- EIGEN_MATRIX_FUNCTION(MatrixSquareRootReturnValue, sqrt, square root)
479
- EIGEN_MATRIX_FUNCTION(MatrixLogarithmReturnValue, log, logarithm)
480
- EIGEN_MATRIX_FUNCTION_1(MatrixPowerReturnValue, pow, power to \c p, const RealScalar& p)
481
- EIGEN_MATRIX_FUNCTION_1(MatrixComplexPowerReturnValue, pow, power to \c p, const std::complex<RealScalar>& p)
482
-
483
- protected:
484
- EIGEN_DEFAULT_COPY_CONSTRUCTOR(MatrixBase)
485
- EIGEN_DEFAULT_EMPTY_CONSTRUCTOR_AND_DESTRUCTOR(MatrixBase)
486
-
487
- private:
488
- EIGEN_DEVICE_FUNC explicit MatrixBase(int);
489
- EIGEN_DEVICE_FUNC MatrixBase(int,int);
490
- template<typename OtherDerived> EIGEN_DEVICE_FUNC explicit MatrixBase(const MatrixBase<OtherDerived>&);
491
- protected:
492
- // mixing arrays and matrices is not legal
493
- template<typename OtherDerived> Derived& operator+=(const ArrayBase<OtherDerived>& )
494
- {EIGEN_STATIC_ASSERT(std::ptrdiff_t(sizeof(typename OtherDerived::Scalar))==-1,YOU_CANNOT_MIX_ARRAYS_AND_MATRICES); return *this;}
495
- // mixing arrays and matrices is not legal
496
- template<typename OtherDerived> Derived& operator-=(const ArrayBase<OtherDerived>& )
497
- {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
+ }
498
501
  };
499
502
 
500
-
501
503
  /***************************************************************************
502
- * Implementation of matrix base methods
503
- ***************************************************************************/
504
+ * Implementation of matrix base methods
505
+ ***************************************************************************/
504
506
 
505
507
  /** replaces \c *this by \c *this * \a other.
506
- *
507
- * \returns a reference to \c *this
508
- *
509
- * Example: \include MatrixBase_applyOnTheRight.cpp
510
- * Output: \verbinclude MatrixBase_applyOnTheRight.out
511
- */
512
- template<typename Derived>
513
- template<typename OtherDerived>
514
- inline Derived&
515
- MatrixBase<Derived>::operator*=(const EigenBase<OtherDerived> &other)
516
- {
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) {
517
517
  other.derived().applyThisOnTheRight(derived());
518
518
  return derived();
519
519
  }
520
520
 
521
521
  /** replaces \c *this by \c *this * \a other. It is equivalent to MatrixBase::operator*=().
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)
529
- {
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) {
530
529
  other.derived().applyThisOnTheRight(derived());
531
530
  }
532
531
 
533
532
  /** replaces \c *this by \a other * \c *this.
534
- *
535
- * Example: \include MatrixBase_applyOnTheLeft.cpp
536
- * Output: \verbinclude MatrixBase_applyOnTheLeft.out
537
- */
538
- template<typename Derived>
539
- template<typename OtherDerived>
540
- inline void MatrixBase<Derived>::applyOnTheLeft(const EigenBase<OtherDerived> &other)
541
- {
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) {
542
540
  other.derived().applyThisOnTheLeft(derived());
543
541
  }
544
542
 
545
- } // end namespace Eigen
543
+ } // end namespace Eigen
546
544
 
547
- #endif // EIGEN_MATRIXBASE_H
545
+ #endif // EIGEN_MATRIXBASE_H