@smake/eigen 1.1.0 → 1.1.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/eigen/Eigen/AccelerateSupport +52 -0
- package/eigen/Eigen/Cholesky +18 -20
- package/eigen/Eigen/CholmodSupport +28 -28
- package/eigen/Eigen/Core +187 -120
- package/eigen/Eigen/Eigenvalues +16 -13
- package/eigen/Eigen/Geometry +18 -18
- package/eigen/Eigen/Householder +9 -7
- package/eigen/Eigen/IterativeLinearSolvers +8 -4
- package/eigen/Eigen/Jacobi +14 -13
- package/eigen/Eigen/KLUSupport +23 -21
- package/eigen/Eigen/LU +15 -16
- package/eigen/Eigen/MetisSupport +12 -12
- package/eigen/Eigen/OrderingMethods +54 -51
- package/eigen/Eigen/PaStiXSupport +23 -21
- package/eigen/Eigen/PardisoSupport +17 -14
- package/eigen/Eigen/QR +18 -20
- package/eigen/Eigen/QtAlignedMalloc +5 -12
- package/eigen/Eigen/SPQRSupport +21 -14
- package/eigen/Eigen/SVD +23 -17
- package/eigen/Eigen/Sparse +1 -2
- package/eigen/Eigen/SparseCholesky +18 -15
- package/eigen/Eigen/SparseCore +18 -17
- package/eigen/Eigen/SparseLU +9 -9
- 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 +366 -405
- package/eigen/Eigen/src/Cholesky/LLT.h +323 -367
- package/eigen/Eigen/src/Cholesky/LLT_LAPACKE.h +81 -56
- package/eigen/Eigen/src/CholmodSupport/CholmodSupport.h +585 -529
- package/eigen/Eigen/src/CholmodSupport/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/Core/ArithmeticSequence.h +143 -317
- package/eigen/Eigen/src/Core/Array.h +329 -370
- package/eigen/Eigen/src/Core/ArrayBase.h +190 -203
- package/eigen/Eigen/src/Core/ArrayWrapper.h +126 -170
- package/eigen/Eigen/src/Core/Assign.h +30 -40
- package/eigen/Eigen/src/Core/AssignEvaluator.h +651 -604
- package/eigen/Eigen/src/Core/Assign_MKL.h +125 -120
- package/eigen/Eigen/src/Core/BandMatrix.h +267 -282
- package/eigen/Eigen/src/Core/Block.h +371 -390
- package/eigen/Eigen/src/Core/CommaInitializer.h +85 -100
- package/eigen/Eigen/src/Core/ConditionEstimator.h +51 -53
- package/eigen/Eigen/src/Core/CoreEvaluators.h +1214 -937
- package/eigen/Eigen/src/Core/CoreIterators.h +72 -63
- package/eigen/Eigen/src/Core/CwiseBinaryOp.h +112 -129
- package/eigen/Eigen/src/Core/CwiseNullaryOp.h +676 -702
- package/eigen/Eigen/src/Core/CwiseTernaryOp.h +77 -103
- package/eigen/Eigen/src/Core/CwiseUnaryOp.h +55 -67
- package/eigen/Eigen/src/Core/CwiseUnaryView.h +127 -92
- package/eigen/Eigen/src/Core/DenseBase.h +630 -658
- package/eigen/Eigen/src/Core/DenseCoeffsBase.h +511 -628
- package/eigen/Eigen/src/Core/DenseStorage.h +511 -590
- package/eigen/Eigen/src/Core/DeviceWrapper.h +153 -0
- package/eigen/Eigen/src/Core/Diagonal.h +168 -207
- package/eigen/Eigen/src/Core/DiagonalMatrix.h +346 -317
- package/eigen/Eigen/src/Core/DiagonalProduct.h +12 -10
- package/eigen/Eigen/src/Core/Dot.h +167 -217
- package/eigen/Eigen/src/Core/EigenBase.h +74 -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 -113
- package/eigen/Eigen/src/Core/Fuzzy.h +82 -105
- package/eigen/Eigen/src/Core/GeneralProduct.h +315 -261
- package/eigen/Eigen/src/Core/GenericPacketMath.h +1182 -520
- package/eigen/Eigen/src/Core/GlobalFunctions.h +193 -157
- package/eigen/Eigen/src/Core/IO.h +131 -156
- package/eigen/Eigen/src/Core/IndexedView.h +209 -125
- 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 +50 -59
- package/eigen/Eigen/src/Core/Map.h +123 -141
- package/eigen/Eigen/src/Core/MapBase.h +255 -282
- package/eigen/Eigen/src/Core/MathFunctions.h +1247 -1201
- package/eigen/Eigen/src/Core/MathFunctionsImpl.h +162 -99
- package/eigen/Eigen/src/Core/Matrix.h +463 -494
- package/eigen/Eigen/src/Core/MatrixBase.h +468 -470
- package/eigen/Eigen/src/Core/NestByValue.h +58 -52
- package/eigen/Eigen/src/Core/NoAlias.h +79 -86
- package/eigen/Eigen/src/Core/NumTraits.h +206 -206
- package/eigen/Eigen/src/Core/PartialReduxEvaluator.h +163 -142
- package/eigen/Eigen/src/Core/PermutationMatrix.h +461 -511
- package/eigen/Eigen/src/Core/PlainObjectBase.h +858 -972
- package/eigen/Eigen/src/Core/Product.h +246 -130
- package/eigen/Eigen/src/Core/ProductEvaluators.h +779 -671
- package/eigen/Eigen/src/Core/Random.h +153 -164
- 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 +334 -314
- package/eigen/Eigen/src/Core/Ref.h +259 -257
- package/eigen/Eigen/src/Core/Replicate.h +92 -104
- package/eigen/Eigen/src/Core/Reshaped.h +215 -271
- package/eigen/Eigen/src/Core/ReturnByValue.h +47 -55
- package/eigen/Eigen/src/Core/Reverse.h +133 -148
- package/eigen/Eigen/src/Core/Select.h +68 -140
- package/eigen/Eigen/src/Core/SelfAdjointView.h +254 -290
- 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 +88 -102
- package/eigen/Eigen/src/Core/SolveTriangular.h +126 -124
- package/eigen/Eigen/src/Core/SolverBase.h +132 -133
- package/eigen/Eigen/src/Core/StableNorm.h +113 -147
- package/eigen/Eigen/src/Core/StlIterators.h +404 -248
- package/eigen/Eigen/src/Core/Stride.h +90 -92
- package/eigen/Eigen/src/Core/Swap.h +70 -39
- package/eigen/Eigen/src/Core/Transpose.h +258 -295
- package/eigen/Eigen/src/Core/Transpositions.h +270 -333
- package/eigen/Eigen/src/Core/TriangularMatrix.h +642 -743
- package/eigen/Eigen/src/Core/VectorBlock.h +59 -72
- package/eigen/Eigen/src/Core/VectorwiseOp.h +653 -704
- package/eigen/Eigen/src/Core/Visitor.h +464 -308
- package/eigen/Eigen/src/Core/arch/AVX/Complex.h +380 -187
- package/eigen/Eigen/src/Core/arch/AVX/MathFunctions.h +65 -163
- package/eigen/Eigen/src/Core/arch/AVX/PacketMath.h +2145 -638
- package/eigen/Eigen/src/Core/arch/AVX/Reductions.h +353 -0
- package/eigen/Eigen/src/Core/arch/AVX/TypeCasting.h +253 -60
- package/eigen/Eigen/src/Core/arch/AVX512/Complex.h +278 -228
- package/eigen/Eigen/src/Core/arch/AVX512/GemmKernel.h +1245 -0
- package/eigen/Eigen/src/Core/arch/AVX512/MathFunctions.h +48 -269
- package/eigen/Eigen/src/Core/arch/AVX512/MathFunctionsFP16.h +75 -0
- package/eigen/Eigen/src/Core/arch/AVX512/PacketMath.h +1597 -754
- 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 +229 -41
- package/eigen/Eigen/src/Core/arch/AVX512/TypeCastingFP16.h +130 -0
- package/eigen/Eigen/src/Core/arch/AltiVec/Complex.h +420 -184
- package/eigen/Eigen/src/Core/arch/AltiVec/MathFunctions.h +40 -49
- package/eigen/Eigen/src/Core/arch/AltiVec/MatrixProduct.h +2962 -2213
- package/eigen/Eigen/src/Core/arch/AltiVec/MatrixProductCommon.h +196 -212
- package/eigen/Eigen/src/Core/arch/AltiVec/MatrixProductMMA.h +713 -441
- 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 +2380 -1362
- package/eigen/Eigen/src/Core/arch/AltiVec/TypeCasting.h +153 -0
- package/eigen/Eigen/src/Core/arch/Default/BFloat16.h +390 -224
- package/eigen/Eigen/src/Core/arch/Default/ConjHelper.h +78 -67
- package/eigen/Eigen/src/Core/arch/Default/GenericPacketMathFunctions.h +1784 -799
- package/eigen/Eigen/src/Core/arch/Default/GenericPacketMathFunctionsFwd.h +167 -50
- package/eigen/Eigen/src/Core/arch/Default/Half.h +528 -379
- package/eigen/Eigen/src/Core/arch/Default/Settings.h +10 -12
- package/eigen/Eigen/src/Core/arch/GPU/Complex.h +244 -0
- package/eigen/Eigen/src/Core/arch/GPU/MathFunctions.h +41 -40
- package/eigen/Eigen/src/Core/arch/GPU/PacketMath.h +550 -523
- package/eigen/Eigen/src/Core/arch/GPU/Tuple.h +268 -0
- package/eigen/Eigen/src/Core/arch/GPU/TypeCasting.h +27 -30
- package/eigen/Eigen/src/Core/arch/HIP/hcc/math_constants.h +8 -8
- 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 +54 -82
- package/eigen/Eigen/src/Core/arch/MSA/MathFunctions.h +84 -92
- package/eigen/Eigen/src/Core/arch/MSA/PacketMath.h +51 -47
- package/eigen/Eigen/src/Core/arch/NEON/Complex.h +454 -306
- package/eigen/Eigen/src/Core/arch/NEON/GeneralBlockPanelKernel.h +175 -115
- package/eigen/Eigen/src/Core/arch/NEON/MathFunctions.h +23 -30
- package/eigen/Eigen/src/Core/arch/NEON/PacketMath.h +4366 -2857
- package/eigen/Eigen/src/Core/arch/NEON/TypeCasting.h +616 -393
- package/eigen/Eigen/src/Core/arch/NEON/UnaryFunctors.h +57 -0
- package/eigen/Eigen/src/Core/arch/SSE/Complex.h +350 -198
- package/eigen/Eigen/src/Core/arch/SSE/MathFunctions.h +38 -149
- package/eigen/Eigen/src/Core/arch/SSE/PacketMath.h +1791 -912
- package/eigen/Eigen/src/Core/arch/SSE/Reductions.h +324 -0
- package/eigen/Eigen/src/Core/arch/SSE/TypeCasting.h +128 -40
- package/eigen/Eigen/src/Core/arch/SVE/MathFunctions.h +10 -6
- package/eigen/Eigen/src/Core/arch/SVE/PacketMath.h +156 -234
- package/eigen/Eigen/src/Core/arch/SVE/TypeCasting.h +6 -3
- package/eigen/Eigen/src/Core/arch/SYCL/InteropHeaders.h +27 -32
- package/eigen/Eigen/src/Core/arch/SYCL/MathFunctions.h +119 -117
- package/eigen/Eigen/src/Core/arch/SYCL/PacketMath.h +325 -419
- package/eigen/Eigen/src/Core/arch/SYCL/TypeCasting.h +15 -17
- package/eigen/Eigen/src/Core/arch/ZVector/Complex.h +325 -181
- package/eigen/Eigen/src/Core/arch/ZVector/MathFunctions.h +94 -83
- package/eigen/Eigen/src/Core/arch/ZVector/PacketMath.h +811 -458
- package/eigen/Eigen/src/Core/functors/AssignmentFunctors.h +121 -124
- package/eigen/Eigen/src/Core/functors/BinaryFunctors.h +576 -370
- package/eigen/Eigen/src/Core/functors/NullaryFunctors.h +194 -109
- package/eigen/Eigen/src/Core/functors/StlFunctors.h +95 -112
- package/eigen/Eigen/src/Core/functors/TernaryFunctors.h +34 -7
- package/eigen/Eigen/src/Core/functors/UnaryFunctors.h +1038 -749
- package/eigen/Eigen/src/Core/products/GeneralBlockPanelKernel.h +1883 -1375
- package/eigen/Eigen/src/Core/products/GeneralMatrixMatrix.h +312 -370
- package/eigen/Eigen/src/Core/products/GeneralMatrixMatrixTriangular.h +189 -176
- package/eigen/Eigen/src/Core/products/GeneralMatrixMatrixTriangular_BLAS.h +84 -81
- package/eigen/Eigen/src/Core/products/GeneralMatrixMatrix_BLAS.h +154 -73
- package/eigen/Eigen/src/Core/products/GeneralMatrixVector.h +292 -337
- package/eigen/Eigen/src/Core/products/GeneralMatrixVector_BLAS.h +80 -77
- package/eigen/Eigen/src/Core/products/Parallelizer.h +207 -105
- package/eigen/Eigen/src/Core/products/SelfadjointMatrixMatrix.h +327 -388
- package/eigen/Eigen/src/Core/products/SelfadjointMatrixMatrix_BLAS.h +206 -224
- package/eigen/Eigen/src/Core/products/SelfadjointMatrixVector.h +138 -147
- 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 -47
- 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 -277
- package/eigen/Eigen/src/Core/products/TriangularSolverMatrix_BLAS.h +108 -109
- package/eigen/Eigen/src/Core/products/TriangularSolverVector.h +68 -94
- package/eigen/Eigen/src/Core/util/Assert.h +158 -0
- package/eigen/Eigen/src/Core/util/BlasUtil.h +342 -303
- package/eigen/Eigen/src/Core/util/ConfigureVectorization.h +348 -317
- package/eigen/Eigen/src/Core/util/Constants.h +297 -262
- package/eigen/Eigen/src/Core/util/DisableStupidWarnings.h +130 -90
- package/eigen/Eigen/src/Core/util/EmulateArray.h +270 -0
- package/eigen/Eigen/src/Core/util/ForwardDeclarations.h +449 -247
- 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 +417 -116
- package/eigen/Eigen/src/Core/util/IntegralConstant.h +211 -204
- package/eigen/Eigen/src/Core/util/MKL_support.h +39 -37
- package/eigen/Eigen/src/Core/util/Macros.h +655 -773
- package/eigen/Eigen/src/Core/util/MaxSizeVector.h +139 -0
- package/eigen/Eigen/src/Core/util/Memory.h +970 -748
- package/eigen/Eigen/src/Core/util/Meta.h +581 -633
- 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 +17 -17
- package/eigen/Eigen/src/Core/util/Serializer.h +209 -0
- package/eigen/Eigen/src/Core/util/StaticAssert.h +50 -166
- package/eigen/Eigen/src/Core/util/SymbolicIndex.h +377 -225
- package/eigen/Eigen/src/Core/util/XprHelper.h +784 -547
- 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 +89 -105
- package/eigen/Eigen/src/Eigenvalues/RealQZ.h +537 -607
- package/eigen/Eigen/src/Eigenvalues/RealSchur.h +342 -381
- package/eigen/Eigen/src/Eigenvalues/RealSchur_LAPACKE.h +41 -35
- package/eigen/Eigen/src/Eigenvalues/SelfAdjointEigenSolver.h +541 -595
- package/eigen/Eigen/src/Eigenvalues/SelfAdjointEigenSolver_LAPACKE.h +47 -44
- package/eigen/Eigen/src/Eigenvalues/Tridiagonalization.h +430 -462
- package/eigen/Eigen/src/Geometry/AlignedBox.h +226 -227
- package/eigen/Eigen/src/Geometry/AngleAxis.h +131 -133
- package/eigen/Eigen/src/Geometry/EulerAngles.h +163 -74
- package/eigen/Eigen/src/Geometry/Homogeneous.h +285 -333
- package/eigen/Eigen/src/Geometry/Hyperplane.h +151 -160
- package/eigen/Eigen/src/Geometry/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/Geometry/OrthoMethods.h +168 -146
- package/eigen/Eigen/src/Geometry/ParametrizedLine.h +127 -127
- package/eigen/Eigen/src/Geometry/Quaternion.h +566 -506
- package/eigen/Eigen/src/Geometry/Rotation2D.h +107 -105
- package/eigen/Eigen/src/Geometry/RotationBase.h +148 -145
- package/eigen/Eigen/src/Geometry/Scaling.h +113 -106
- package/eigen/Eigen/src/Geometry/Transform.h +858 -936
- package/eigen/Eigen/src/Geometry/Translation.h +94 -92
- package/eigen/Eigen/src/Geometry/Umeyama.h +79 -84
- package/eigen/Eigen/src/Geometry/arch/Geometry_SIMD.h +90 -104
- package/eigen/Eigen/src/Householder/BlockHouseholder.h +51 -46
- package/eigen/Eigen/src/Householder/Householder.h +102 -124
- package/eigen/Eigen/src/Householder/HouseholderSequence.h +412 -453
- package/eigen/Eigen/src/Householder/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/IterativeLinearSolvers/BasicPreconditioners.h +149 -162
- package/eigen/Eigen/src/IterativeLinearSolvers/BiCGSTAB.h +124 -119
- package/eigen/Eigen/src/IterativeLinearSolvers/ConjugateGradient.h +92 -104
- package/eigen/Eigen/src/IterativeLinearSolvers/IncompleteCholesky.h +251 -243
- package/eigen/Eigen/src/IterativeLinearSolvers/IncompleteLUT.h +224 -228
- package/eigen/Eigen/src/IterativeLinearSolvers/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/IterativeLinearSolvers/IterativeSolverBase.h +178 -227
- package/eigen/Eigen/src/IterativeLinearSolvers/LeastSquareConjugateGradient.h +79 -84
- package/eigen/Eigen/src/IterativeLinearSolvers/SolveWithGuess.h +54 -60
- package/eigen/Eigen/src/Jacobi/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/Jacobi/Jacobi.h +252 -308
- package/eigen/Eigen/src/KLUSupport/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/KLUSupport/KLUSupport.h +208 -227
- package/eigen/Eigen/src/LU/Determinant.h +50 -69
- package/eigen/Eigen/src/LU/FullPivLU.h +545 -596
- package/eigen/Eigen/src/LU/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/LU/InverseImpl.h +206 -285
- package/eigen/Eigen/src/LU/PartialPivLU.h +390 -428
- package/eigen/Eigen/src/LU/PartialPivLU_LAPACKE.h +54 -40
- package/eigen/Eigen/src/LU/arch/InverseSize4.h +72 -70
- 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 +243 -265
- package/eigen/Eigen/src/OrderingMethods/Eigen_Colamd.h +831 -1004
- package/eigen/Eigen/src/OrderingMethods/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/OrderingMethods/Ordering.h +112 -119
- 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 -430
- package/eigen/Eigen/src/QR/ColPivHouseholderQR.h +479 -479
- package/eigen/Eigen/src/QR/ColPivHouseholderQR_LAPACKE.h +120 -56
- package/eigen/Eigen/src/QR/CompleteOrthogonalDecomposition.h +166 -153
- package/eigen/Eigen/src/QR/FullPivHouseholderQR.h +495 -475
- package/eigen/Eigen/src/QR/HouseholderQR.h +394 -285
- 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 +244 -264
- package/eigen/Eigen/src/SVD/BDCSVD.h +817 -713
- 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 +577 -543
- package/eigen/Eigen/src/SVD/JacobiSVD_LAPACKE.h +85 -49
- package/eigen/Eigen/src/SVD/SVDBase.h +242 -182
- package/eigen/Eigen/src/SVD/UpperBidiagonalization.h +200 -235
- package/eigen/Eigen/src/SparseCholesky/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/SparseCholesky/SimplicialCholesky.h +765 -594
- package/eigen/Eigen/src/SparseCholesky/SimplicialCholesky_impl.h +308 -94
- package/eigen/Eigen/src/SparseCore/AmbiVector.h +202 -251
- package/eigen/Eigen/src/SparseCore/CompressedStorage.h +184 -252
- package/eigen/Eigen/src/SparseCore/ConservativeSparseSparseProduct.h +134 -178
- package/eigen/Eigen/src/SparseCore/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/SparseCore/SparseAssign.h +149 -140
- package/eigen/Eigen/src/SparseCore/SparseBlock.h +403 -440
- package/eigen/Eigen/src/SparseCore/SparseColEtree.h +100 -112
- package/eigen/Eigen/src/SparseCore/SparseCompressedBase.h +525 -303
- package/eigen/Eigen/src/SparseCore/SparseCwiseBinaryOp.h +555 -339
- package/eigen/Eigen/src/SparseCore/SparseCwiseUnaryOp.h +100 -108
- package/eigen/Eigen/src/SparseCore/SparseDenseProduct.h +169 -197
- 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 +1603 -1245
- package/eigen/Eigen/src/SparseCore/SparseMatrixBase.h +403 -350
- package/eigen/Eigen/src/SparseCore/SparsePermutation.h +186 -115
- package/eigen/Eigen/src/SparseCore/SparseProduct.h +94 -97
- 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 +370 -416
- 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 +138 -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 +756 -710
- 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 +245 -301
- 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 +89 -100
- 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 +124 -132
- 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 +450 -502
- package/eigen/Eigen/src/StlSupport/StdDeque.h +28 -93
- 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 -730
- 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 +428 -464
- 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 +9972 -16179
- 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.h → BlockMethods.inc} +434 -506
- package/eigen/Eigen/src/plugins/CommonCwiseBinaryOps.inc +116 -0
- package/eigen/Eigen/src/plugins/{CommonCwiseUnaryOps.h → CommonCwiseUnaryOps.inc} +58 -68
- 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/package.json +1 -1
- package/eigen/COPYING.APACHE +0 -203
- package/eigen/COPYING.BSD +0 -26
- package/eigen/COPYING.GPL +0 -674
- package/eigen/COPYING.LGPL +0 -502
- package/eigen/COPYING.MINPACK +0 -51
- package/eigen/COPYING.MPL2 +0 -373
- package/eigen/COPYING.README +0 -18
- package/eigen/Eigen/src/Core/BooleanRedux.h +0 -162
- package/eigen/Eigen/src/Core/arch/CUDA/Complex.h +0 -258
- package/eigen/Eigen/src/Core/arch/Default/TypeCasting.h +0 -120
- package/eigen/Eigen/src/Core/arch/SYCL/SyclMemoryModel.h +0 -694
- package/eigen/Eigen/src/Core/util/NonMPL2.h +0 -3
- 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 -358
- package/eigen/Eigen/src/plugins/ArrayCwiseUnaryOps.h +0 -696
- package/eigen/Eigen/src/plugins/CommonCwiseBinaryOps.h +0 -115
- package/eigen/Eigen/src/plugins/IndexedViewMethods.h +0 -262
- package/eigen/Eigen/src/plugins/MatrixCwiseBinaryOps.h +0 -152
- package/eigen/Eigen/src/plugins/MatrixCwiseUnaryOps.h +0 -95
- package/eigen/Eigen/src/plugins/ReshapedMethods.h +0 -149
- package/eigen/README.md +0 -5
|
@@ -10,284 +10,436 @@
|
|
|
10
10
|
#ifndef EIGEN_SYMBOLIC_INDEX_H
|
|
11
11
|
#define EIGEN_SYMBOLIC_INDEX_H
|
|
12
12
|
|
|
13
|
+
// IWYU pragma: private
|
|
14
|
+
#include "../InternalHeaderCheck.h"
|
|
15
|
+
|
|
13
16
|
namespace Eigen {
|
|
14
17
|
|
|
15
18
|
/** \namespace Eigen::symbolic
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
*/
|
|
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
|
+
*/
|
|
41
43
|
namespace symbolic {
|
|
42
44
|
|
|
43
|
-
template<typename Tag>
|
|
44
|
-
|
|
45
|
-
template<typename
|
|
46
|
-
|
|
47
|
-
template<typename
|
|
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
|
+
};
|
|
48
184
|
|
|
49
185
|
// A simple wrapper around an integral value to provide the eval method.
|
|
50
186
|
// We could also use a free-function symbolic_eval...
|
|
51
|
-
template<typename IndexType
|
|
52
|
-
class ValueExpr {
|
|
53
|
-
public:
|
|
54
|
-
ValueExpr(
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
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_;
|
|
59
203
|
};
|
|
60
204
|
|
|
61
205
|
// Specialization for compile-time value,
|
|
62
206
|
// It is similar to ValueExpr(N) but this version helps the compiler to generate better code.
|
|
63
|
-
template<int N>
|
|
64
|
-
class ValueExpr<internal::FixedInt<N
|
|
65
|
-
public:
|
|
66
|
-
ValueExpr()
|
|
67
|
-
|
|
68
|
-
|
|
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
|
+
}
|
|
69
220
|
};
|
|
70
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>> {};
|
|
71
228
|
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
template<typename Derived>
|
|
77
|
-
class BaseExpr
|
|
78
|
-
{
|
|
79
|
-
public:
|
|
80
|
-
const Derived& derived() const { return *static_cast<const Derived*>(this); }
|
|
229
|
+
template <typename Tag>
|
|
230
|
+
class SymbolValue<Tag, Index> : public BaseExpr<SymbolValue<Tag, Index>> {
|
|
231
|
+
public:
|
|
232
|
+
constexpr SymbolValue() = default;
|
|
81
233
|
|
|
82
|
-
/**
|
|
83
|
-
|
|
84
|
-
* \param values defines the values of the symbols, it can either be a SymbolValue or a std::tuple of SymbolValue
|
|
85
|
-
* as constructed by SymbolExpr::operator= operator.
|
|
86
|
-
*
|
|
87
|
-
*/
|
|
88
|
-
template<typename T>
|
|
89
|
-
Index eval(const T& values) const { return derived().eval_impl(values); }
|
|
90
|
-
|
|
91
|
-
#if EIGEN_HAS_CXX14
|
|
92
|
-
template<typename... Types>
|
|
93
|
-
Index eval(Types&&... values) const { return derived().eval_impl(std::make_tuple(values...)); }
|
|
94
|
-
#endif
|
|
95
|
-
|
|
96
|
-
NegateExpr<Derived> operator-() const { return NegateExpr<Derived>(derived()); }
|
|
97
|
-
|
|
98
|
-
AddExpr<Derived,ValueExpr<> > operator+(Index b) const
|
|
99
|
-
{ return AddExpr<Derived,ValueExpr<> >(derived(), b); }
|
|
100
|
-
AddExpr<Derived,ValueExpr<> > operator-(Index a) const
|
|
101
|
-
{ return AddExpr<Derived,ValueExpr<> >(derived(), -a); }
|
|
102
|
-
ProductExpr<Derived,ValueExpr<> > operator*(Index a) const
|
|
103
|
-
{ return ProductExpr<Derived,ValueExpr<> >(derived(),a); }
|
|
104
|
-
QuotientExpr<Derived,ValueExpr<> > operator/(Index a) const
|
|
105
|
-
{ return QuotientExpr<Derived,ValueExpr<> >(derived(),a); }
|
|
106
|
-
|
|
107
|
-
friend AddExpr<Derived,ValueExpr<> > operator+(Index a, const BaseExpr& b)
|
|
108
|
-
{ return AddExpr<Derived,ValueExpr<> >(b.derived(), a); }
|
|
109
|
-
friend AddExpr<NegateExpr<Derived>,ValueExpr<> > operator-(Index a, const BaseExpr& b)
|
|
110
|
-
{ return AddExpr<NegateExpr<Derived>,ValueExpr<> >(-b.derived(), a); }
|
|
111
|
-
friend ProductExpr<ValueExpr<>,Derived> operator*(Index a, const BaseExpr& b)
|
|
112
|
-
{ return ProductExpr<ValueExpr<>,Derived>(a,b.derived()); }
|
|
113
|
-
friend QuotientExpr<ValueExpr<>,Derived> operator/(Index a, const BaseExpr& b)
|
|
114
|
-
{ return QuotientExpr<ValueExpr<>,Derived>(a,b.derived()); }
|
|
115
|
-
|
|
116
|
-
template<int N>
|
|
117
|
-
AddExpr<Derived,ValueExpr<internal::FixedInt<N> > > operator+(internal::FixedInt<N>) const
|
|
118
|
-
{ return AddExpr<Derived,ValueExpr<internal::FixedInt<N> > >(derived(), ValueExpr<internal::FixedInt<N> >()); }
|
|
119
|
-
template<int N>
|
|
120
|
-
AddExpr<Derived,ValueExpr<internal::FixedInt<-N> > > operator-(internal::FixedInt<N>) const
|
|
121
|
-
{ return AddExpr<Derived,ValueExpr<internal::FixedInt<-N> > >(derived(), ValueExpr<internal::FixedInt<-N> >()); }
|
|
122
|
-
template<int N>
|
|
123
|
-
ProductExpr<Derived,ValueExpr<internal::FixedInt<N> > > operator*(internal::FixedInt<N>) const
|
|
124
|
-
{ return ProductExpr<Derived,ValueExpr<internal::FixedInt<N> > >(derived(),ValueExpr<internal::FixedInt<N> >()); }
|
|
125
|
-
template<int N>
|
|
126
|
-
QuotientExpr<Derived,ValueExpr<internal::FixedInt<N> > > operator/(internal::FixedInt<N>) const
|
|
127
|
-
{ return QuotientExpr<Derived,ValueExpr<internal::FixedInt<N> > >(derived(),ValueExpr<internal::FixedInt<N> >()); }
|
|
128
|
-
|
|
129
|
-
template<int N>
|
|
130
|
-
friend AddExpr<Derived,ValueExpr<internal::FixedInt<N> > > operator+(internal::FixedInt<N>, const BaseExpr& b)
|
|
131
|
-
{ return AddExpr<Derived,ValueExpr<internal::FixedInt<N> > >(b.derived(), ValueExpr<internal::FixedInt<N> >()); }
|
|
132
|
-
template<int N>
|
|
133
|
-
friend AddExpr<NegateExpr<Derived>,ValueExpr<internal::FixedInt<N> > > operator-(internal::FixedInt<N>, const BaseExpr& b)
|
|
134
|
-
{ return AddExpr<NegateExpr<Derived>,ValueExpr<internal::FixedInt<N> > >(-b.derived(), ValueExpr<internal::FixedInt<N> >()); }
|
|
135
|
-
template<int N>
|
|
136
|
-
friend ProductExpr<ValueExpr<internal::FixedInt<N> >,Derived> operator*(internal::FixedInt<N>, const BaseExpr& b)
|
|
137
|
-
{ return ProductExpr<ValueExpr<internal::FixedInt<N> >,Derived>(ValueExpr<internal::FixedInt<N> >(),b.derived()); }
|
|
138
|
-
template<int N>
|
|
139
|
-
friend QuotientExpr<ValueExpr<internal::FixedInt<N> >,Derived> operator/(internal::FixedInt<N>, const BaseExpr& b)
|
|
140
|
-
{ return QuotientExpr<ValueExpr<internal::FixedInt<N> > ,Derived>(ValueExpr<internal::FixedInt<N> >(),b.derived()); }
|
|
141
|
-
|
|
142
|
-
#if (!EIGEN_HAS_CXX14)
|
|
143
|
-
template<int N>
|
|
144
|
-
AddExpr<Derived,ValueExpr<internal::FixedInt<N> > > operator+(internal::FixedInt<N> (*)()) const
|
|
145
|
-
{ return AddExpr<Derived,ValueExpr<internal::FixedInt<N> > >(derived(), ValueExpr<internal::FixedInt<N> >()); }
|
|
146
|
-
template<int N>
|
|
147
|
-
AddExpr<Derived,ValueExpr<internal::FixedInt<-N> > > operator-(internal::FixedInt<N> (*)()) const
|
|
148
|
-
{ return AddExpr<Derived,ValueExpr<internal::FixedInt<-N> > >(derived(), ValueExpr<internal::FixedInt<-N> >()); }
|
|
149
|
-
template<int N>
|
|
150
|
-
ProductExpr<Derived,ValueExpr<internal::FixedInt<N> > > operator*(internal::FixedInt<N> (*)()) const
|
|
151
|
-
{ return ProductExpr<Derived,ValueExpr<internal::FixedInt<N> > >(derived(),ValueExpr<internal::FixedInt<N> >()); }
|
|
152
|
-
template<int N>
|
|
153
|
-
QuotientExpr<Derived,ValueExpr<internal::FixedInt<N> > > operator/(internal::FixedInt<N> (*)()) const
|
|
154
|
-
{ return QuotientExpr<Derived,ValueExpr<internal::FixedInt<N> > >(derived(),ValueExpr<internal::FixedInt<N> >()); }
|
|
155
|
-
|
|
156
|
-
template<int N>
|
|
157
|
-
friend AddExpr<Derived,ValueExpr<internal::FixedInt<N> > > operator+(internal::FixedInt<N> (*)(), const BaseExpr& b)
|
|
158
|
-
{ return AddExpr<Derived,ValueExpr<internal::FixedInt<N> > >(b.derived(), ValueExpr<internal::FixedInt<N> >()); }
|
|
159
|
-
template<int N>
|
|
160
|
-
friend AddExpr<NegateExpr<Derived>,ValueExpr<internal::FixedInt<N> > > operator-(internal::FixedInt<N> (*)(), const BaseExpr& b)
|
|
161
|
-
{ return AddExpr<NegateExpr<Derived>,ValueExpr<internal::FixedInt<N> > >(-b.derived(), ValueExpr<internal::FixedInt<N> >()); }
|
|
162
|
-
template<int N>
|
|
163
|
-
friend ProductExpr<ValueExpr<internal::FixedInt<N> >,Derived> operator*(internal::FixedInt<N> (*)(), const BaseExpr& b)
|
|
164
|
-
{ return ProductExpr<ValueExpr<internal::FixedInt<N> >,Derived>(ValueExpr<internal::FixedInt<N> >(),b.derived()); }
|
|
165
|
-
template<int N>
|
|
166
|
-
friend QuotientExpr<ValueExpr<internal::FixedInt<N> >,Derived> operator/(internal::FixedInt<N> (*)(), const BaseExpr& b)
|
|
167
|
-
{ return QuotientExpr<ValueExpr<internal::FixedInt<N> > ,Derived>(ValueExpr<internal::FixedInt<N> >(),b.derived()); }
|
|
168
|
-
#endif
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
template<typename OtherDerived>
|
|
172
|
-
AddExpr<Derived,OtherDerived> operator+(const BaseExpr<OtherDerived> &b) const
|
|
173
|
-
{ return AddExpr<Derived,OtherDerived>(derived(), b.derived()); }
|
|
174
|
-
|
|
175
|
-
template<typename OtherDerived>
|
|
176
|
-
AddExpr<Derived,NegateExpr<OtherDerived> > operator-(const BaseExpr<OtherDerived> &b) const
|
|
177
|
-
{ return AddExpr<Derived,NegateExpr<OtherDerived> >(derived(), -b.derived()); }
|
|
178
|
-
|
|
179
|
-
template<typename OtherDerived>
|
|
180
|
-
ProductExpr<Derived,OtherDerived> operator*(const BaseExpr<OtherDerived> &b) const
|
|
181
|
-
{ return ProductExpr<Derived,OtherDerived>(derived(), b.derived()); }
|
|
182
|
-
|
|
183
|
-
template<typename OtherDerived>
|
|
184
|
-
QuotientExpr<Derived,OtherDerived> operator/(const BaseExpr<OtherDerived> &b) const
|
|
185
|
-
{ return QuotientExpr<Derived,OtherDerived>(derived(), b.derived()); }
|
|
186
|
-
};
|
|
234
|
+
/** Default constructor from the value \a val */
|
|
235
|
+
constexpr SymbolValue(Index val) : value_(val) {}
|
|
187
236
|
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
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_;
|
|
192
255
|
};
|
|
193
256
|
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
class SymbolValue
|
|
200
|
-
{
|
|
201
|
-
public:
|
|
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
|
+
|
|
202
262
|
/** Default constructor from the value \a val */
|
|
203
|
-
SymbolValue(
|
|
263
|
+
constexpr SymbolValue(internal::FixedInt<N>) {}
|
|
204
264
|
|
|
205
265
|
/** \returns the stored value of the symbol */
|
|
206
|
-
Index value() const { return
|
|
207
|
-
|
|
208
|
-
|
|
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
|
+
}
|
|
209
316
|
};
|
|
210
317
|
|
|
211
318
|
/** Expression of a symbol uniquely identified by the template parameter type \c tag */
|
|
212
|
-
template<typename tag>
|
|
213
|
-
class SymbolExpr : public BaseExpr<SymbolExpr<tag
|
|
214
|
-
|
|
215
|
-
public:
|
|
319
|
+
template <typename tag>
|
|
320
|
+
class SymbolExpr : public BaseExpr<SymbolExpr<tag>> {
|
|
321
|
+
public:
|
|
216
322
|
/** Alias to the template parameter \c tag */
|
|
217
323
|
typedef tag Tag;
|
|
218
324
|
|
|
219
|
-
SymbolExpr()
|
|
325
|
+
constexpr SymbolExpr() = default;
|
|
220
326
|
|
|
221
327
|
/** Associate the value \a val to the given symbol \c *this, uniquely identified by its \c Tag.
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
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>{}};
|
|
227
337
|
}
|
|
228
338
|
|
|
229
|
-
|
|
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
|
+
}
|
|
230
343
|
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
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
|
+
}
|
|
236
349
|
};
|
|
237
350
|
|
|
238
|
-
template<typename Arg0>
|
|
239
|
-
class NegateExpr : public BaseExpr<NegateExpr<Arg0
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
NegateExpr(const Arg0& arg0) : m_arg0(arg0) {}
|
|
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
|
+
}
|
|
243
367
|
|
|
244
|
-
|
|
245
|
-
Index eval_impl(const T& values) const { return -m_arg0.eval_impl(values); }
|
|
246
|
-
protected:
|
|
368
|
+
protected:
|
|
247
369
|
Arg0 m_arg0;
|
|
248
370
|
};
|
|
249
371
|
|
|
250
|
-
template<typename Arg0, typename Arg1>
|
|
251
|
-
class AddExpr : public BaseExpr<AddExpr<Arg0,Arg1
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
AddExpr(const Arg0& arg0, const Arg1& arg1) : m_arg0(arg0), m_arg1(arg1) {}
|
|
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) {}
|
|
255
377
|
|
|
256
|
-
template<typename
|
|
257
|
-
Index eval_impl(const
|
|
258
|
-
|
|
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:
|
|
259
391
|
Arg0 m_arg0;
|
|
260
392
|
Arg1 m_arg1;
|
|
261
393
|
};
|
|
262
394
|
|
|
263
|
-
template<typename Arg0, typename Arg1>
|
|
264
|
-
class ProductExpr : public BaseExpr<ProductExpr<Arg0,Arg1
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
ProductExpr(const Arg0& arg0, const Arg1& arg1) : m_arg0(arg0), m_arg1(arg1) {}
|
|
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
|
+
}
|
|
268
412
|
|
|
269
|
-
|
|
270
|
-
Index eval_impl(const T& values) const { return m_arg0.eval_impl(values) * m_arg1.eval_impl(values); }
|
|
271
|
-
protected:
|
|
413
|
+
protected:
|
|
272
414
|
Arg0 m_arg0;
|
|
273
415
|
Arg1 m_arg1;
|
|
274
416
|
};
|
|
275
417
|
|
|
276
|
-
template<typename Arg0, typename Arg1>
|
|
277
|
-
class QuotientExpr : public BaseExpr<QuotientExpr<Arg0,Arg1
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
QuotientExpr(const Arg0& arg0, const Arg1& arg1) : m_arg0(arg0), m_arg1(arg1) {}
|
|
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
|
+
}
|
|
281
435
|
|
|
282
|
-
|
|
283
|
-
Index eval_impl(const T& values) const { return m_arg0.eval_impl(values) / m_arg1.eval_impl(values); }
|
|
284
|
-
protected:
|
|
436
|
+
protected:
|
|
285
437
|
Arg0 m_arg0;
|
|
286
438
|
Arg1 m_arg1;
|
|
287
439
|
};
|
|
288
440
|
|
|
289
|
-
}
|
|
441
|
+
} // end namespace symbolic
|
|
290
442
|
|
|
291
|
-
}
|
|
443
|
+
} // end namespace Eigen
|
|
292
444
|
|
|
293
|
-
#endif
|
|
445
|
+
#endif // EIGEN_SYMBOLIC_INDEX_H
|