@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
@@ -0,0 +1,331 @@
1
+ // This file is part of Eigen, a lightweight C++ template library
2
+ // for linear algebra.
3
+ //
4
+ // Copyright (C) 2008-2009 Gael Guennebaud <gael.guennebaud@inria.fr>
5
+ // Copyright (C) 2006-2008 Benoit Jacob <jacob.benoit.1@gmail.com>
6
+ //
7
+ // This Source Code Form is subject to the terms of the Mozilla
8
+ // Public License v. 2.0. If a copy of the MPL was not distributed
9
+ // with this file, You can obtain one at http://mozilla.org/MPL/2.0/.
10
+
11
+ // This file is a base class plugin containing matrix specifics coefficient wise functions.
12
+
13
+ /** \returns an expression of the Schur product (coefficient wise product) of *this and \a other
14
+ *
15
+ * Example: \include MatrixBase_cwiseProduct.cpp
16
+ * Output: \verbinclude MatrixBase_cwiseProduct.out
17
+ *
18
+ * \sa class CwiseBinaryOp, cwiseAbs2
19
+ */
20
+ template <typename OtherDerived>
21
+ EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const EIGEN_CWISE_BINARY_RETURN_TYPE(Derived, OtherDerived, product)
22
+ cwiseProduct(const EIGEN_CURRENT_STORAGE_BASE_CLASS<OtherDerived>& other) const {
23
+ return EIGEN_CWISE_BINARY_RETURN_TYPE(Derived, OtherDerived, product)(derived(), other.derived());
24
+ }
25
+
26
+ template <typename OtherDerived>
27
+ using CwiseBinaryEqualReturnType =
28
+ CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_EQ>, const Derived, const OtherDerived>;
29
+ template <typename OtherDerived>
30
+ using CwiseBinaryNotEqualReturnType =
31
+ CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_NEQ>, const Derived, const OtherDerived>;
32
+ template <typename OtherDerived>
33
+ using CwiseBinaryLessReturnType =
34
+ CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_LT>, const Derived, const OtherDerived>;
35
+ template <typename OtherDerived>
36
+ using CwiseBinaryGreaterReturnType =
37
+ CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_GT>, const Derived, const OtherDerived>;
38
+ template <typename OtherDerived>
39
+ using CwiseBinaryLessOrEqualReturnType =
40
+ CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_LE>, const Derived, const OtherDerived>;
41
+ template <typename OtherDerived>
42
+ using CwiseBinaryGreaterOrEqualReturnType =
43
+ CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_GE>, const Derived, const OtherDerived>;
44
+
45
+ /** \returns an expression of the coefficient-wise == operator of *this and \a other
46
+ *
47
+ * \warning this performs an exact comparison, which is generally a bad idea with floating-point types.
48
+ * In order to check for equality between two vectors or matrices with floating-point coefficients, it is
49
+ * generally a far better idea to use a fuzzy comparison as provided by isApprox() and
50
+ * isMuchSmallerThan().
51
+ *
52
+ * Example: \include MatrixBase_cwiseEqual.cpp
53
+ * Output: \verbinclude MatrixBase_cwiseEqual.out
54
+ *
55
+ * \sa cwiseNotEqual(), isApprox(), isMuchSmallerThan()
56
+ */
57
+ template <typename OtherDerived>
58
+ EIGEN_DEVICE_FUNC inline const CwiseBinaryEqualReturnType<OtherDerived> cwiseEqual(
59
+ const EIGEN_CURRENT_STORAGE_BASE_CLASS<OtherDerived>& other) const {
60
+ return CwiseBinaryEqualReturnType<OtherDerived>(derived(), other.derived());
61
+ }
62
+
63
+ /** \returns an expression of the coefficient-wise != operator of *this and \a other
64
+ *
65
+ * \warning this performs an exact comparison, which is generally a bad idea with floating-point types.
66
+ * In order to check for equality between two vectors or matrices with floating-point coefficients, it is
67
+ * generally a far better idea to use a fuzzy comparison as provided by isApprox() and
68
+ * isMuchSmallerThan().
69
+ *
70
+ * Example: \include MatrixBase_cwiseNotEqual.cpp
71
+ * Output: \verbinclude MatrixBase_cwiseNotEqual.out
72
+ *
73
+ * \sa cwiseEqual(), isApprox(), isMuchSmallerThan()
74
+ */
75
+ template <typename OtherDerived>
76
+ EIGEN_DEVICE_FUNC inline const CwiseBinaryNotEqualReturnType<OtherDerived> cwiseNotEqual(
77
+ const EIGEN_CURRENT_STORAGE_BASE_CLASS<OtherDerived>& other) const {
78
+ return CwiseBinaryNotEqualReturnType<OtherDerived>(derived(), other.derived());
79
+ }
80
+
81
+ /** \returns an expression of the coefficient-wise < operator of *this and \a other */
82
+ template <typename OtherDerived>
83
+ EIGEN_DEVICE_FUNC inline const CwiseBinaryLessReturnType<OtherDerived> cwiseLess(
84
+ const EIGEN_CURRENT_STORAGE_BASE_CLASS<OtherDerived>& other) const {
85
+ return CwiseBinaryLessReturnType<OtherDerived>(derived(), other.derived());
86
+ }
87
+
88
+ /** \returns an expression of the coefficient-wise > operator of *this and \a other */
89
+ template <typename OtherDerived>
90
+ EIGEN_DEVICE_FUNC inline const CwiseBinaryGreaterReturnType<OtherDerived> cwiseGreater(
91
+ const EIGEN_CURRENT_STORAGE_BASE_CLASS<OtherDerived>& other) const {
92
+ return CwiseBinaryGreaterReturnType<OtherDerived>(derived(), other.derived());
93
+ }
94
+
95
+ /** \returns an expression of the coefficient-wise <= operator of *this and \a other */
96
+ template <typename OtherDerived>
97
+ EIGEN_DEVICE_FUNC inline const CwiseBinaryLessOrEqualReturnType<OtherDerived> cwiseLessOrEqual(
98
+ const EIGEN_CURRENT_STORAGE_BASE_CLASS<OtherDerived>& other) const {
99
+ return CwiseBinaryLessOrEqualReturnType<OtherDerived>(derived(), other.derived());
100
+ }
101
+
102
+ /** \returns an expression of the coefficient-wise >= operator of *this and \a other */
103
+ template <typename OtherDerived>
104
+ EIGEN_DEVICE_FUNC inline const CwiseBinaryGreaterOrEqualReturnType<OtherDerived> cwiseGreaterOrEqual(
105
+ const EIGEN_CURRENT_STORAGE_BASE_CLASS<OtherDerived>& other) const {
106
+ return CwiseBinaryGreaterOrEqualReturnType<OtherDerived>(derived(), other.derived());
107
+ }
108
+
109
+ /** \returns an expression of the coefficient-wise min of *this and \a other
110
+ *
111
+ * Example: \include MatrixBase_cwiseMin.cpp
112
+ * Output: \verbinclude MatrixBase_cwiseMin.out
113
+ *
114
+ * \sa class CwiseBinaryOp, max()
115
+ */
116
+ template <int NaNPropagation = PropagateFast, typename OtherDerived>
117
+ EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const
118
+ CwiseBinaryOp<internal::scalar_min_op<Scalar, Scalar, NaNPropagation>, const Derived, const OtherDerived>
119
+ cwiseMin(const EIGEN_CURRENT_STORAGE_BASE_CLASS<OtherDerived>& other) const {
120
+ return CwiseBinaryOp<internal::scalar_min_op<Scalar, Scalar, NaNPropagation>, const Derived, const OtherDerived>(
121
+ derived(), other.derived());
122
+ }
123
+
124
+ /** \returns an expression of the coefficient-wise min of *this and scalar \a other
125
+ *
126
+ * \sa class CwiseBinaryOp, min()
127
+ */
128
+ template <int NaNPropagation = PropagateFast>
129
+ EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const
130
+ CwiseBinaryOp<internal::scalar_min_op<Scalar, Scalar, NaNPropagation>, const Derived, const ConstantReturnType>
131
+ cwiseMin(const Scalar& other) const {
132
+ return cwiseMin<NaNPropagation>(Derived::Constant(rows(), cols(), other));
133
+ }
134
+
135
+ /** \returns an expression of the coefficient-wise max of *this and \a other
136
+ *
137
+ * Example: \include MatrixBase_cwiseMax.cpp
138
+ * Output: \verbinclude MatrixBase_cwiseMax.out
139
+ *
140
+ * \sa class CwiseBinaryOp, min()
141
+ */
142
+ template <int NaNPropagation = PropagateFast, typename OtherDerived>
143
+ EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const
144
+ CwiseBinaryOp<internal::scalar_max_op<Scalar, Scalar, NaNPropagation>, const Derived, const OtherDerived>
145
+ cwiseMax(const EIGEN_CURRENT_STORAGE_BASE_CLASS<OtherDerived>& other) const {
146
+ return CwiseBinaryOp<internal::scalar_max_op<Scalar, Scalar, NaNPropagation>, const Derived, const OtherDerived>(
147
+ derived(), other.derived());
148
+ }
149
+
150
+ /** \returns an expression of the coefficient-wise max of *this and scalar \a other
151
+ *
152
+ * \sa class CwiseBinaryOp, min()
153
+ */
154
+ template <int NaNPropagation = PropagateFast>
155
+ EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const
156
+ CwiseBinaryOp<internal::scalar_max_op<Scalar, Scalar, NaNPropagation>, const Derived, const ConstantReturnType>
157
+ cwiseMax(const Scalar& other) const {
158
+ return cwiseMax<NaNPropagation>(Derived::Constant(rows(), cols(), other));
159
+ }
160
+
161
+ /** \returns an expression of the coefficient-wise quotient of *this and \a other
162
+ *
163
+ * Example: \include MatrixBase_cwiseQuotient.cpp
164
+ * Output: \verbinclude MatrixBase_cwiseQuotient.out
165
+ *
166
+ * \sa class CwiseBinaryOp, cwiseProduct(), cwiseInverse()
167
+ */
168
+ template <typename OtherDerived>
169
+ EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const
170
+ CwiseBinaryOp<internal::scalar_quotient_op<Scalar>, const Derived, const OtherDerived>
171
+ cwiseQuotient(const EIGEN_CURRENT_STORAGE_BASE_CLASS<OtherDerived>& other) const {
172
+ return CwiseBinaryOp<internal::scalar_quotient_op<Scalar>, const Derived, const OtherDerived>(derived(),
173
+ other.derived());
174
+ }
175
+
176
+ using CwiseScalarEqualReturnType =
177
+ CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_EQ>, const Derived, const ConstantReturnType>;
178
+ using CwiseScalarNotEqualReturnType =
179
+ CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_NEQ>, const Derived, const ConstantReturnType>;
180
+ using CwiseScalarLessReturnType =
181
+ CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_LT>, const Derived, const ConstantReturnType>;
182
+ using CwiseScalarGreaterReturnType =
183
+ CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_GT>, const Derived, const ConstantReturnType>;
184
+ using CwiseScalarLessOrEqualReturnType =
185
+ CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_LE>, const Derived, const ConstantReturnType>;
186
+ using CwiseScalarGreaterOrEqualReturnType =
187
+ CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_GE>, const Derived, const ConstantReturnType>;
188
+
189
+ /** \returns an expression of the coefficient-wise == operator of \c *this and a scalar \a s
190
+ *
191
+ * \warning this performs an exact comparison, which is generally a bad idea with floating-point types.
192
+ * In order to check for equality between two vectors or matrices with floating-point coefficients, it is
193
+ * generally a far better idea to use a fuzzy comparison as provided by isApprox() and
194
+ * isMuchSmallerThan().
195
+ *
196
+ * \sa cwiseEqual(const MatrixBase<OtherDerived> &) const
197
+ */
198
+ EIGEN_DEVICE_FUNC inline const CwiseScalarEqualReturnType cwiseEqual(const Scalar& s) const {
199
+ return CwiseScalarEqualReturnType(derived(), Derived::Constant(rows(), cols(), s));
200
+ }
201
+
202
+ /** \returns an expression of the coefficient-wise == operator of \c *this and a scalar \a s
203
+ *
204
+ * \warning this performs an exact comparison, which is generally a bad idea with floating-point types.
205
+ * In order to check for equality between two vectors or matrices with floating-point coefficients, it is
206
+ * generally a far better idea to use a fuzzy comparison as provided by isApprox() and
207
+ * isMuchSmallerThan().
208
+ *
209
+ * \sa cwiseEqual(const MatrixBase<OtherDerived> &) const
210
+ */
211
+ EIGEN_DEVICE_FUNC inline const CwiseScalarNotEqualReturnType cwiseNotEqual(const Scalar& s) const {
212
+ return CwiseScalarNotEqualReturnType(derived(), Derived::Constant(rows(), cols(), s));
213
+ }
214
+
215
+ /** \returns an expression of the coefficient-wise < operator of \c *this and a scalar \a s */
216
+ EIGEN_DEVICE_FUNC inline const CwiseScalarLessReturnType cwiseLess(const Scalar& s) const {
217
+ return CwiseScalarLessReturnType(derived(), Derived::Constant(rows(), cols(), s));
218
+ }
219
+
220
+ /** \returns an expression of the coefficient-wise > operator of \c *this and a scalar \a s */
221
+ EIGEN_DEVICE_FUNC inline const CwiseScalarGreaterReturnType cwiseGreater(const Scalar& s) const {
222
+ return CwiseScalarGreaterReturnType(derived(), Derived::Constant(rows(), cols(), s));
223
+ }
224
+
225
+ /** \returns an expression of the coefficient-wise <= operator of \c *this and a scalar \a s */
226
+ EIGEN_DEVICE_FUNC inline const CwiseScalarLessOrEqualReturnType cwiseLessOrEqual(const Scalar& s) const {
227
+ return CwiseScalarLessOrEqualReturnType(derived(), Derived::Constant(rows(), cols(), s));
228
+ }
229
+
230
+ /** \returns an expression of the coefficient-wise >= operator of \c *this and a scalar \a s */
231
+ EIGEN_DEVICE_FUNC inline const CwiseScalarGreaterOrEqualReturnType cwiseGreaterOrEqual(const Scalar& s) const {
232
+ return CwiseScalarGreaterOrEqualReturnType(derived(), Derived::Constant(rows(), cols(), s));
233
+ }
234
+
235
+ template <typename OtherDerived>
236
+ using CwiseBinaryTypedEqualReturnType =
237
+ CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_EQ, true>, const Derived, const OtherDerived>;
238
+ template <typename OtherDerived>
239
+ using CwiseBinaryTypedNotEqualReturnType =
240
+ CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_NEQ, true>, const Derived, const OtherDerived>;
241
+ template <typename OtherDerived>
242
+ using CwiseBinaryTypedLessReturnType =
243
+ CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_LT, true>, const Derived, const OtherDerived>;
244
+ template <typename OtherDerived>
245
+ using CwiseBinaryTypedGreaterReturnType =
246
+ CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_GT, true>, const Derived, const OtherDerived>;
247
+ template <typename OtherDerived>
248
+ using CwiseBinaryTypedLessOrEqualReturnType =
249
+ CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_LE, true>, const Derived, const OtherDerived>;
250
+ template <typename OtherDerived>
251
+ using CwiseBinaryTypedGreaterOrEqualReturnType =
252
+ CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_GE, true>, const Derived, const OtherDerived>;
253
+
254
+ template <typename OtherDerived>
255
+ EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const CwiseBinaryTypedEqualReturnType<OtherDerived> cwiseTypedEqual(
256
+ const EIGEN_CURRENT_STORAGE_BASE_CLASS<OtherDerived>& other) const {
257
+ return CwiseBinaryTypedEqualReturnType<OtherDerived>(derived(), other.derived());
258
+ }
259
+
260
+ template <typename OtherDerived>
261
+ EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const CwiseBinaryTypedNotEqualReturnType<OtherDerived> cwiseTypedNotEqual(
262
+ const EIGEN_CURRENT_STORAGE_BASE_CLASS<OtherDerived>& other) const {
263
+ return CwiseBinaryTypedNotEqualReturnType<OtherDerived>(derived(), other.derived());
264
+ }
265
+
266
+ template <typename OtherDerived>
267
+ EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const CwiseBinaryTypedLessReturnType<OtherDerived> cwiseTypedLess(
268
+ const EIGEN_CURRENT_STORAGE_BASE_CLASS<OtherDerived>& other) const {
269
+ return CwiseBinaryTypedLessReturnType<OtherDerived>(derived(), other.derived());
270
+ }
271
+
272
+ template <typename OtherDerived>
273
+ EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const CwiseBinaryTypedGreaterReturnType<OtherDerived> cwiseTypedGreater(
274
+ const EIGEN_CURRENT_STORAGE_BASE_CLASS<OtherDerived>& other) const {
275
+ return CwiseBinaryTypedGreaterReturnType<OtherDerived>(derived(), other.derived());
276
+ }
277
+
278
+ template <typename OtherDerived>
279
+ EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const CwiseBinaryTypedLessOrEqualReturnType<OtherDerived> cwiseTypedLessOrEqual(
280
+ const EIGEN_CURRENT_STORAGE_BASE_CLASS<OtherDerived>& other) const {
281
+ return CwiseBinaryTypedLessOrEqualReturnType<OtherDerived>(derived(), other.derived());
282
+ }
283
+
284
+ template <typename OtherDerived>
285
+ EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const CwiseBinaryTypedGreaterOrEqualReturnType<OtherDerived>
286
+ cwiseTypedGreaterOrEqual(const EIGEN_CURRENT_STORAGE_BASE_CLASS<OtherDerived>& other) const {
287
+ return CwiseBinaryTypedGreaterOrEqualReturnType<OtherDerived>(derived(), other.derived());
288
+ }
289
+
290
+ using CwiseScalarTypedEqualReturnType = CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_EQ, true>,
291
+ const Derived, const ConstantReturnType>;
292
+ using CwiseScalarTypedNotEqualReturnType =
293
+ CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_NEQ, true>, const Derived,
294
+ const ConstantReturnType>;
295
+ using CwiseScalarTypedLessReturnType = CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_LT, true>,
296
+ const Derived, const ConstantReturnType>;
297
+ using CwiseScalarTypedGreaterReturnType = CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_GT, true>,
298
+ const Derived, const ConstantReturnType>;
299
+ using CwiseScalarTypedLessOrEqualReturnType =
300
+ CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_LE, true>, const Derived,
301
+ const ConstantReturnType>;
302
+ using CwiseScalarTypedGreaterOrEqualReturnType =
303
+ CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_GE, true>, const Derived,
304
+ const ConstantReturnType>;
305
+
306
+ EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const CwiseScalarTypedEqualReturnType cwiseTypedEqual(const Scalar& s) const {
307
+ return CwiseScalarTypedEqualReturnType(derived(), ConstantReturnType(rows(), cols(), s));
308
+ }
309
+
310
+ EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const CwiseScalarTypedNotEqualReturnType
311
+ cwiseTypedNotEqual(const Scalar& s) const {
312
+ return CwiseScalarTypedNotEqualReturnType(derived(), ConstantReturnType(rows(), cols(), s));
313
+ }
314
+
315
+ EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const CwiseScalarTypedLessReturnType cwiseTypedLess(const Scalar& s) const {
316
+ return CwiseScalarTypedLessReturnType(derived(), ConstantReturnType(rows(), cols(), s));
317
+ }
318
+
319
+ EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const CwiseScalarTypedGreaterReturnType cwiseTypedGreater(const Scalar& s) const {
320
+ return CwiseScalarTypedGreaterReturnType(derived(), ConstantReturnType(rows(), cols(), s));
321
+ }
322
+
323
+ EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const CwiseScalarTypedLessOrEqualReturnType
324
+ cwiseTypedLessOrEqual(const Scalar& s) const {
325
+ return CwiseScalarTypedLessOrEqualReturnType(derived(), ConstantReturnType(rows(), cols(), s));
326
+ }
327
+
328
+ EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const CwiseScalarTypedGreaterOrEqualReturnType
329
+ cwiseTypedGreaterOrEqual(const Scalar& s) const {
330
+ return CwiseScalarTypedGreaterOrEqualReturnType(derived(), ConstantReturnType(rows(), cols(), s));
331
+ }
@@ -0,0 +1,118 @@
1
+ // This file is part of Eigen, a lightweight C++ template library
2
+ // for linear algebra.
3
+ //
4
+ // Copyright (C) 2008-2009 Gael Guennebaud <gael.guennebaud@inria.fr>
5
+ // Copyright (C) 2006-2008 Benoit Jacob <jacob.benoit.1@gmail.com>
6
+ //
7
+ // This Source Code Form is subject to the terms of the Mozilla
8
+ // Public License v. 2.0. If a copy of the MPL was not distributed
9
+ // with this file, You can obtain one at http://mozilla.org/MPL/2.0/.
10
+
11
+ // This file is included into the body of the base classes supporting matrix specific coefficient-wise functions.
12
+ // This include MatrixBase and SparseMatrixBase.
13
+
14
+ typedef CwiseUnaryOp<internal::scalar_abs_op<Scalar>, const Derived> CwiseAbsReturnType;
15
+ typedef CwiseUnaryOp<internal::scalar_abs2_op<Scalar>, const Derived> CwiseAbs2ReturnType;
16
+ typedef CwiseUnaryOp<internal::scalar_arg_op<Scalar>, const Derived> CwiseArgReturnType;
17
+ typedef CwiseUnaryOp<internal::scalar_carg_op<Scalar>, const Derived> CwiseCArgReturnType;
18
+ typedef CwiseUnaryOp<internal::scalar_sqrt_op<Scalar>, const Derived> CwiseSqrtReturnType;
19
+ typedef CwiseUnaryOp<internal::scalar_cbrt_op<Scalar>, const Derived> CwiseCbrtReturnType;
20
+ typedef CwiseUnaryOp<internal::scalar_square_op<Scalar>, const Derived> CwiseSquareReturnType;
21
+ typedef CwiseUnaryOp<internal::scalar_sign_op<Scalar>, const Derived> CwiseSignReturnType;
22
+ typedef CwiseUnaryOp<internal::scalar_inverse_op<Scalar>, const Derived> CwiseInverseReturnType;
23
+
24
+ /// \returns an expression of the coefficient-wise absolute value of \c *this
25
+ ///
26
+ /// Example: \include MatrixBase_cwiseAbs.cpp
27
+ /// Output: \verbinclude MatrixBase_cwiseAbs.out
28
+ ///
29
+ EIGEN_DOC_UNARY_ADDONS(cwiseAbs, absolute value)
30
+ ///
31
+ /// \sa cwiseAbs2()
32
+ ///
33
+ EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const CwiseAbsReturnType cwiseAbs() const {
34
+ return CwiseAbsReturnType(derived());
35
+ }
36
+
37
+ /// \returns an expression of the coefficient-wise squared absolute value of \c *this
38
+ ///
39
+ /// Example: \include MatrixBase_cwiseAbs2.cpp
40
+ /// Output: \verbinclude MatrixBase_cwiseAbs2.out
41
+ ///
42
+ EIGEN_DOC_UNARY_ADDONS(cwiseAbs2, squared absolute value)
43
+ ///
44
+ /// \sa cwiseAbs()
45
+ ///
46
+ EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const CwiseAbs2ReturnType cwiseAbs2() const {
47
+ return CwiseAbs2ReturnType(derived());
48
+ }
49
+
50
+ /// \returns an expression of the coefficient-wise square root of *this.
51
+ ///
52
+ /// Example: \include MatrixBase_cwiseSqrt.cpp
53
+ /// Output: \verbinclude MatrixBase_cwiseSqrt.out
54
+ ///
55
+ EIGEN_DOC_UNARY_ADDONS(cwiseSqrt, square - root)
56
+ ///
57
+ /// \sa cwisePow(), cwiseSquare(), cwiseCbrt()
58
+ ///
59
+ EIGEN_DEVICE_FUNC inline const CwiseSqrtReturnType cwiseSqrt() const { return CwiseSqrtReturnType(derived()); }
60
+
61
+ /// \returns an expression of the coefficient-wise cube root of *this.
62
+ ///
63
+ EIGEN_DOC_UNARY_ADDONS(cwiseCbrt, cube - root)
64
+ ///
65
+ /// \sa cwiseSqrt(), cwiseSquare(), cwisePow()
66
+ ///
67
+ EIGEN_DEVICE_FUNC inline const CwiseCbrtReturnType cwiseCbrt() const { return CwiseCbrtReturnType(derived()); }
68
+
69
+ /// \returns an expression of the coefficient-wise square of *this.
70
+ ///
71
+ EIGEN_DOC_UNARY_ADDONS(cwiseSquare, square)
72
+ ///
73
+ /// \sa cwisePow(), cwiseSqrt(), cwiseCbrt()
74
+ ///
75
+ EIGEN_DEVICE_FUNC inline const CwiseSquareReturnType cwiseSquare() const { return CwiseSquareReturnType(derived()); }
76
+
77
+ /// \returns an expression of the coefficient-wise signum of *this.
78
+ ///
79
+ /// Example: \include MatrixBase_cwiseSign.cpp
80
+ /// Output: \verbinclude MatrixBase_cwiseSign.out
81
+ ///
82
+ EIGEN_DOC_UNARY_ADDONS(cwiseSign, sign function)
83
+ ///
84
+ EIGEN_DEVICE_FUNC inline const CwiseSignReturnType cwiseSign() const { return CwiseSignReturnType(derived()); }
85
+
86
+ /// \returns an expression of the coefficient-wise inverse of *this.
87
+ ///
88
+ /// Example: \include MatrixBase_cwiseInverse.cpp
89
+ /// Output: \verbinclude MatrixBase_cwiseInverse.out
90
+ ///
91
+ EIGEN_DOC_UNARY_ADDONS(cwiseInverse, inverse)
92
+ ///
93
+ /// \sa cwiseProduct()
94
+ ///
95
+ EIGEN_DEVICE_FUNC inline const CwiseInverseReturnType cwiseInverse() const { return CwiseInverseReturnType(derived()); }
96
+
97
+ /// \returns an expression of the coefficient-wise phase angle of \c *this
98
+ ///
99
+ /// Example: \include MatrixBase_cwiseArg.cpp
100
+ /// Output: \verbinclude MatrixBase_cwiseArg.out
101
+ ///
102
+ EIGEN_DOC_UNARY_ADDONS(cwiseArg, arg)
103
+
104
+ EIGEN_DEVICE_FUNC inline const CwiseArgReturnType cwiseArg() const { return CwiseArgReturnType(derived()); }
105
+
106
+ EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const CwiseCArgReturnType cwiseCArg() const {
107
+ return CwiseCArgReturnType(derived());
108
+ }
109
+
110
+ template <typename ScalarExponent>
111
+ using CwisePowReturnType =
112
+ std::enable_if_t<internal::is_arithmetic<typename NumTraits<ScalarExponent>::Real>::value,
113
+ CwiseUnaryOp<internal::scalar_unary_pow_op<Scalar, ScalarExponent>, const Derived>>;
114
+
115
+ template <typename ScalarExponent>
116
+ EIGEN_DEVICE_FUNC inline const CwisePowReturnType<ScalarExponent> cwisePow(const ScalarExponent& exponent) const {
117
+ return CwisePowReturnType<ScalarExponent>(derived(), internal::scalar_unary_pow_op<Scalar, ScalarExponent>(exponent));
118
+ }
@@ -0,0 +1,133 @@
1
+
2
+ #ifdef EIGEN_PARSED_BY_DOXYGEN
3
+
4
+ /// \returns an expression of \c *this with reshaped sizes.
5
+ ///
6
+ /// \param nRows the number of rows in the reshaped expression, specified at either run-time or compile-time, or
7
+ /// AutoSize \param nCols the number of columns in the reshaped expression, specified at either run-time or
8
+ /// compile-time, or AutoSize \tparam Order specifies whether the coefficients should be processed in column-major-order
9
+ /// (ColMajor), in row-major-order (RowMajor),
10
+ /// or follows the \em natural order of the nested expression (AutoOrder). The default is ColMajor.
11
+ /// \tparam NRowsType the type of the value handling the number of rows, typically Index.
12
+ /// \tparam NColsType the type of the value handling the number of columns, typically Index.
13
+ ///
14
+ /// Dynamic size example: \include MatrixBase_reshaped_int_int.cpp
15
+ /// Output: \verbinclude MatrixBase_reshaped_int_int.out
16
+ ///
17
+ /// The number of rows \a nRows and columns \a nCols can also be specified at compile-time by passing Eigen::fix<N>,
18
+ /// or Eigen::fix<N>(n) as arguments. In the later case, \c n plays the role of a runtime fallback value in case \c N
19
+ /// equals Eigen::Dynamic. Here is an example with a fixed number of rows and columns: \include
20
+ /// MatrixBase_reshaped_fixed.cpp Output: \verbinclude MatrixBase_reshaped_fixed.out
21
+ ///
22
+ /// Finally, one of the sizes parameter can be automatically deduced from the other one by passing AutoSize as in the
23
+ /// following example: \include MatrixBase_reshaped_auto.cpp Output: \verbinclude MatrixBase_reshaped_auto.out AutoSize
24
+ /// does preserve compile-time sizes when possible, i.e., when the sizes of the input are known at compile time \b and
25
+ /// that the other size is passed at compile-time using Eigen::fix<N> as above.
26
+ ///
27
+ /// \sa class Reshaped, fix, fix<N>(int)
28
+ ///
29
+ template <int Order = ColMajor, typename NRowsType, typename NColsType>
30
+ EIGEN_DEVICE_FUNC inline Reshaped<Derived, ...> reshaped(NRowsType nRows, NColsType nCols);
31
+
32
+ /// This is the const version of reshaped(NRowsType,NColsType).
33
+ template <int Order = ColMajor, typename NRowsType, typename NColsType>
34
+ EIGEN_DEVICE_FUNC inline const Reshaped<const Derived, ...> reshaped(NRowsType nRows, NColsType nCols) const;
35
+
36
+ /// \returns an expression of \c *this with columns (or rows) stacked to a linear column vector
37
+ ///
38
+ /// \tparam Order specifies whether the coefficients should be processed in column-major-order (ColMajor), in
39
+ /// row-major-order (RowMajor),
40
+ /// or follows the \em natural order of the nested expression (AutoOrder). The default is ColMajor.
41
+ ///
42
+ /// This overloads is essentially a shortcut for `A.reshaped<Order>(AutoSize,fix<1>)`.
43
+ ///
44
+ /// - If `Order==ColMajor` (the default), then it returns a column-vector from the stacked columns of \c *this.
45
+ /// - If `Order==RowMajor`, then it returns a column-vector from the stacked rows of \c *this.
46
+ /// - If `Order==AutoOrder`, then it returns a column-vector with elements stacked following the storage order of \c
47
+ /// *this.
48
+ /// This mode is the recommended one when the particular ordering of the element is not relevant.
49
+ ///
50
+ /// Example:
51
+ /// \include MatrixBase_reshaped_to_vector.cpp
52
+ /// Output: \verbinclude MatrixBase_reshaped_to_vector.out
53
+ ///
54
+ /// If you want more control, you can still fall back to reshaped(NRowsType,NColsType).
55
+ ///
56
+ /// \sa reshaped(NRowsType,NColsType), class Reshaped
57
+ ///
58
+ template <int Order = ColMajor>
59
+ EIGEN_DEVICE_FUNC inline Reshaped<Derived, ...> reshaped();
60
+
61
+ /// This is the const version of reshaped().
62
+ template <int Order = ColMajor>
63
+ EIGEN_DEVICE_FUNC inline const Reshaped<const Derived, ...> reshaped() const;
64
+
65
+ #else
66
+
67
+ // This file is automatically included twice to generate const and non-const versions
68
+
69
+ #ifndef EIGEN_RESHAPED_METHOD_2ND_PASS
70
+ #define EIGEN_RESHAPED_METHOD_CONST const
71
+ #else
72
+ #define EIGEN_RESHAPED_METHOD_CONST
73
+ #endif
74
+
75
+ #ifndef EIGEN_RESHAPED_METHOD_2ND_PASS
76
+
77
+ // This part is included once
78
+
79
+ #endif
80
+
81
+ template <typename NRowsType, typename NColsType>
82
+ EIGEN_DEVICE_FUNC inline Reshaped<
83
+ EIGEN_RESHAPED_METHOD_CONST Derived,
84
+ internal::get_compiletime_reshape_size<NRowsType, NColsType, SizeAtCompileTime>::value,
85
+ internal::get_compiletime_reshape_size<NColsType, NRowsType, SizeAtCompileTime>::value>
86
+ reshaped(NRowsType nRows, NColsType nCols) EIGEN_RESHAPED_METHOD_CONST {
87
+ return Reshaped<EIGEN_RESHAPED_METHOD_CONST Derived,
88
+ internal::get_compiletime_reshape_size<NRowsType, NColsType, SizeAtCompileTime>::value,
89
+ internal::get_compiletime_reshape_size<NColsType, NRowsType, SizeAtCompileTime>::value>(
90
+ derived(), internal::get_runtime_reshape_size(nRows, internal::get_runtime_value(nCols), size()),
91
+ internal::get_runtime_reshape_size(nCols, internal::get_runtime_value(nRows), size()));
92
+ }
93
+
94
+ template <int Order, typename NRowsType, typename NColsType>
95
+ EIGEN_DEVICE_FUNC inline Reshaped<
96
+ EIGEN_RESHAPED_METHOD_CONST Derived,
97
+ internal::get_compiletime_reshape_size<NRowsType, NColsType, SizeAtCompileTime>::value,
98
+ internal::get_compiletime_reshape_size<NColsType, NRowsType, SizeAtCompileTime>::value,
99
+ internal::get_compiletime_reshape_order(Flags, Order)>
100
+ reshaped(NRowsType nRows, NColsType nCols) EIGEN_RESHAPED_METHOD_CONST {
101
+ return Reshaped<EIGEN_RESHAPED_METHOD_CONST Derived,
102
+ internal::get_compiletime_reshape_size<NRowsType, NColsType, SizeAtCompileTime>::value,
103
+ internal::get_compiletime_reshape_size<NColsType, NRowsType, SizeAtCompileTime>::value,
104
+ internal::get_compiletime_reshape_order(Flags, Order)>(
105
+ derived(), internal::get_runtime_reshape_size(nRows, internal::get_runtime_value(nCols), size()),
106
+ internal::get_runtime_reshape_size(nCols, internal::get_runtime_value(nRows), size()));
107
+ }
108
+
109
+ // Views as linear vectors
110
+
111
+ EIGEN_DEVICE_FUNC inline Reshaped<EIGEN_RESHAPED_METHOD_CONST Derived, SizeAtCompileTime, 1> reshaped()
112
+ EIGEN_RESHAPED_METHOD_CONST {
113
+ return Reshaped<EIGEN_RESHAPED_METHOD_CONST Derived, SizeAtCompileTime, 1>(derived(), size(), 1);
114
+ }
115
+
116
+ template <int Order>
117
+ EIGEN_DEVICE_FUNC inline Reshaped<EIGEN_RESHAPED_METHOD_CONST Derived, SizeAtCompileTime, 1,
118
+ internal::get_compiletime_reshape_order(Flags, Order)>
119
+ reshaped() EIGEN_RESHAPED_METHOD_CONST {
120
+ EIGEN_STATIC_ASSERT(Order == RowMajor || Order == ColMajor || Order == AutoOrder, INVALID_TEMPLATE_PARAMETER);
121
+ return Reshaped<EIGEN_RESHAPED_METHOD_CONST Derived, SizeAtCompileTime, 1,
122
+ internal::get_compiletime_reshape_order(Flags, Order)>(derived(), size(), 1);
123
+ }
124
+
125
+ #undef EIGEN_RESHAPED_METHOD_CONST
126
+
127
+ #ifndef EIGEN_RESHAPED_METHOD_2ND_PASS
128
+ #define EIGEN_RESHAPED_METHOD_2ND_PASS
129
+ #include "ReshapedMethods.inc"
130
+ #undef EIGEN_RESHAPED_METHOD_2ND_PASS
131
+ #endif
132
+
133
+ #endif // EIGEN_PARSED_BY_DOXYGEN
@@ -0,0 +1,4 @@
1
+ import { LLVM } from '@smake/llvm';
2
+ export declare abstract class LibEigen {
3
+ static config(llvm: LLVM): void;
4
+ }
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.LibEigen = void 0;
4
+ const path_1 = require("path");
5
+ class LibEigen {
6
+ static config(llvm) {
7
+ llvm.includedirs = [
8
+ ...llvm.includedirs,
9
+ (0, path_1.resolve)(__dirname, '..', 'eigen').replace(/\\/g, '/'),
10
+ ];
11
+ }
12
+ }
13
+ exports.LibEigen = LibEigen;
14
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTGliRWlnZW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvTGliRWlnZW4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsK0JBQStCO0FBRy9CLE1BQXNCLFFBQVE7SUFDNUIsTUFBTSxDQUFDLE1BQU0sQ0FBQyxJQUFVO1FBQ3RCLElBQUksQ0FBQyxXQUFXLEdBQUc7WUFDakIsR0FBRyxJQUFJLENBQUMsV0FBVztZQUNuQixJQUFBLGNBQU8sRUFBQyxTQUFTLEVBQUUsSUFBSSxFQUFFLE9BQU8sQ0FBQyxDQUFDLE9BQU8sQ0FBQyxLQUFLLEVBQUUsR0FBRyxDQUFDO1NBQ3RELENBQUM7SUFDSixDQUFDO0NBQ0Y7QUFQRCw0QkFPQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHJlc29sdmUgfSBmcm9tICdwYXRoJztcbmltcG9ydCB7IExMVk0gfSBmcm9tICdAc21ha2UvbGx2bSc7XG5cbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBMaWJFaWdlbiB7XG4gIHN0YXRpYyBjb25maWcobGx2bTogTExWTSkge1xuICAgIGxsdm0uaW5jbHVkZWRpcnMgPSBbXG4gICAgICAuLi5sbHZtLmluY2x1ZGVkaXJzLFxuICAgICAgcmVzb2x2ZShfX2Rpcm5hbWUsICcuLicsICdlaWdlbicpLnJlcGxhY2UoL1xcXFwvZywgJy8nKSxcbiAgICBdO1xuICB9XG59XG4iXX0=
package/lib/index.d.ts CHANGED
@@ -1 +1 @@
1
- export * from './eigen';
1
+ export * from './LibEigen';
package/lib/index.js CHANGED
@@ -1,7 +1,11 @@
1
1
  "use strict";
