@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.
- package/README.md +1 -1
- package/eigen/Eigen/AccelerateSupport +52 -0
- package/eigen/Eigen/Cholesky +18 -21
- package/eigen/Eigen/CholmodSupport +28 -28
- package/eigen/Eigen/Core +235 -326
- package/eigen/Eigen/Eigenvalues +16 -14
- package/eigen/Eigen/Geometry +21 -24
- package/eigen/Eigen/Householder +9 -8
- package/eigen/Eigen/IterativeLinearSolvers +8 -4
- package/eigen/Eigen/Jacobi +14 -14
- package/eigen/Eigen/KLUSupport +43 -0
- package/eigen/Eigen/LU +16 -20
- package/eigen/Eigen/MetisSupport +12 -12
- package/eigen/Eigen/OrderingMethods +54 -54
- package/eigen/Eigen/PaStiXSupport +23 -20
- package/eigen/Eigen/PardisoSupport +17 -14
- package/eigen/Eigen/QR +18 -21
- package/eigen/Eigen/QtAlignedMalloc +5 -13
- package/eigen/Eigen/SPQRSupport +21 -14
- package/eigen/Eigen/SVD +23 -18
- package/eigen/Eigen/Sparse +1 -4
- package/eigen/Eigen/SparseCholesky +18 -23
- package/eigen/Eigen/SparseCore +18 -17
- package/eigen/Eigen/SparseLU +12 -8
- package/eigen/Eigen/SparseQR +16 -14
- package/eigen/Eigen/StdDeque +5 -2
- package/eigen/Eigen/StdList +5 -2
- package/eigen/Eigen/StdVector +5 -2
- package/eigen/Eigen/SuperLUSupport +30 -24
- package/eigen/Eigen/ThreadPool +80 -0
- package/eigen/Eigen/UmfPackSupport +19 -17
- package/eigen/Eigen/Version +14 -0
- package/eigen/Eigen/src/AccelerateSupport/AccelerateSupport.h +423 -0
- package/eigen/Eigen/src/AccelerateSupport/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/Cholesky/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/Cholesky/LDLT.h +377 -401
- package/eigen/Eigen/src/Cholesky/LLT.h +332 -360
- package/eigen/Eigen/src/Cholesky/LLT_LAPACKE.h +81 -56
- package/eigen/Eigen/src/CholmodSupport/CholmodSupport.h +620 -521
- package/eigen/Eigen/src/CholmodSupport/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/Core/ArithmeticSequence.h +239 -0
- package/eigen/Eigen/src/Core/Array.h +341 -294
- package/eigen/Eigen/src/Core/ArrayBase.h +190 -203
- package/eigen/Eigen/src/Core/ArrayWrapper.h +127 -171
- package/eigen/Eigen/src/Core/Assign.h +30 -40
- package/eigen/Eigen/src/Core/AssignEvaluator.h +711 -589
- package/eigen/Eigen/src/Core/Assign_MKL.h +130 -125
- package/eigen/Eigen/src/Core/BandMatrix.h +268 -283
- package/eigen/Eigen/src/Core/Block.h +375 -398
- package/eigen/Eigen/src/Core/CommaInitializer.h +86 -97
- package/eigen/Eigen/src/Core/ConditionEstimator.h +51 -53
- package/eigen/Eigen/src/Core/CoreEvaluators.h +1356 -1026
- package/eigen/Eigen/src/Core/CoreIterators.h +73 -59
- package/eigen/Eigen/src/Core/CwiseBinaryOp.h +114 -132
- package/eigen/Eigen/src/Core/CwiseNullaryOp.h +726 -617
- package/eigen/Eigen/src/Core/CwiseTernaryOp.h +77 -103
- package/eigen/Eigen/src/Core/CwiseUnaryOp.h +56 -68
- package/eigen/Eigen/src/Core/CwiseUnaryView.h +132 -95
- package/eigen/Eigen/src/Core/DenseBase.h +632 -571
- package/eigen/Eigen/src/Core/DenseCoeffsBase.h +511 -624
- package/eigen/Eigen/src/Core/DenseStorage.h +512 -509
- package/eigen/Eigen/src/Core/DeviceWrapper.h +153 -0
- package/eigen/Eigen/src/Core/Diagonal.h +169 -210
- package/eigen/Eigen/src/Core/DiagonalMatrix.h +351 -274
- package/eigen/Eigen/src/Core/DiagonalProduct.h +12 -10
- package/eigen/Eigen/src/Core/Dot.h +172 -222
- package/eigen/Eigen/src/Core/EigenBase.h +75 -85
- package/eigen/Eigen/src/Core/Fill.h +138 -0
- package/eigen/Eigen/src/Core/FindCoeff.h +464 -0
- package/eigen/Eigen/src/Core/ForceAlignedAccess.h +90 -109
- package/eigen/Eigen/src/Core/Fuzzy.h +82 -105
- package/eigen/Eigen/src/Core/GeneralProduct.h +327 -263
- package/eigen/Eigen/src/Core/GenericPacketMath.h +1472 -360
- package/eigen/Eigen/src/Core/GlobalFunctions.h +194 -151
- package/eigen/Eigen/src/Core/IO.h +147 -139
- package/eigen/Eigen/src/Core/IndexedView.h +321 -0
- package/eigen/Eigen/src/Core/InnerProduct.h +260 -0
- package/eigen/Eigen/src/Core/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/Core/Inverse.h +56 -66
- package/eigen/Eigen/src/Core/Map.h +124 -142
- package/eigen/Eigen/src/Core/MapBase.h +256 -281
- package/eigen/Eigen/src/Core/MathFunctions.h +1620 -938
- package/eigen/Eigen/src/Core/MathFunctionsImpl.h +233 -71
- package/eigen/Eigen/src/Core/Matrix.h +491 -416
- package/eigen/Eigen/src/Core/MatrixBase.h +468 -453
- package/eigen/Eigen/src/Core/NestByValue.h +66 -85
- package/eigen/Eigen/src/Core/NoAlias.h +79 -85
- package/eigen/Eigen/src/Core/NumTraits.h +235 -148
- package/eigen/Eigen/src/Core/PartialReduxEvaluator.h +253 -0
- package/eigen/Eigen/src/Core/PermutationMatrix.h +461 -511
- package/eigen/Eigen/src/Core/PlainObjectBase.h +871 -894
- package/eigen/Eigen/src/Core/Product.h +260 -139
- package/eigen/Eigen/src/Core/ProductEvaluators.h +863 -714
- package/eigen/Eigen/src/Core/Random.h +161 -136
- package/eigen/Eigen/src/Core/RandomImpl.h +262 -0
- package/eigen/Eigen/src/Core/RealView.h +250 -0
- package/eigen/Eigen/src/Core/Redux.h +366 -336
- package/eigen/Eigen/src/Core/Ref.h +308 -209
- package/eigen/Eigen/src/Core/Replicate.h +94 -106
- package/eigen/Eigen/src/Core/Reshaped.h +398 -0
- package/eigen/Eigen/src/Core/ReturnByValue.h +49 -55
- package/eigen/Eigen/src/Core/Reverse.h +136 -145
- package/eigen/Eigen/src/Core/Select.h +70 -140
- package/eigen/Eigen/src/Core/SelfAdjointView.h +262 -285
- package/eigen/Eigen/src/Core/SelfCwiseBinaryOp.h +23 -20
- package/eigen/Eigen/src/Core/SkewSymmetricMatrix3.h +382 -0
- package/eigen/Eigen/src/Core/Solve.h +97 -111
- package/eigen/Eigen/src/Core/SolveTriangular.h +131 -129
- package/eigen/Eigen/src/Core/SolverBase.h +138 -101
- package/eigen/Eigen/src/Core/StableNorm.h +156 -160
- package/eigen/Eigen/src/Core/StlIterators.h +619 -0
- package/eigen/Eigen/src/Core/Stride.h +91 -88
- package/eigen/Eigen/src/Core/Swap.h +70 -38
- package/eigen/Eigen/src/Core/Transpose.h +295 -273
- package/eigen/Eigen/src/Core/Transpositions.h +272 -317
- package/eigen/Eigen/src/Core/TriangularMatrix.h +670 -755
- package/eigen/Eigen/src/Core/VectorBlock.h +59 -72
- package/eigen/Eigen/src/Core/VectorwiseOp.h +668 -630
- package/eigen/Eigen/src/Core/Visitor.h +480 -216
- package/eigen/Eigen/src/Core/arch/AVX/Complex.h +407 -293
- package/eigen/Eigen/src/Core/arch/AVX/MathFunctions.h +79 -388
- package/eigen/Eigen/src/Core/arch/AVX/PacketMath.h +2935 -491
- package/eigen/Eigen/src/Core/arch/AVX/Reductions.h +353 -0
- package/eigen/Eigen/src/Core/arch/AVX/TypeCasting.h +279 -22
- package/eigen/Eigen/src/Core/arch/AVX512/Complex.h +472 -0
- package/eigen/Eigen/src/Core/arch/AVX512/GemmKernel.h +1245 -0
- package/eigen/Eigen/src/Core/arch/AVX512/MathFunctions.h +85 -333
- package/eigen/Eigen/src/Core/arch/AVX512/MathFunctionsFP16.h +75 -0
- package/eigen/Eigen/src/Core/arch/AVX512/PacketMath.h +2490 -649
- package/eigen/Eigen/src/Core/arch/AVX512/PacketMathFP16.h +1413 -0
- package/eigen/Eigen/src/Core/arch/AVX512/Reductions.h +297 -0
- package/eigen/Eigen/src/Core/arch/AVX512/TrsmKernel.h +1167 -0
- package/eigen/Eigen/src/Core/arch/AVX512/TrsmUnrolls.inc +1219 -0
- package/eigen/Eigen/src/Core/arch/AVX512/TypeCasting.h +277 -0
- package/eigen/Eigen/src/Core/arch/AVX512/TypeCastingFP16.h +130 -0
- package/eigen/Eigen/src/Core/arch/AltiVec/Complex.h +521 -298
- package/eigen/Eigen/src/Core/arch/AltiVec/MathFunctions.h +39 -280
- package/eigen/Eigen/src/Core/arch/AltiVec/MatrixProduct.h +3686 -0
- package/eigen/Eigen/src/Core/arch/AltiVec/MatrixProductCommon.h +205 -0
- package/eigen/Eigen/src/Core/arch/AltiVec/MatrixProductMMA.h +901 -0
- package/eigen/Eigen/src/Core/arch/AltiVec/MatrixProductMMAbfloat16.h +742 -0
- package/eigen/Eigen/src/Core/arch/AltiVec/MatrixVectorProduct.inc +2818 -0
- package/eigen/Eigen/src/Core/arch/AltiVec/PacketMath.h +3391 -723
- package/eigen/Eigen/src/Core/arch/AltiVec/TypeCasting.h +153 -0
- package/eigen/Eigen/src/Core/arch/Default/BFloat16.h +866 -0
- package/eigen/Eigen/src/Core/arch/Default/ConjHelper.h +113 -14
- package/eigen/Eigen/src/Core/arch/Default/GenericPacketMathFunctions.h +2634 -0
- package/eigen/Eigen/src/Core/arch/Default/GenericPacketMathFunctionsFwd.h +227 -0
- package/eigen/Eigen/src/Core/arch/Default/Half.h +1091 -0
- package/eigen/Eigen/src/Core/arch/Default/Settings.h +11 -13
- package/eigen/Eigen/src/Core/arch/GPU/Complex.h +244 -0
- package/eigen/Eigen/src/Core/arch/GPU/MathFunctions.h +104 -0
- package/eigen/Eigen/src/Core/arch/GPU/PacketMath.h +1712 -0
- package/eigen/Eigen/src/Core/arch/GPU/Tuple.h +268 -0
- package/eigen/Eigen/src/Core/arch/GPU/TypeCasting.h +77 -0
- package/eigen/Eigen/src/Core/arch/HIP/hcc/math_constants.h +23 -0
- package/eigen/Eigen/src/Core/arch/HVX/PacketMath.h +1088 -0
- package/eigen/Eigen/src/Core/arch/LSX/Complex.h +520 -0
- package/eigen/Eigen/src/Core/arch/LSX/GeneralBlockPanelKernel.h +23 -0
- package/eigen/Eigen/src/Core/arch/LSX/MathFunctions.h +43 -0
- package/eigen/Eigen/src/Core/arch/LSX/PacketMath.h +2866 -0
- package/eigen/Eigen/src/Core/arch/LSX/TypeCasting.h +526 -0
- package/eigen/Eigen/src/Core/arch/MSA/Complex.h +620 -0
- package/eigen/Eigen/src/Core/arch/MSA/MathFunctions.h +379 -0
- package/eigen/Eigen/src/Core/arch/MSA/PacketMath.h +1237 -0
- package/eigen/Eigen/src/Core/arch/NEON/Complex.h +531 -289
- package/eigen/Eigen/src/Core/arch/NEON/GeneralBlockPanelKernel.h +243 -0
- package/eigen/Eigen/src/Core/arch/NEON/MathFunctions.h +50 -73
- package/eigen/Eigen/src/Core/arch/NEON/PacketMath.h +5915 -579
- package/eigen/Eigen/src/Core/arch/NEON/TypeCasting.h +1642 -0
- package/eigen/Eigen/src/Core/arch/NEON/UnaryFunctors.h +57 -0
- package/eigen/Eigen/src/Core/arch/SSE/Complex.h +366 -334
- package/eigen/Eigen/src/Core/arch/SSE/MathFunctions.h +40 -514
- package/eigen/Eigen/src/Core/arch/SSE/PacketMath.h +2164 -675
- package/eigen/Eigen/src/Core/arch/SSE/Reductions.h +324 -0
- package/eigen/Eigen/src/Core/arch/SSE/TypeCasting.h +188 -35
- package/eigen/Eigen/src/Core/arch/SVE/MathFunctions.h +48 -0
- package/eigen/Eigen/src/Core/arch/SVE/PacketMath.h +674 -0
- package/eigen/Eigen/src/Core/arch/SVE/TypeCasting.h +52 -0
- package/eigen/Eigen/src/Core/arch/SYCL/InteropHeaders.h +227 -0
- package/eigen/Eigen/src/Core/arch/SYCL/MathFunctions.h +303 -0
- package/eigen/Eigen/src/Core/arch/SYCL/PacketMath.h +576 -0
- package/eigen/Eigen/src/Core/arch/SYCL/TypeCasting.h +83 -0
- package/eigen/Eigen/src/Core/arch/ZVector/Complex.h +434 -261
- package/eigen/Eigen/src/Core/arch/ZVector/MathFunctions.h +160 -53
- package/eigen/Eigen/src/Core/arch/ZVector/PacketMath.h +1073 -605
- package/eigen/Eigen/src/Core/functors/AssignmentFunctors.h +123 -117
- package/eigen/Eigen/src/Core/functors/BinaryFunctors.h +594 -322
- package/eigen/Eigen/src/Core/functors/NullaryFunctors.h +204 -118
- package/eigen/Eigen/src/Core/functors/StlFunctors.h +110 -97
- package/eigen/Eigen/src/Core/functors/TernaryFunctors.h +34 -7
- package/eigen/Eigen/src/Core/functors/UnaryFunctors.h +1158 -530
- package/eigen/Eigen/src/Core/products/GeneralBlockPanelKernel.h +2329 -1333
- package/eigen/Eigen/src/Core/products/GeneralMatrixMatrix.h +328 -364
- package/eigen/Eigen/src/Core/products/GeneralMatrixMatrixTriangular.h +191 -178
- package/eigen/Eigen/src/Core/products/GeneralMatrixMatrixTriangular_BLAS.h +85 -82
- package/eigen/Eigen/src/Core/products/GeneralMatrixMatrix_BLAS.h +154 -73
- package/eigen/Eigen/src/Core/products/GeneralMatrixVector.h +396 -542
- package/eigen/Eigen/src/Core/products/GeneralMatrixVector_BLAS.h +80 -77
- package/eigen/Eigen/src/Core/products/Parallelizer.h +208 -92
- package/eigen/Eigen/src/Core/products/SelfadjointMatrixMatrix.h +331 -375
- package/eigen/Eigen/src/Core/products/SelfadjointMatrixMatrix_BLAS.h +206 -224
- package/eigen/Eigen/src/Core/products/SelfadjointMatrixVector.h +139 -146
- package/eigen/Eigen/src/Core/products/SelfadjointMatrixVector_BLAS.h +58 -61
- package/eigen/Eigen/src/Core/products/SelfadjointProduct.h +71 -71
- package/eigen/Eigen/src/Core/products/SelfadjointRank2Update.h +48 -46
- package/eigen/Eigen/src/Core/products/TriangularMatrixMatrix.h +294 -369
- package/eigen/Eigen/src/Core/products/TriangularMatrixMatrix_BLAS.h +246 -238
- package/eigen/Eigen/src/Core/products/TriangularMatrixVector.h +244 -247
- package/eigen/Eigen/src/Core/products/TriangularMatrixVector_BLAS.h +212 -192
- package/eigen/Eigen/src/Core/products/TriangularSolverMatrix.h +328 -275
- package/eigen/Eigen/src/Core/products/TriangularSolverMatrix_BLAS.h +108 -109
- package/eigen/Eigen/src/Core/products/TriangularSolverVector.h +70 -93
- package/eigen/Eigen/src/Core/util/Assert.h +158 -0
- package/eigen/Eigen/src/Core/util/BlasUtil.h +413 -290
- package/eigen/Eigen/src/Core/util/ConfigureVectorization.h +543 -0
- package/eigen/Eigen/src/Core/util/Constants.h +314 -263
- package/eigen/Eigen/src/Core/util/DisableStupidWarnings.h +130 -78
- package/eigen/Eigen/src/Core/util/EmulateArray.h +270 -0
- package/eigen/Eigen/src/Core/util/ForwardDeclarations.h +450 -224
- package/eigen/Eigen/src/Core/util/GpuHipCudaDefines.inc +101 -0
- package/eigen/Eigen/src/Core/util/GpuHipCudaUndefines.inc +45 -0
- package/eigen/Eigen/src/Core/util/IndexedViewHelper.h +487 -0
- package/eigen/Eigen/src/Core/util/IntegralConstant.h +279 -0
- package/eigen/Eigen/src/Core/util/MKL_support.h +39 -30
- package/eigen/Eigen/src/Core/util/Macros.h +939 -646
- package/eigen/Eigen/src/Core/util/MaxSizeVector.h +139 -0
- package/eigen/Eigen/src/Core/util/Memory.h +1042 -650
- package/eigen/Eigen/src/Core/util/Meta.h +618 -426
- package/eigen/Eigen/src/Core/util/MoreMeta.h +638 -0
- package/eigen/Eigen/src/Core/util/ReenableStupidWarnings.h +32 -19
- package/eigen/Eigen/src/Core/util/ReshapedHelper.h +51 -0
- package/eigen/Eigen/src/Core/util/Serializer.h +209 -0
- package/eigen/Eigen/src/Core/util/StaticAssert.h +51 -164
- package/eigen/Eigen/src/Core/util/SymbolicIndex.h +445 -0
- package/eigen/Eigen/src/Core/util/XprHelper.h +793 -538
- package/eigen/Eigen/src/Eigenvalues/ComplexEigenSolver.h +246 -277
- package/eigen/Eigen/src/Eigenvalues/ComplexSchur.h +299 -319
- package/eigen/Eigen/src/Eigenvalues/ComplexSchur_LAPACKE.h +52 -48
- package/eigen/Eigen/src/Eigenvalues/EigenSolver.h +413 -456
- package/eigen/Eigen/src/Eigenvalues/GeneralizedEigenSolver.h +309 -325
- package/eigen/Eigen/src/Eigenvalues/GeneralizedSelfAdjointEigenSolver.h +157 -171
- package/eigen/Eigen/src/Eigenvalues/HessenbergDecomposition.h +292 -310
- package/eigen/Eigen/src/Eigenvalues/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/Eigenvalues/MatrixBaseEigenvalues.h +91 -107
- package/eigen/Eigen/src/Eigenvalues/RealQZ.h +539 -606
- package/eigen/Eigen/src/Eigenvalues/RealSchur.h +348 -382
- package/eigen/Eigen/src/Eigenvalues/RealSchur_LAPACKE.h +41 -35
- package/eigen/Eigen/src/Eigenvalues/SelfAdjointEigenSolver.h +579 -600
- package/eigen/Eigen/src/Eigenvalues/SelfAdjointEigenSolver_LAPACKE.h +47 -44
- package/eigen/Eigen/src/Eigenvalues/Tridiagonalization.h +434 -461
- package/eigen/Eigen/src/Geometry/AlignedBox.h +307 -214
- package/eigen/Eigen/src/Geometry/AngleAxis.h +135 -137
- package/eigen/Eigen/src/Geometry/EulerAngles.h +163 -74
- package/eigen/Eigen/src/Geometry/Homogeneous.h +289 -333
- package/eigen/Eigen/src/Geometry/Hyperplane.h +152 -161
- package/eigen/Eigen/src/Geometry/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/Geometry/OrthoMethods.h +168 -145
- package/eigen/Eigen/src/Geometry/ParametrizedLine.h +141 -104
- package/eigen/Eigen/src/Geometry/Quaternion.h +595 -497
- package/eigen/Eigen/src/Geometry/Rotation2D.h +110 -108
- package/eigen/Eigen/src/Geometry/RotationBase.h +148 -145
- package/eigen/Eigen/src/Geometry/Scaling.h +115 -90
- package/eigen/Eigen/src/Geometry/Transform.h +896 -953
- package/eigen/Eigen/src/Geometry/Translation.h +100 -98
- package/eigen/Eigen/src/Geometry/Umeyama.h +79 -84
- package/eigen/Eigen/src/Geometry/arch/Geometry_SIMD.h +154 -0
- package/eigen/Eigen/src/Householder/BlockHouseholder.h +54 -42
- package/eigen/Eigen/src/Householder/Householder.h +104 -122
- package/eigen/Eigen/src/Householder/HouseholderSequence.h +416 -382
- package/eigen/Eigen/src/Householder/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/IterativeLinearSolvers/BasicPreconditioners.h +153 -166
- package/eigen/Eigen/src/IterativeLinearSolvers/BiCGSTAB.h +127 -138
- package/eigen/Eigen/src/IterativeLinearSolvers/ConjugateGradient.h +95 -124
- package/eigen/Eigen/src/IterativeLinearSolvers/IncompleteCholesky.h +269 -267
- package/eigen/Eigen/src/IterativeLinearSolvers/IncompleteLUT.h +246 -259
- package/eigen/Eigen/src/IterativeLinearSolvers/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/IterativeLinearSolvers/IterativeSolverBase.h +218 -217
- package/eigen/Eigen/src/IterativeLinearSolvers/LeastSquareConjugateGradient.h +80 -103
- package/eigen/Eigen/src/IterativeLinearSolvers/SolveWithGuess.h +59 -63
- package/eigen/Eigen/src/Jacobi/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/Jacobi/Jacobi.h +256 -291
- package/eigen/Eigen/src/KLUSupport/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/KLUSupport/KLUSupport.h +339 -0
- package/eigen/Eigen/src/LU/Determinant.h +60 -63
- package/eigen/Eigen/src/LU/FullPivLU.h +561 -626
- package/eigen/Eigen/src/LU/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/LU/InverseImpl.h +213 -275
- package/eigen/Eigen/src/LU/PartialPivLU.h +407 -435
- package/eigen/Eigen/src/LU/PartialPivLU_LAPACKE.h +54 -40
- package/eigen/Eigen/src/LU/arch/InverseSize4.h +353 -0
- package/eigen/Eigen/src/MetisSupport/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/MetisSupport/MetisSupport.h +81 -93
- package/eigen/Eigen/src/OrderingMethods/Amd.h +250 -282
- package/eigen/Eigen/src/OrderingMethods/Eigen_Colamd.h +950 -1103
- package/eigen/Eigen/src/OrderingMethods/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/OrderingMethods/Ordering.h +111 -122
- package/eigen/Eigen/src/PaStiXSupport/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/PaStiXSupport/PaStiXSupport.h +524 -570
- package/eigen/Eigen/src/PardisoSupport/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/PardisoSupport/PardisoSupport.h +385 -429
- package/eigen/Eigen/src/QR/ColPivHouseholderQR.h +494 -473
- package/eigen/Eigen/src/QR/ColPivHouseholderQR_LAPACKE.h +120 -56
- package/eigen/Eigen/src/QR/CompleteOrthogonalDecomposition.h +223 -137
- package/eigen/Eigen/src/QR/FullPivHouseholderQR.h +517 -460
- package/eigen/Eigen/src/QR/HouseholderQR.h +412 -278
- package/eigen/Eigen/src/QR/HouseholderQR_LAPACKE.h +32 -23
- package/eigen/Eigen/src/QR/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/SPQRSupport/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/SPQRSupport/SuiteSparseQRSupport.h +263 -261
- package/eigen/Eigen/src/SVD/BDCSVD.h +872 -679
- package/eigen/Eigen/src/SVD/BDCSVD_LAPACKE.h +174 -0
- package/eigen/Eigen/src/SVD/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/SVD/JacobiSVD.h +585 -543
- package/eigen/Eigen/src/SVD/JacobiSVD_LAPACKE.h +85 -49
- package/eigen/Eigen/src/SVD/SVDBase.h +281 -160
- package/eigen/Eigen/src/SVD/UpperBidiagonalization.h +202 -237
- package/eigen/Eigen/src/SparseCholesky/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/SparseCholesky/SimplicialCholesky.h +769 -590
- package/eigen/Eigen/src/SparseCholesky/SimplicialCholesky_impl.h +318 -129
- package/eigen/Eigen/src/SparseCore/AmbiVector.h +202 -251
- package/eigen/Eigen/src/SparseCore/CompressedStorage.h +184 -236
- package/eigen/Eigen/src/SparseCore/ConservativeSparseSparseProduct.h +140 -184
- package/eigen/Eigen/src/SparseCore/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/SparseCore/SparseAssign.h +174 -111
- package/eigen/Eigen/src/SparseCore/SparseBlock.h +408 -477
- package/eigen/Eigen/src/SparseCore/SparseColEtree.h +100 -112
- package/eigen/Eigen/src/SparseCore/SparseCompressedBase.h +531 -280
- package/eigen/Eigen/src/SparseCore/SparseCwiseBinaryOp.h +559 -347
- package/eigen/Eigen/src/SparseCore/SparseCwiseUnaryOp.h +100 -108
- package/eigen/Eigen/src/SparseCore/SparseDenseProduct.h +185 -191
- package/eigen/Eigen/src/SparseCore/SparseDiagonalProduct.h +71 -71
- package/eigen/Eigen/src/SparseCore/SparseDot.h +49 -47
- package/eigen/Eigen/src/SparseCore/SparseFuzzy.h +13 -11
- package/eigen/Eigen/src/SparseCore/SparseMap.h +243 -253
- package/eigen/Eigen/src/SparseCore/SparseMatrix.h +1614 -1142
- package/eigen/Eigen/src/SparseCore/SparseMatrixBase.h +403 -357
- package/eigen/Eigen/src/SparseCore/SparsePermutation.h +186 -115
- package/eigen/Eigen/src/SparseCore/SparseProduct.h +100 -91
- package/eigen/Eigen/src/SparseCore/SparseRedux.h +22 -24
- package/eigen/Eigen/src/SparseCore/SparseRef.h +268 -295
- package/eigen/Eigen/src/SparseCore/SparseSelfAdjointView.h +371 -414
- package/eigen/Eigen/src/SparseCore/SparseSolverBase.h +78 -87
- package/eigen/Eigen/src/SparseCore/SparseSparseProductWithPruning.h +81 -95
- package/eigen/Eigen/src/SparseCore/SparseTranspose.h +62 -71
- package/eigen/Eigen/src/SparseCore/SparseTriangularView.h +132 -144
- package/eigen/Eigen/src/SparseCore/SparseUtil.h +146 -115
- package/eigen/Eigen/src/SparseCore/SparseVector.h +426 -372
- package/eigen/Eigen/src/SparseCore/SparseView.h +164 -193
- package/eigen/Eigen/src/SparseCore/TriangularSolver.h +129 -170
- package/eigen/Eigen/src/SparseLU/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/SparseLU/SparseLU.h +814 -618
- package/eigen/Eigen/src/SparseLU/SparseLUImpl.h +61 -48
- package/eigen/Eigen/src/SparseLU/SparseLU_Memory.h +102 -118
- package/eigen/Eigen/src/SparseLU/SparseLU_Structs.h +38 -35
- package/eigen/Eigen/src/SparseLU/SparseLU_SupernodalMatrix.h +273 -255
- package/eigen/Eigen/src/SparseLU/SparseLU_Utils.h +44 -49
- package/eigen/Eigen/src/SparseLU/SparseLU_column_bmod.h +104 -108
- package/eigen/Eigen/src/SparseLU/SparseLU_column_dfs.h +90 -101
- package/eigen/Eigen/src/SparseLU/SparseLU_copy_to_ucol.h +57 -58
- package/eigen/Eigen/src/SparseLU/SparseLU_heap_relax_snode.h +43 -55
- package/eigen/Eigen/src/SparseLU/SparseLU_kernel_bmod.h +74 -71
- package/eigen/Eigen/src/SparseLU/SparseLU_panel_bmod.h +125 -133
- package/eigen/Eigen/src/SparseLU/SparseLU_panel_dfs.h +136 -159
- package/eigen/Eigen/src/SparseLU/SparseLU_pivotL.h +51 -52
- package/eigen/Eigen/src/SparseLU/SparseLU_pruneL.h +67 -73
- package/eigen/Eigen/src/SparseLU/SparseLU_relax_snode.h +24 -26
- package/eigen/Eigen/src/SparseQR/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/SparseQR/SparseQR.h +451 -490
- package/eigen/Eigen/src/StlSupport/StdDeque.h +28 -105
- package/eigen/Eigen/src/StlSupport/StdList.h +28 -84
- package/eigen/Eigen/src/StlSupport/StdVector.h +28 -108
- package/eigen/Eigen/src/StlSupport/details.h +48 -50
- package/eigen/Eigen/src/SuperLUSupport/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/SuperLUSupport/SuperLUSupport.h +634 -732
- package/eigen/Eigen/src/ThreadPool/Barrier.h +70 -0
- package/eigen/Eigen/src/ThreadPool/CoreThreadPoolDevice.h +336 -0
- package/eigen/Eigen/src/ThreadPool/EventCount.h +241 -0
- package/eigen/Eigen/src/ThreadPool/ForkJoin.h +140 -0
- package/eigen/Eigen/src/ThreadPool/InternalHeaderCheck.h +4 -0
- package/eigen/Eigen/src/ThreadPool/NonBlockingThreadPool.h +587 -0
- package/eigen/Eigen/src/ThreadPool/RunQueue.h +230 -0
- package/eigen/Eigen/src/ThreadPool/ThreadCancel.h +21 -0
- package/eigen/Eigen/src/ThreadPool/ThreadEnvironment.h +43 -0
- package/eigen/Eigen/src/ThreadPool/ThreadLocal.h +289 -0
- package/eigen/Eigen/src/ThreadPool/ThreadPoolInterface.h +50 -0
- package/eigen/Eigen/src/ThreadPool/ThreadYield.h +16 -0
- package/eigen/Eigen/src/UmfPackSupport/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/UmfPackSupport/UmfPackSupport.h +480 -380
- package/eigen/Eigen/src/misc/Image.h +41 -43
- package/eigen/Eigen/src/misc/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/misc/Kernel.h +39 -41
- package/eigen/Eigen/src/misc/RealSvd2x2.h +19 -21
- package/eigen/Eigen/src/misc/blas.h +83 -426
- package/eigen/Eigen/src/misc/lapacke.h +9976 -16182
- package/eigen/Eigen/src/misc/lapacke_helpers.h +163 -0
- package/eigen/Eigen/src/misc/lapacke_mangling.h +4 -5
- package/eigen/Eigen/src/plugins/ArrayCwiseBinaryOps.inc +344 -0
- package/eigen/Eigen/src/plugins/ArrayCwiseUnaryOps.inc +544 -0
- package/eigen/Eigen/src/plugins/BlockMethods.inc +1370 -0
- package/eigen/Eigen/src/plugins/CommonCwiseBinaryOps.inc +116 -0
- package/eigen/Eigen/src/plugins/CommonCwiseUnaryOps.inc +167 -0
- package/eigen/Eigen/src/plugins/IndexedViewMethods.inc +192 -0
- package/eigen/Eigen/src/plugins/InternalHeaderCheck.inc +3 -0
- package/eigen/Eigen/src/plugins/MatrixCwiseBinaryOps.inc +331 -0
- package/eigen/Eigen/src/plugins/MatrixCwiseUnaryOps.inc +118 -0
- package/eigen/Eigen/src/plugins/ReshapedMethods.inc +133 -0
- package/lib/LibEigen.d.ts +4 -0
- package/lib/LibEigen.js +14 -0
- package/lib/index.d.ts +1 -1
- package/lib/index.js +7 -3
- package/package.json +2 -10
- package/eigen/Eigen/CMakeLists.txt +0 -19
- package/eigen/Eigen/src/Core/BooleanRedux.h +0 -164
- package/eigen/Eigen/src/Core/arch/CUDA/Complex.h +0 -103
- package/eigen/Eigen/src/Core/arch/CUDA/Half.h +0 -675
- package/eigen/Eigen/src/Core/arch/CUDA/MathFunctions.h +0 -91
- package/eigen/Eigen/src/Core/arch/CUDA/PacketMath.h +0 -333
- package/eigen/Eigen/src/Core/arch/CUDA/PacketMathHalf.h +0 -1124
- package/eigen/Eigen/src/Core/arch/CUDA/TypeCasting.h +0 -212
- package/eigen/Eigen/src/Core/util/NonMPL2.h +0 -3
- package/eigen/Eigen/src/Geometry/arch/Geometry_SSE.h +0 -161
- package/eigen/Eigen/src/LU/arch/Inverse_SSE.h +0 -338
- package/eigen/Eigen/src/SparseCore/MappedSparseMatrix.h +0 -67
- package/eigen/Eigen/src/SparseLU/SparseLU_gemm_kernel.h +0 -280
- package/eigen/Eigen/src/misc/lapack.h +0 -152
- package/eigen/Eigen/src/plugins/ArrayCwiseBinaryOps.h +0 -332
- package/eigen/Eigen/src/plugins/ArrayCwiseUnaryOps.h +0 -552
- package/eigen/Eigen/src/plugins/BlockMethods.h +0 -1058
- package/eigen/Eigen/src/plugins/CommonCwiseBinaryOps.h +0 -115
- package/eigen/Eigen/src/plugins/CommonCwiseUnaryOps.h +0 -163
- package/eigen/Eigen/src/plugins/MatrixCwiseBinaryOps.h +0 -152
- package/eigen/Eigen/src/plugins/MatrixCwiseUnaryOps.h +0 -85
- package/lib/eigen.d.ts +0 -2
- package/lib/eigen.js +0 -15
|
@@ -0,0 +1,445 @@
|
|
|
1
|
+
// This file is part of Eigen, a lightweight C++ template library
|
|
2
|
+
// for linear algebra.
|
|
3
|
+
//
|
|
4
|
+
// Copyright (C) 2017 Gael Guennebaud <gael.guennebaud@inria.fr>
|
|
5
|
+
//
|
|
6
|
+
// This Source Code Form is subject to the terms of the Mozilla
|
|
7
|
+
// Public License v. 2.0. If a copy of the MPL was not distributed
|
|
8
|
+
// with this file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
9
|
+
|
|
10
|
+
#ifndef EIGEN_SYMBOLIC_INDEX_H
|
|
11
|
+
#define EIGEN_SYMBOLIC_INDEX_H
|
|
12
|
+
|
|
13
|
+
// IWYU pragma: private
|
|
14
|
+
#include "../InternalHeaderCheck.h"
|
|
15
|
+
|
|
16
|
+
namespace Eigen {
|
|
17
|
+
|
|
18
|
+
/** \namespace Eigen::symbolic
|
|
19
|
+
* \ingroup Core_Module
|
|
20
|
+
*
|
|
21
|
+
* This namespace defines a set of classes and functions to build and evaluate symbolic expressions of scalar type
|
|
22
|
+
* Index. Here is a simple example:
|
|
23
|
+
*
|
|
24
|
+
* \code
|
|
25
|
+
* // First step, defines symbols:
|
|
26
|
+
* struct x_tag {}; static const symbolic::SymbolExpr<x_tag> x;
|
|
27
|
+
* struct y_tag {}; static const symbolic::SymbolExpr<y_tag> y;
|
|
28
|
+
* struct z_tag {}; static const symbolic::SymbolExpr<z_tag> z;
|
|
29
|
+
*
|
|
30
|
+
* // Defines an expression:
|
|
31
|
+
* auto expr = (x+3)/y+z;
|
|
32
|
+
*
|
|
33
|
+
* // And evaluate it: (c++14)
|
|
34
|
+
* std::cout << expr.eval(x=6,y=3,z=-13) << "\n";
|
|
35
|
+
*
|
|
36
|
+
* \endcode
|
|
37
|
+
*
|
|
38
|
+
* It is currently only used internally to define and manipulate the
|
|
39
|
+
* Eigen::placeholders::last and Eigen::placeholders::lastp1 symbols in
|
|
40
|
+
* Eigen::seq and Eigen::seqN.
|
|
41
|
+
*
|
|
42
|
+
*/
|
|
43
|
+
namespace symbolic {
|
|
44
|
+
|
|
45
|
+
template <typename Tag>
|
|
46
|
+
class Symbol;
|
|
47
|
+
template <typename Tag, typename Type>
|
|
48
|
+
class SymbolValue;
|
|
49
|
+
template <typename Arg0>
|
|
50
|
+
class NegateExpr;
|
|
51
|
+
template <typename Arg1, typename Arg2>
|
|
52
|
+
class AddExpr;
|
|
53
|
+
template <typename Arg1, typename Arg2>
|
|
54
|
+
class ProductExpr;
|
|
55
|
+
template <typename Arg1, typename Arg2>
|
|
56
|
+
class QuotientExpr;
|
|
57
|
+
template <typename IndexType = Index>
|
|
58
|
+
class ValueExpr;
|
|
59
|
+
|
|
60
|
+
/** \class BaseExpr
|
|
61
|
+
* \ingroup Core_Module
|
|
62
|
+
* Common base class of any symbolic expressions
|
|
63
|
+
*/
|
|
64
|
+
template <typename Derived_>
|
|
65
|
+
class BaseExpr {
|
|
66
|
+
public:
|
|
67
|
+
using Derived = Derived_;
|
|
68
|
+
constexpr const Derived& derived() const { return *static_cast<const Derived*>(this); }
|
|
69
|
+
|
|
70
|
+
/** Evaluate the expression given the \a values of the symbols.
|
|
71
|
+
*
|
|
72
|
+
* \param values defines the values of the symbols, as constructed by SymbolExpr::operator= operator.
|
|
73
|
+
*
|
|
74
|
+
*/
|
|
75
|
+
template <typename... Tags, typename... Types>
|
|
76
|
+
constexpr Index eval(const SymbolValue<Tags, Types>&... values) const {
|
|
77
|
+
return derived().eval_impl(values...);
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
/** Evaluate the expression at compile time given the \a values of the symbols.
|
|
81
|
+
*
|
|
82
|
+
* If a value is not known at compile-time, returns Eigen::Undefined.
|
|
83
|
+
*
|
|
84
|
+
*/
|
|
85
|
+
template <typename... Tags, typename... Types>
|
|
86
|
+
static constexpr Index eval_at_compile_time(const SymbolValue<Tags, Types>&...) {
|
|
87
|
+
return Derived::eval_at_compile_time_impl(SymbolValue<Tags, Types>{}...);
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
constexpr NegateExpr<Derived> operator-() const { return NegateExpr<Derived>(derived()); }
|
|
91
|
+
|
|
92
|
+
constexpr AddExpr<Derived, ValueExpr<>> operator+(Index b) const {
|
|
93
|
+
return AddExpr<Derived, ValueExpr<>>(derived(), b);
|
|
94
|
+
}
|
|
95
|
+
constexpr AddExpr<Derived, ValueExpr<>> operator-(Index a) const {
|
|
96
|
+
return AddExpr<Derived, ValueExpr<>>(derived(), -a);
|
|
97
|
+
}
|
|
98
|
+
constexpr ProductExpr<Derived, ValueExpr<>> operator*(Index a) const {
|
|
99
|
+
return ProductExpr<Derived, ValueExpr<>>(derived(), a);
|
|
100
|
+
}
|
|
101
|
+
constexpr QuotientExpr<Derived, ValueExpr<>> operator/(Index a) const {
|
|
102
|
+
return QuotientExpr<Derived, ValueExpr<>>(derived(), a);
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
friend constexpr AddExpr<Derived, ValueExpr<>> operator+(Index a, const BaseExpr& b) {
|
|
106
|
+
return AddExpr<Derived, ValueExpr<>>(b.derived(), a);
|
|
107
|
+
}
|
|
108
|
+
friend constexpr AddExpr<NegateExpr<Derived>, ValueExpr<>> operator-(Index a, const BaseExpr& b) {
|
|
109
|
+
return AddExpr<NegateExpr<Derived>, ValueExpr<>>(-b.derived(), a);
|
|
110
|
+
}
|
|
111
|
+
friend constexpr ProductExpr<ValueExpr<>, Derived> operator*(Index a, const BaseExpr& b) {
|
|
112
|
+
return ProductExpr<ValueExpr<>, Derived>(a, b.derived());
|
|
113
|
+
}
|
|
114
|
+
friend constexpr QuotientExpr<ValueExpr<>, Derived> operator/(Index a, const BaseExpr& b) {
|
|
115
|
+
return QuotientExpr<ValueExpr<>, Derived>(a, b.derived());
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
template <int N>
|
|
119
|
+
constexpr AddExpr<Derived, ValueExpr<internal::FixedInt<N>>> operator+(internal::FixedInt<N>) const {
|
|
120
|
+
return AddExpr<Derived, ValueExpr<internal::FixedInt<N>>>(derived(), ValueExpr<internal::FixedInt<N>>());
|
|
121
|
+
}
|
|
122
|
+
template <int N>
|
|
123
|
+
constexpr AddExpr<Derived, ValueExpr<internal::FixedInt<-N>>> operator-(internal::FixedInt<N>) const {
|
|
124
|
+
return AddExpr<Derived, ValueExpr<internal::FixedInt<-N>>>(derived(), ValueExpr<internal::FixedInt<-N>>());
|
|
125
|
+
}
|
|
126
|
+
template <int N>
|
|
127
|
+
constexpr ProductExpr<Derived, ValueExpr<internal::FixedInt<N>>> operator*(internal::FixedInt<N>) const {
|
|
128
|
+
return ProductExpr<Derived, ValueExpr<internal::FixedInt<N>>>(derived(), ValueExpr<internal::FixedInt<N>>());
|
|
129
|
+
}
|
|
130
|
+
template <int N>
|
|
131
|
+
constexpr QuotientExpr<Derived, ValueExpr<internal::FixedInt<N>>> operator/(internal::FixedInt<N>) const {
|
|
132
|
+
return QuotientExpr<Derived, ValueExpr<internal::FixedInt<N>>>(derived(), ValueExpr<internal::FixedInt<N>>());
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
template <int N>
|
|
136
|
+
friend constexpr AddExpr<Derived, ValueExpr<internal::FixedInt<N>>> operator+(internal::FixedInt<N>,
|
|
137
|
+
const BaseExpr& b) {
|
|
138
|
+
return AddExpr<Derived, ValueExpr<internal::FixedInt<N>>>(b.derived(), ValueExpr<internal::FixedInt<N>>());
|
|
139
|
+
}
|
|
140
|
+
template <int N>
|
|
141
|
+
friend constexpr AddExpr<NegateExpr<Derived>, ValueExpr<internal::FixedInt<N>>> operator-(internal::FixedInt<N>,
|
|
142
|
+
const BaseExpr& b) {
|
|
143
|
+
return AddExpr<NegateExpr<Derived>, ValueExpr<internal::FixedInt<N>>>(-b.derived(),
|
|
144
|
+
ValueExpr<internal::FixedInt<N>>());
|
|
145
|
+
}
|
|
146
|
+
template <int N>
|
|
147
|
+
friend constexpr ProductExpr<ValueExpr<internal::FixedInt<N>>, Derived> operator*(internal::FixedInt<N>,
|
|
148
|
+
const BaseExpr& b) {
|
|
149
|
+
return ProductExpr<ValueExpr<internal::FixedInt<N>>, Derived>(ValueExpr<internal::FixedInt<N>>(), b.derived());
|
|
150
|
+
}
|
|
151
|
+
template <int N>
|
|
152
|
+
friend constexpr QuotientExpr<ValueExpr<internal::FixedInt<N>>, Derived> operator/(internal::FixedInt<N>,
|
|
153
|
+
const BaseExpr& b) {
|
|
154
|
+
return QuotientExpr<ValueExpr<internal::FixedInt<N>>, Derived>(ValueExpr<internal::FixedInt<N>>(), b.derived());
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
template <typename OtherDerived>
|
|
158
|
+
constexpr AddExpr<Derived, OtherDerived> operator+(const BaseExpr<OtherDerived>& b) const {
|
|
159
|
+
return AddExpr<Derived, OtherDerived>(derived(), b.derived());
|
|
160
|
+
}
|
|
161
|
+
|
|
162
|
+
template <typename OtherDerived>
|
|
163
|
+
constexpr AddExpr<Derived, NegateExpr<OtherDerived>> operator-(const BaseExpr<OtherDerived>& b) const {
|
|
164
|
+
return AddExpr<Derived, NegateExpr<OtherDerived>>(derived(), -b.derived());
|
|
165
|
+
}
|
|
166
|
+
|
|
167
|
+
template <typename OtherDerived>
|
|
168
|
+
constexpr ProductExpr<Derived, OtherDerived> operator*(const BaseExpr<OtherDerived>& b) const {
|
|
169
|
+
return ProductExpr<Derived, OtherDerived>(derived(), b.derived());
|
|
170
|
+
}
|
|
171
|
+
|
|
172
|
+
template <typename OtherDerived>
|
|
173
|
+
constexpr QuotientExpr<Derived, OtherDerived> operator/(const BaseExpr<OtherDerived>& b) const {
|
|
174
|
+
return QuotientExpr<Derived, OtherDerived>(derived(), b.derived());
|
|
175
|
+
}
|
|
176
|
+
};
|
|
177
|
+
|
|
178
|
+
template <typename T>
|
|
179
|
+
struct is_symbolic {
|
|
180
|
+
// BaseExpr has no conversion ctor, so we only have to check whether T can be statically cast to its base class
|
|
181
|
+
// BaseExpr<T>.
|
|
182
|
+
enum { value = internal::is_convertible<T, BaseExpr<T>>::value };
|
|
183
|
+
};
|
|
184
|
+
|
|
185
|
+
// A simple wrapper around an integral value to provide the eval method.
|
|
186
|
+
// We could also use a free-function symbolic_eval...
|
|
187
|
+
template <typename IndexType>
|
|
188
|
+
class ValueExpr : BaseExpr<ValueExpr<IndexType>> {
|
|
189
|
+
public:
|
|
190
|
+
constexpr ValueExpr() = default;
|
|
191
|
+
constexpr ValueExpr(IndexType val) : value_(val) {}
|
|
192
|
+
template <typename... Tags, typename... Types>
|
|
193
|
+
constexpr IndexType eval_impl(const SymbolValue<Tags, Types>&...) const {
|
|
194
|
+
return value_;
|
|
195
|
+
}
|
|
196
|
+
template <typename... Tags, typename... Types>
|
|
197
|
+
static constexpr IndexType eval_at_compile_time_impl(const SymbolValue<Tags, Types>&...) {
|
|
198
|
+
return IndexType(Undefined);
|
|
199
|
+
}
|
|
200
|
+
|
|
201
|
+
protected:
|
|
202
|
+
IndexType value_;
|
|
203
|
+
};
|
|
204
|
+
|
|
205
|
+
// Specialization for compile-time value,
|
|
206
|
+
// It is similar to ValueExpr(N) but this version helps the compiler to generate better code.
|
|
207
|
+
template <int N>
|
|
208
|
+
class ValueExpr<internal::FixedInt<N>> : public BaseExpr<ValueExpr<internal::FixedInt<N>>> {
|
|
209
|
+
public:
|
|
210
|
+
constexpr ValueExpr() = default;
|
|
211
|
+
constexpr ValueExpr(internal::FixedInt<N>) {}
|
|
212
|
+
template <typename... Tags, typename... Types>
|
|
213
|
+
constexpr Index eval_impl(const SymbolValue<Tags, Types>&...) const {
|
|
214
|
+
return Index(N);
|
|
215
|
+
}
|
|
216
|
+
template <typename... Tags, typename... Types>
|
|
217
|
+
static constexpr Index eval_at_compile_time_impl(const SymbolValue<Tags, Types>&...) {
|
|
218
|
+
return Index(N);
|
|
219
|
+
}
|
|
220
|
+
};
|
|
221
|
+
|
|
222
|
+
/** Represents the actual value of a symbol identified by its tag
|
|
223
|
+
*
|
|
224
|
+
* It is the return type of SymbolValue::operator=, and most of the time this is only way it is used.
|
|
225
|
+
*/
|
|
226
|
+
template <typename Tag, typename Type>
|
|
227
|
+
class SymbolValue : public BaseExpr<SymbolValue<Tag, Type>> {};
|
|
228
|
+
|
|
229
|
+
template <typename Tag>
|
|
230
|
+
class SymbolValue<Tag, Index> : public BaseExpr<SymbolValue<Tag, Index>> {
|
|
231
|
+
public:
|
|
232
|
+
constexpr SymbolValue() = default;
|
|
233
|
+
|
|
234
|
+
/** Default constructor from the value \a val */
|
|
235
|
+
constexpr SymbolValue(Index val) : value_(val) {}
|
|
236
|
+
|
|
237
|
+
/** \returns the stored value of the symbol */
|
|
238
|
+
constexpr Index value() const { return value_; }
|
|
239
|
+
|
|
240
|
+
/** \returns the stored value of the symbol at compile time, or Undefined if not known. */
|
|
241
|
+
static constexpr Index value_at_compile_time() { return Index(Undefined); }
|
|
242
|
+
|
|
243
|
+
template <typename... Tags, typename... Types>
|
|
244
|
+
constexpr Index eval_impl(const SymbolValue<Tags, Types>&...) const {
|
|
245
|
+
return value();
|
|
246
|
+
}
|
|
247
|
+
|
|
248
|
+
template <typename... Tags, typename... Types>
|
|
249
|
+
static constexpr Index eval_at_compile_time_impl(const SymbolValue<Tags, Types>&...) {
|
|
250
|
+
return value_at_compile_time();
|
|
251
|
+
}
|
|
252
|
+
|
|
253
|
+
protected:
|
|
254
|
+
Index value_;
|
|
255
|
+
};
|
|
256
|
+
|
|
257
|
+
template <typename Tag, int N>
|
|
258
|
+
class SymbolValue<Tag, internal::FixedInt<N>> : public BaseExpr<SymbolValue<Tag, internal::FixedInt<N>>> {
|
|
259
|
+
public:
|
|
260
|
+
constexpr SymbolValue() = default;
|
|
261
|
+
|
|
262
|
+
/** Default constructor from the value \a val */
|
|
263
|
+
constexpr SymbolValue(internal::FixedInt<N>) {}
|
|
264
|
+
|
|
265
|
+
/** \returns the stored value of the symbol */
|
|
266
|
+
constexpr Index value() const { return static_cast<Index>(N); }
|
|
267
|
+
|
|
268
|
+
/** \returns the stored value of the symbol at compile time, or Undefined if not known. */
|
|
269
|
+
static constexpr Index value_at_compile_time() { return static_cast<Index>(N); }
|
|
270
|
+
|
|
271
|
+
template <typename... Tags, typename... Types>
|
|
272
|
+
constexpr Index eval_impl(const SymbolValue<Tags, Types>&...) const {
|
|
273
|
+
return value();
|
|
274
|
+
}
|
|
275
|
+
|
|
276
|
+
template <typename... Tags, typename... Types>
|
|
277
|
+
static constexpr Index eval_at_compile_time_impl(const SymbolValue<Tags, Types>&...) {
|
|
278
|
+
return value_at_compile_time();
|
|
279
|
+
}
|
|
280
|
+
};
|
|
281
|
+
|
|
282
|
+
// Find and return a symbol value based on the tag.
|
|
283
|
+
template <typename Tag, typename... Types>
|
|
284
|
+
struct EvalSymbolValueHelper;
|
|
285
|
+
|
|
286
|
+
// Empty base case, symbol not found.
|
|
287
|
+
template <typename Tag>
|
|
288
|
+
struct EvalSymbolValueHelper<Tag> {
|
|
289
|
+
static constexpr Index eval_impl() {
|
|
290
|
+
eigen_assert(false && "Symbol not found.");
|
|
291
|
+
return Index(Undefined);
|
|
292
|
+
}
|
|
293
|
+
static constexpr Index eval_at_compile_time_impl() { return Index(Undefined); }
|
|
294
|
+
};
|
|
295
|
+
|
|
296
|
+
// We found a symbol value matching the provided Tag!
|
|
297
|
+
template <typename Tag, typename Type, typename... OtherTypes>
|
|
298
|
+
struct EvalSymbolValueHelper<Tag, SymbolValue<Tag, Type>, OtherTypes...> {
|
|
299
|
+
static constexpr Index eval_impl(const SymbolValue<Tag, Type>& symbol, const OtherTypes&...) {
|
|
300
|
+
return symbol.value();
|
|
301
|
+
}
|
|
302
|
+
static constexpr Index eval_at_compile_time_impl(const SymbolValue<Tag, Type>& symbol, const OtherTypes&...) {
|
|
303
|
+
return symbol.value_at_compile_time();
|
|
304
|
+
}
|
|
305
|
+
};
|
|
306
|
+
|
|
307
|
+
// No symbol value in first value, recursive search starting with next.
|
|
308
|
+
template <typename Tag, typename T1, typename... OtherTypes>
|
|
309
|
+
struct EvalSymbolValueHelper<Tag, T1, OtherTypes...> {
|
|
310
|
+
static constexpr Index eval_impl(const T1&, const OtherTypes&... values) {
|
|
311
|
+
return EvalSymbolValueHelper<Tag, OtherTypes...>::eval_impl(values...);
|
|
312
|
+
}
|
|
313
|
+
static constexpr Index eval_at_compile_time_impl(const T1&, const OtherTypes&...) {
|
|
314
|
+
return EvalSymbolValueHelper<Tag, OtherTypes...>::eval_at_compile_time_impl(OtherTypes{}...);
|
|
315
|
+
}
|
|
316
|
+
};
|
|
317
|
+
|
|
318
|
+
/** Expression of a symbol uniquely identified by the template parameter type \c tag */
|
|
319
|
+
template <typename tag>
|
|
320
|
+
class SymbolExpr : public BaseExpr<SymbolExpr<tag>> {
|
|
321
|
+
public:
|
|
322
|
+
/** Alias to the template parameter \c tag */
|
|
323
|
+
typedef tag Tag;
|
|
324
|
+
|
|
325
|
+
constexpr SymbolExpr() = default;
|
|
326
|
+
|
|
327
|
+
/** Associate the value \a val to the given symbol \c *this, uniquely identified by its \c Tag.
|
|
328
|
+
*
|
|
329
|
+
* The returned object should be passed to ExprBase::eval() to evaluate a given expression with this specified
|
|
330
|
+
* runtime-time value.
|
|
331
|
+
*/
|
|
332
|
+
constexpr SymbolValue<Tag, Index> operator=(Index val) const { return SymbolValue<Tag, Index>(val); }
|
|
333
|
+
|
|
334
|
+
template <int N>
|
|
335
|
+
constexpr SymbolValue<Tag, internal::FixedInt<N>> operator=(internal::FixedInt<N>) const {
|
|
336
|
+
return SymbolValue<Tag, internal::FixedInt<N>>{internal::FixedInt<N>{}};
|
|
337
|
+
}
|
|
338
|
+
|
|
339
|
+
template <typename... Tags, typename... Types>
|
|
340
|
+
constexpr Index eval_impl(const SymbolValue<Tags, Types>&... values) const {
|
|
341
|
+
return EvalSymbolValueHelper<Tag, SymbolValue<Tags, Types>...>::eval_impl(values...);
|
|
342
|
+
}
|
|
343
|
+
|
|
344
|
+
template <typename... Tags, typename... Types>
|
|
345
|
+
static constexpr Index eval_at_compile_time_impl(const SymbolValue<Tags, Types>&...) {
|
|
346
|
+
return EvalSymbolValueHelper<Tag, SymbolValue<Tags, Types>...>::eval_at_compile_time_impl(
|
|
347
|
+
SymbolValue<Tags, Types>{}...);
|
|
348
|
+
}
|
|
349
|
+
};
|
|
350
|
+
|
|
351
|
+
template <typename Arg0>
|
|
352
|
+
class NegateExpr : public BaseExpr<NegateExpr<Arg0>> {
|
|
353
|
+
public:
|
|
354
|
+
constexpr NegateExpr() = default;
|
|
355
|
+
constexpr NegateExpr(const Arg0& arg0) : m_arg0(arg0) {}
|
|
356
|
+
|
|
357
|
+
template <typename... Tags, typename... Types>
|
|
358
|
+
constexpr Index eval_impl(const SymbolValue<Tags, Types>&... values) const {
|
|
359
|
+
return -m_arg0.eval_impl(values...);
|
|
360
|
+
}
|
|
361
|
+
|
|
362
|
+
template <typename... Tags, typename... Types>
|
|
363
|
+
static constexpr Index eval_at_compile_time_impl(const SymbolValue<Tags, Types>&...) {
|
|
364
|
+
constexpr Index v = Arg0::eval_at_compile_time_impl(SymbolValue<Tags, Types>{}...);
|
|
365
|
+
return (v == Undefined) ? Undefined : -v;
|
|
366
|
+
}
|
|
367
|
+
|
|
368
|
+
protected:
|
|
369
|
+
Arg0 m_arg0;
|
|
370
|
+
};
|
|
371
|
+
|
|
372
|
+
template <typename Arg0, typename Arg1>
|
|
373
|
+
class AddExpr : public BaseExpr<AddExpr<Arg0, Arg1>> {
|
|
374
|
+
public:
|
|
375
|
+
constexpr AddExpr() = default;
|
|
376
|
+
constexpr AddExpr(const Arg0& arg0, const Arg1& arg1) : m_arg0(arg0), m_arg1(arg1) {}
|
|
377
|
+
|
|
378
|
+
template <typename... Tags, typename... Types>
|
|
379
|
+
constexpr Index eval_impl(const SymbolValue<Tags, Types>&... values) const {
|
|
380
|
+
return m_arg0.eval_impl(values...) + m_arg1.eval_impl(values...);
|
|
381
|
+
}
|
|
382
|
+
|
|
383
|
+
template <typename... Tags, typename... Types>
|
|
384
|
+
static constexpr Index eval_at_compile_time_impl(const SymbolValue<Tags, Types>&...) {
|
|
385
|
+
constexpr Index v0 = Arg0::eval_at_compile_time_impl(SymbolValue<Tags, Types>{}...);
|
|
386
|
+
constexpr Index v1 = Arg1::eval_at_compile_time_impl(SymbolValue<Tags, Types>{}...);
|
|
387
|
+
return (v0 == Undefined || v1 == Undefined) ? Undefined : v0 + v1;
|
|
388
|
+
}
|
|
389
|
+
|
|
390
|
+
protected:
|
|
391
|
+
Arg0 m_arg0;
|
|
392
|
+
Arg1 m_arg1;
|
|
393
|
+
};
|
|
394
|
+
|
|
395
|
+
template <typename Arg0, typename Arg1>
|
|
396
|
+
class ProductExpr : public BaseExpr<ProductExpr<Arg0, Arg1>> {
|
|
397
|
+
public:
|
|
398
|
+
constexpr ProductExpr() = default;
|
|
399
|
+
constexpr ProductExpr(const Arg0& arg0, const Arg1& arg1) : m_arg0(arg0), m_arg1(arg1) {}
|
|
400
|
+
|
|
401
|
+
template <typename... Tags, typename... Types>
|
|
402
|
+
constexpr Index eval_impl(const SymbolValue<Tags, Types>&... values) const {
|
|
403
|
+
return m_arg0.eval_impl(values...) * m_arg1.eval_impl(values...);
|
|
404
|
+
}
|
|
405
|
+
|
|
406
|
+
template <typename... Tags, typename... Types>
|
|
407
|
+
static constexpr Index eval_at_compile_time_impl(const SymbolValue<Tags, Types>&...) {
|
|
408
|
+
constexpr Index v0 = Arg0::eval_at_compile_time_impl(SymbolValue<Tags, Types>{}...);
|
|
409
|
+
constexpr Index v1 = Arg1::eval_at_compile_time_impl(SymbolValue<Tags, Types>{}...);
|
|
410
|
+
return (v0 == Undefined || v1 == Undefined) ? Undefined : v0 * v1;
|
|
411
|
+
}
|
|
412
|
+
|
|
413
|
+
protected:
|
|
414
|
+
Arg0 m_arg0;
|
|
415
|
+
Arg1 m_arg1;
|
|
416
|
+
};
|
|
417
|
+
|
|
418
|
+
template <typename Arg0, typename Arg1>
|
|
419
|
+
class QuotientExpr : public BaseExpr<QuotientExpr<Arg0, Arg1>> {
|
|
420
|
+
public:
|
|
421
|
+
constexpr QuotientExpr() = default;
|
|
422
|
+
constexpr QuotientExpr(const Arg0& arg0, const Arg1& arg1) : m_arg0(arg0), m_arg1(arg1) {}
|
|
423
|
+
|
|
424
|
+
template <typename... Tags, typename... Types>
|
|
425
|
+
constexpr Index eval_impl(const SymbolValue<Tags, Types>&... values) const {
|
|
426
|
+
return m_arg0.eval_impl(values...) / m_arg1.eval_impl(values...);
|
|
427
|
+
}
|
|
428
|
+
|
|
429
|
+
template <typename... Tags, typename... Types>
|
|
430
|
+
static constexpr Index eval_at_compile_time_impl(const SymbolValue<Tags, Types>&...) {
|
|
431
|
+
constexpr Index v0 = Arg0::eval_at_compile_time_impl(SymbolValue<Tags, Types>{}...);
|
|
432
|
+
constexpr Index v1 = Arg1::eval_at_compile_time_impl(SymbolValue<Tags, Types>{}...);
|
|
433
|
+
return (v0 == Undefined || v1 == Undefined) ? Undefined : v0 / v1;
|
|
434
|
+
}
|
|
435
|
+
|
|
436
|
+
protected:
|
|
437
|
+
Arg0 m_arg0;
|
|
438
|
+
Arg1 m_arg1;
|
|
439
|
+
};
|
|
440
|
+
|
|
441
|
+
} // end namespace symbolic
|
|
442
|
+
|
|
443
|
+
} // end namespace Eigen
|
|
444
|
+
|
|
445
|
+
#endif // EIGEN_SYMBOLIC_INDEX_H
|