2
2
  var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
3
  if (k2 === undefined) k2 = k;
4
- Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
5
9
  }) : (function(o, m, k, k2) {
6
10
  if (k2 === undefined) k2 = k;
7
11
  o[k2] = m[k];
@@ -10,5 +14,5 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
10
14
  for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
11
15
  };
12
16
  Object.defineProperty(exports, "__esModule", { value: true });
13
- __exportStar(require("./eigen"), exports);
14
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0FBQUEsMENBQXdCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9laWdlbic7XG4iXX0=
17
+ __exportStar(require("./LibEigen"), exports);
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLDZDQUEyQiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vTGliRWlnZW4nO1xuIl19
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@smake/eigen",
3
- "version": "1.0.2",
3
+ "version": "1.1.1",
4
4
  "description": "Typescript Module Template",
5
5
  "license": "MIT",
6
6
  "repository": "https://github.com/kuyoonjo/smake-lib-eigen.git",
@@ -36,19 +36,11 @@
36
36
  "watch": "npm run build -- --watch",
37
37
  "watch:test": "jest --watch"
38
38
  },
39
- "dependencies": {
40
- "@smake/libs": "^1.0.2",
41
- "smake": "^0.3.12"
42
- },
43
39
  "devDependencies": {
44
- "@types/jest": "^26.0.24",
40
+ "@smake/llvm": "^1.2.0",
45
41
  "@types/node": "^16.4.7",
46
- "coveralls": "^3.1.1",
47
- "jest": "^27.0.6",
48
42
  "prettier": "^2.3.2",
49
43
  "rimraf": "^3.0.2",
50
- "ts-jest": "^27.0.4",
51
- "ts-node": "^10.1.0",
52
44
  "tslint": "^6.1.3",
53
45
  "tslint-config-prettier": "^1.18.0",
54
46
  "typescript": "^4.3.5"