@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
|
@@ -14,276 +14,288 @@
|
|
|
14
14
|
#include <vector>
|
|
15
15
|
#include <list>
|
|
16
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
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
>
|
|
51
|
-
class IncompleteCholesky : public SparseSolverBase<IncompleteCholesky<Scalar,
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
17
|
+
// IWYU pragma: private
|
|
18
|
+
#include "./InternalHeaderCheck.h"
|
|
19
|
+
|
|
20
|
+
namespace Eigen {
|
|
21
|
+
/**
|
|
22
|
+
* \brief Modified Incomplete Cholesky with dual threshold
|
|
23
|
+
*
|
|
24
|
+
* References : C-J. Lin and J. J. Moré, Incomplete Cholesky Factorizations with
|
|
25
|
+
* Limited memory, SIAM J. Sci. Comput. 21(1), pp. 24-45, 1999
|
|
26
|
+
*
|
|
27
|
+
* \tparam Scalar the scalar type of the input matrices
|
|
28
|
+
* \tparam UpLo_ The triangular part that will be used for the computations. It can be Lower
|
|
29
|
+
* or Upper. Default is Lower.
|
|
30
|
+
* \tparam OrderingType_ The ordering method to use, either AMDOrdering<> or NaturalOrdering<>. Default is
|
|
31
|
+
* AMDOrdering<int>.
|
|
32
|
+
*
|
|
33
|
+
* \implsparsesolverconcept
|
|
34
|
+
*
|
|
35
|
+
* It performs the following incomplete factorization: \f$ S P A P' S + \sigma I \approx L L' \f$
|
|
36
|
+
* where L is a lower triangular factor, S is a diagonal scaling matrix, P is a
|
|
37
|
+
* fill-in reducing permutation as computed by the ordering method, and \f$ \sigma \f$ is a shift
|
|
38
|
+
* for ensuring the decomposed matrix is positive definite.
|
|
39
|
+
*
|
|
40
|
+
* \b Shifting \b strategy: Let \f$ B = S P A P' S \f$ be the scaled matrix on which the factorization is carried out,
|
|
41
|
+
* and \f$ \beta \f$ be the minimum value of the diagonal. If \f$ \beta > 0 \f$ then, the factorization is directly
|
|
42
|
+
* performed on the matrix B, and \f$ \sigma = 0 \f$. Otherwise, the factorization is performed on the shifted matrix
|
|
43
|
+
* \f$ B + \sigma I \f$ for a shifting factor \f$ \sigma \f$. We start with \f$ \sigma = \sigma_0 - \beta \f$, where
|
|
44
|
+
* \f$ \sigma_0 \f$ is the initial shift value as returned and set by setInitialShift() method. The default value is \f$
|
|
45
|
+
* \sigma_0 = 10^{-3} \f$. If the factorization fails, then the shift in doubled until it succeed or a maximum of ten
|
|
46
|
+
* attempts. If it still fails, as returned by the info() method, then you can either increase the initial shift, or
|
|
47
|
+
* better use another preconditioning technique.
|
|
48
|
+
*
|
|
49
|
+
*/
|
|
50
|
+
template <typename Scalar, int UpLo_ = Lower, typename OrderingType_ = AMDOrdering<int> >
|
|
51
|
+
class IncompleteCholesky : public SparseSolverBase<IncompleteCholesky<Scalar, UpLo_, OrderingType_> > {
|
|
52
|
+
protected:
|
|
53
|
+
typedef SparseSolverBase<IncompleteCholesky<Scalar, UpLo_, OrderingType_> > Base;
|
|
54
|
+
using Base::m_isInitialized;
|
|
55
|
+
|
|
56
|
+
public:
|
|
57
|
+
typedef typename NumTraits<Scalar>::Real RealScalar;
|
|
58
|
+
typedef OrderingType_ OrderingType;
|
|
59
|
+
typedef typename OrderingType::PermutationType PermutationType;
|
|
60
|
+
typedef typename PermutationType::StorageIndex StorageIndex;
|
|
61
|
+
typedef SparseMatrix<Scalar, ColMajor, StorageIndex> FactorType;
|
|
62
|
+
typedef Matrix<Scalar, Dynamic, 1> VectorSx;
|
|
63
|
+
typedef Matrix<RealScalar, Dynamic, 1> VectorRx;
|
|
64
|
+
typedef Matrix<StorageIndex, Dynamic, 1> VectorIx;
|
|
65
|
+
typedef std::vector<std::list<StorageIndex> > VectorList;
|
|
66
|
+
enum { UpLo = UpLo_ };
|
|
67
|
+
enum { ColsAtCompileTime = Dynamic, MaxColsAtCompileTime = Dynamic };
|
|
68
|
+
|
|
69
|
+
public:
|
|
70
|
+
/** Default constructor leaving the object in a partly non-initialized stage.
|
|
71
|
+
*
|
|
72
|
+
* You must call compute() or the pair analyzePattern()/factorize() to make it valid.
|
|
73
|
+
*
|
|
74
|
+
* \sa IncompleteCholesky(const MatrixType&)
|
|
75
|
+
*/
|
|
76
|
+
IncompleteCholesky() : m_initialShift(1e-3), m_analysisIsOk(false), m_factorizationIsOk(false) {}
|
|
77
|
+
|
|
78
|
+
/** Constructor computing the incomplete factorization for the given matrix \a matrix.
|
|
79
|
+
*/
|
|
80
|
+
template <typename MatrixType>
|
|
81
|
+
IncompleteCholesky(const MatrixType& matrix)
|
|
82
|
+
: m_initialShift(1e-3), m_analysisIsOk(false), m_factorizationIsOk(false) {
|
|
83
|
+
compute(matrix);
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
/** \returns number of rows of the factored matrix */
|
|
87
|
+
constexpr Index rows() const noexcept { return m_L.rows(); }
|
|
88
|
+
|
|
89
|
+
/** \returns number of columns of the factored matrix */
|
|
90
|
+
constexpr Index cols() const noexcept { return m_L.cols(); }
|
|
91
|
+
|
|
92
|
+
/** \brief Reports whether previous computation was successful.
|
|
93
|
+
*
|
|
94
|
+
* It triggers an assertion if \c *this has not been initialized through the respective constructor,
|
|
95
|
+
* or a call to compute() or analyzePattern().
|
|
96
|
+
*
|
|
97
|
+
* \returns \c Success if computation was successful,
|
|
98
|
+
* \c NumericalIssue if the matrix appears to be negative.
|
|
99
|
+
*/
|
|
100
|
+
ComputationInfo info() const {
|
|
101
|
+
eigen_assert(m_isInitialized && "IncompleteCholesky is not initialized.");
|
|
102
|
+
return m_info;
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
/** \brief Set the initial shift parameter \f$ \sigma \f$.
|
|
106
|
+
*/
|
|
107
|
+
void setInitialShift(RealScalar shift) { m_initialShift = shift; }
|
|
108
|
+
|
|
109
|
+
/** \brief Computes the fill reducing permutation vector using the sparsity pattern of \a mat
|
|
110
|
+
*/
|
|
111
|
+
template <typename MatrixType>
|
|
112
|
+
void analyzePattern(const MatrixType& mat) {
|
|
113
|
+
OrderingType ord;
|
|
114
|
+
PermutationType pinv;
|
|
115
|
+
ord(mat.template selfadjointView<UpLo>(), pinv);
|
|
116
|
+
if (pinv.size() > 0)
|
|
117
|
+
m_perm = pinv.inverse();
|
|
118
|
+
else
|
|
119
|
+
m_perm.resize(0);
|
|
120
|
+
m_L.resize(mat.rows(), mat.cols());
|
|
121
|
+
m_analysisIsOk = true;
|
|
122
|
+
m_isInitialized = true;
|
|
123
|
+
m_info = Success;
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
/** \brief Performs the numerical factorization of the input matrix \a mat
|
|
127
|
+
*
|
|
128
|
+
* The method analyzePattern() or compute() must have been called beforehand
|
|
129
|
+
* with a matrix having the same pattern.
|
|
130
|
+
*
|
|
131
|
+
* \sa compute(), analyzePattern()
|
|
132
|
+
*/
|
|
133
|
+
template <typename MatrixType>
|
|
134
|
+
void factorize(const MatrixType& mat);
|
|
135
|
+
|
|
136
|
+
/** Computes or re-computes the incomplete Cholesky factorization of the input matrix \a mat
|
|
137
|
+
*
|
|
138
|
+
* It is a shortcut for a sequential call to the analyzePattern() and factorize() methods.
|
|
139
|
+
*
|
|
140
|
+
* \sa analyzePattern(), factorize()
|
|
141
|
+
*/
|
|
142
|
+
template <typename MatrixType>
|
|
143
|
+
void compute(const MatrixType& mat) {
|
|
144
|
+
analyzePattern(mat);
|
|
145
|
+
factorize(mat);
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
// internal
|
|
149
|
+
template <typename Rhs, typename Dest>
|
|
150
|
+
void _solve_impl(const Rhs& b, Dest& x) const {
|
|
151
|
+
eigen_assert(m_factorizationIsOk && "factorize() should be called first");
|
|
152
|
+
if (m_perm.rows() == b.rows())
|
|
153
|
+
x = m_perm * b;
|
|
154
|
+
else
|
|
155
|
+
x = b;
|
|
156
|
+
x = m_scale.asDiagonal() * x;
|
|
157
|
+
x = m_L.template triangularView<Lower>().solve(x);
|
|
158
|
+
x = m_L.adjoint().template triangularView<Upper>().solve(x);
|
|
159
|
+
x = m_scale.asDiagonal() * x;
|
|
160
|
+
if (m_perm.rows() == b.rows()) x = m_perm.inverse() * x;
|
|
161
|
+
}
|
|
162
|
+
|
|
163
|
+
/** \returns the sparse lower triangular factor L */
|
|
164
|
+
const FactorType& matrixL() const {
|
|
165
|
+
eigen_assert(m_factorizationIsOk && "factorize() should be called first");
|
|
166
|
+
return m_L;
|
|
167
|
+
}
|
|
167
168
|
|
|
168
|
-
|
|
169
|
-
|
|
169
|
+
/** \returns a vector representing the scaling factor S */
|
|
170
|
+
const VectorRx& scalingS() const {
|
|
171
|
+
eigen_assert(m_factorizationIsOk && "factorize() should be called first");
|
|
172
|
+
return m_scale;
|
|
173
|
+
}
|
|
170
174
|
|
|
171
|
-
|
|
172
|
-
|
|
175
|
+
/** \returns the fill-in reducing permutation P (can be empty for a natural ordering) */
|
|
176
|
+
const PermutationType& permutationP() const {
|
|
177
|
+
eigen_assert(m_analysisIsOk && "analyzePattern() should be called first");
|
|
178
|
+
return m_perm;
|
|
179
|
+
}
|
|
173
180
|
|
|
174
|
-
|
|
175
|
-
|
|
181
|
+
/** \returns the final shift parameter from the computation */
|
|
182
|
+
RealScalar shift() const { return m_shift; }
|
|
176
183
|
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
184
|
+
protected:
|
|
185
|
+
FactorType m_L; // The lower part stored in CSC
|
|
186
|
+
VectorRx m_scale; // The vector for scaling the matrix
|
|
187
|
+
RealScalar m_initialShift; // The initial shift parameter
|
|
188
|
+
bool m_analysisIsOk;
|
|
189
|
+
bool m_factorizationIsOk;
|
|
190
|
+
ComputationInfo m_info;
|
|
191
|
+
PermutationType m_perm;
|
|
192
|
+
RealScalar m_shift; // The final shift parameter.
|
|
185
193
|
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
194
|
+
private:
|
|
195
|
+
inline void updateList(Ref<const VectorIx> colPtr, Ref<VectorIx> rowIdx, Ref<VectorSx> vals, const Index& col,
|
|
196
|
+
const Index& jk, VectorIx& firstElt, VectorList& listCol);
|
|
197
|
+
};
|
|
189
198
|
|
|
190
199
|
// Based on the following paper:
|
|
191
200
|
// C-J. Lin and J. J. Moré, Incomplete Cholesky Factorizations with
|
|
192
201
|
// Limited memory, SIAM J. Sci. Comput. 21(1), pp. 24-45, 1999
|
|
193
202
|
// http://ftp.mcs.anl.gov/pub/tech_reports/reports/P682.pdf
|
|
194
|
-
template<typename Scalar, int
|
|
195
|
-
template<typename
|
|
196
|
-
void IncompleteCholesky<Scalar,
|
|
197
|
-
{
|
|
203
|
+
template <typename Scalar, int UpLo_, typename OrderingType>
|
|
204
|
+
template <typename MatrixType_>
|
|
205
|
+
void IncompleteCholesky<Scalar, UpLo_, OrderingType>::factorize(const MatrixType_& mat) {
|
|
198
206
|
using std::sqrt;
|
|
199
|
-
eigen_assert(m_analysisIsOk && "analyzePattern() should be called first");
|
|
200
|
-
|
|
201
|
-
// Dropping strategy : Keep only the p largest elements per column, where p is the number of elements in the column of
|
|
202
|
-
|
|
207
|
+
eigen_assert(m_analysisIsOk && "analyzePattern() should be called first");
|
|
208
|
+
|
|
209
|
+
// Dropping strategy : Keep only the p largest elements per column, where p is the number of elements in the column of
|
|
210
|
+
// the original matrix. Other strategies will be added
|
|
211
|
+
|
|
203
212
|
// Apply the fill-reducing permutation computed in analyzePattern()
|
|
204
|
-
if (m_perm.rows() == mat.rows()
|
|
213
|
+
if (m_perm.rows() == mat.rows()) // To detect the null permutation
|
|
205
214
|
{
|
|
206
215
|
// The temporary is needed to make sure that the diagonal entry is properly sorted
|
|
207
216
|
FactorType tmp(mat.rows(), mat.cols());
|
|
208
|
-
tmp = mat.template selfadjointView<
|
|
217
|
+
tmp = mat.template selfadjointView<UpLo_>().twistedBy(m_perm);
|
|
209
218
|
m_L.template selfadjointView<Lower>() = tmp.template selfadjointView<Lower>();
|
|
219
|
+
} else {
|
|
220
|
+
m_L.template selfadjointView<Lower>() = mat.template selfadjointView<UpLo_>();
|
|
210
221
|
}
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
222
|
+
|
|
223
|
+
// The algorithm will insert increasingly large shifts on the diagonal until
|
|
224
|
+
// factorization succeeds. Therefore we have to make sure that there is a
|
|
225
|
+
// space in the datastructure to store such values, even if the original
|
|
226
|
+
// matrix has a zero on the diagonal.
|
|
227
|
+
bool modified = false;
|
|
228
|
+
for (Index i = 0; i < mat.cols(); ++i) {
|
|
229
|
+
bool inserted = false;
|
|
230
|
+
m_L.findOrInsertCoeff(i, i, &inserted);
|
|
231
|
+
if (inserted) {
|
|
232
|
+
modified = true;
|
|
233
|
+
}
|
|
214
234
|
}
|
|
215
|
-
|
|
216
|
-
|
|
235
|
+
if (modified) m_L.makeCompressed();
|
|
236
|
+
|
|
237
|
+
Index n = m_L.cols();
|
|
217
238
|
Index nnz = m_L.nonZeros();
|
|
218
|
-
Map<VectorSx> vals(m_L.valuePtr(), nnz);
|
|
219
|
-
Map<VectorIx> rowIdx(m_L.innerIndexPtr(), nnz);
|
|
220
|
-
Map<VectorIx> colPtr(
|
|
221
|
-
VectorIx firstElt(n-1);
|
|
222
|
-
VectorList listCol(n);
|
|
223
|
-
VectorSx col_vals(n);
|
|
224
|
-
VectorIx col_irow(n);
|
|
239
|
+
Map<VectorSx> vals(m_L.valuePtr(), nnz); // values
|
|
240
|
+
Map<VectorIx> rowIdx(m_L.innerIndexPtr(), nnz); // Row indices
|
|
241
|
+
Map<VectorIx> colPtr(m_L.outerIndexPtr(), n + 1); // Pointer to the beginning of each row
|
|
242
|
+
VectorIx firstElt(n - 1); // for each j, points to the next entry in vals that will be used in the factorization
|
|
243
|
+
VectorList listCol(n); // listCol(j) is a linked list of columns to update column j
|
|
244
|
+
VectorSx col_vals(n); // Store a nonzero values in each column
|
|
245
|
+
VectorIx col_irow(n); // Row indices of nonzero elements in each column
|
|
225
246
|
VectorIx col_pattern(n);
|
|
226
247
|
col_pattern.fill(-1);
|
|
227
248
|
StorageIndex col_nnz;
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
// Computes the scaling factors
|
|
249
|
+
|
|
250
|
+
// Computes the scaling factors
|
|
231
251
|
m_scale.resize(n);
|
|
232
252
|
m_scale.setZero();
|
|
233
253
|
for (Index j = 0; j < n; j++)
|
|
234
|
-
for (Index k = colPtr[j]; k < colPtr[j+1]; k++)
|
|
235
|
-
{
|
|
254
|
+
for (Index k = colPtr[j]; k < colPtr[j + 1]; k++) {
|
|
236
255
|
m_scale(j) += numext::abs2(vals(k));
|
|
237
|
-
if(rowIdx[k]!=j)
|
|
238
|
-
m_scale(rowIdx[k]) += numext::abs2(vals(k));
|
|
256
|
+
if (rowIdx[k] != j) m_scale(rowIdx[k]) += numext::abs2(vals(k));
|
|
239
257
|
}
|
|
240
|
-
|
|
258
|
+
|
|
241
259
|
m_scale = m_scale.cwiseSqrt().cwiseSqrt();
|
|
242
260
|
|
|
243
261
|
for (Index j = 0; j < n; ++j)
|
|
244
|
-
if(m_scale(j)>(std::numeric_limits<RealScalar>::min)())
|
|
245
|
-
m_scale(j) = RealScalar(1)/m_scale(j);
|
|
262
|
+
if (m_scale(j) > (std::numeric_limits<RealScalar>::min)())
|
|
263
|
+
m_scale(j) = RealScalar(1) / m_scale(j);
|
|
246
264
|
else
|
|
247
265
|
m_scale(j) = 1;
|
|
248
266
|
|
|
249
267
|
// TODO disable scaling if not needed, i.e., if it is roughly uniform? (this will make solve() faster)
|
|
250
|
-
|
|
251
|
-
// Scale and compute the shift for the matrix
|
|
268
|
+
|
|
269
|
+
// Scale and compute the shift for the matrix
|
|
252
270
|
RealScalar mindiag = NumTraits<RealScalar>::highest();
|
|
253
|
-
for (Index j = 0; j < n; j++)
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
eigen_internal_assert(rowIdx[colPtr[j]]==j && "IncompleteCholesky: only the lower triangular part must be stored");
|
|
271
|
+
for (Index j = 0; j < n; j++) {
|
|
272
|
+
for (Index k = colPtr[j]; k < colPtr[j + 1]; k++) vals[k] *= (m_scale(j) * m_scale(rowIdx[k]));
|
|
273
|
+
eigen_internal_assert(rowIdx[colPtr[j]] == j &&
|
|
274
|
+
"IncompleteCholesky: only the lower triangular part must be stored");
|
|
258
275
|
mindiag = numext::mini(numext::real(vals[colPtr[j]]), mindiag);
|
|
259
276
|
}
|
|
260
277
|
|
|
261
278
|
FactorType L_save = m_L;
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
if(mindiag <= RealScalar(0.))
|
|
265
|
-
shift = m_initialShift - mindiag;
|
|
279
|
+
|
|
280
|
+
m_shift = RealScalar(0);
|
|
281
|
+
if (mindiag <= RealScalar(0.)) m_shift = m_initialShift - mindiag;
|
|
266
282
|
|
|
267
283
|
m_info = NumericalIssue;
|
|
268
284
|
|
|
269
285
|
// Try to perform the incomplete factorization using the current shift
|
|
270
286
|
int iter = 0;
|
|
271
|
-
do
|
|
272
|
-
{
|
|
287
|
+
do {
|
|
273
288
|
// Apply the shift to the diagonal elements of the matrix
|
|
274
|
-
for (Index j = 0; j < n; j++)
|
|
275
|
-
vals[colPtr[j]] += shift;
|
|
289
|
+
for (Index j = 0; j < n; j++) vals[colPtr[j]] += m_shift;
|
|
276
290
|
|
|
277
291
|
// jki version of the Cholesky factorization
|
|
278
|
-
Index j=0;
|
|
279
|
-
for (; j < n; ++j)
|
|
280
|
-
{
|
|
292
|
+
Index j = 0;
|
|
293
|
+
for (; j < n; ++j) {
|
|
281
294
|
// Left-looking factorization of the j-th column
|
|
282
295
|
// First, load the j-th column into col_vals
|
|
283
296
|
Scalar diag = vals[colPtr[j]]; // It is assumed that only the lower part is stored
|
|
284
297
|
col_nnz = 0;
|
|
285
|
-
for (Index i = colPtr[j] + 1; i < colPtr[j+1]; i++)
|
|
286
|
-
{
|
|
298
|
+
for (Index i = colPtr[j] + 1; i < colPtr[j + 1]; i++) {
|
|
287
299
|
StorageIndex l = rowIdx[i];
|
|
288
300
|
col_vals(col_nnz) = vals[i];
|
|
289
301
|
col_irow(col_nnz) = l;
|
|
@@ -293,69 +305,60 @@ void IncompleteCholesky<Scalar,_UpLo, OrderingType>::factorize(const _MatrixType
|
|
|
293
305
|
{
|
|
294
306
|
typename std::list<StorageIndex>::iterator k;
|
|
295
307
|
// Browse all previous columns that will update column j
|
|
296
|
-
for(k = listCol[j].begin(); k != listCol[j].end(); k++)
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
eigen_internal_assert(rowIdx[jk]==j);
|
|
308
|
+
for (k = listCol[j].begin(); k != listCol[j].end(); k++) {
|
|
309
|
+
Index jk = firstElt(*k); // First element to use in the column
|
|
310
|
+
eigen_internal_assert(rowIdx[jk] == j);
|
|
300
311
|
Scalar v_j_jk = numext::conj(vals[jk]);
|
|
301
312
|
|
|
302
313
|
jk += 1;
|
|
303
|
-
for (Index i = jk; i < colPtr[*k+1]; i++)
|
|
304
|
-
{
|
|
314
|
+
for (Index i = jk; i < colPtr[*k + 1]; i++) {
|
|
305
315
|
StorageIndex l = rowIdx[i];
|
|
306
|
-
if(col_pattern[l]<0)
|
|
307
|
-
{
|
|
316
|
+
if (col_pattern[l] < 0) {
|
|
308
317
|
col_vals(col_nnz) = vals[i] * v_j_jk;
|
|
309
318
|
col_irow[col_nnz] = l;
|
|
310
319
|
col_pattern(l) = col_nnz;
|
|
311
320
|
col_nnz++;
|
|
312
|
-
}
|
|
313
|
-
else
|
|
321
|
+
} else
|
|
314
322
|
col_vals(col_pattern[l]) -= vals[i] * v_j_jk;
|
|
315
323
|
}
|
|
316
|
-
updateList(colPtr,rowIdx,vals, *k, jk, firstElt, listCol);
|
|
324
|
+
updateList(colPtr, rowIdx, vals, *k, jk, firstElt, listCol);
|
|
317
325
|
}
|
|
318
326
|
}
|
|
319
327
|
|
|
320
328
|
// Scale the current column
|
|
321
|
-
if(numext::real(diag) <= 0)
|
|
322
|
-
|
|
323
|
-
if(++iter>=10)
|
|
324
|
-
return;
|
|
329
|
+
if (numext::real(diag) <= 0) {
|
|
330
|
+
if (++iter >= 10) return;
|
|
325
331
|
|
|
326
332
|
// increase shift
|
|
327
|
-
|
|
333
|
+
m_shift = numext::maxi(m_initialShift, RealScalar(2) * m_shift);
|
|
328
334
|
// restore m_L, col_pattern, and listCol
|
|
329
335
|
vals = Map<const VectorSx>(L_save.valuePtr(), nnz);
|
|
330
336
|
rowIdx = Map<const VectorIx>(L_save.innerIndexPtr(), nnz);
|
|
331
|
-
colPtr = Map<const VectorIx>(L_save.outerIndexPtr(), n+1);
|
|
337
|
+
colPtr = Map<const VectorIx>(L_save.outerIndexPtr(), n + 1);
|
|
332
338
|
col_pattern.fill(-1);
|
|
333
|
-
for(Index i=0; i<n; ++i)
|
|
334
|
-
listCol[i].clear();
|
|
339
|
+
for (Index i = 0; i < n; ++i) listCol[i].clear();
|
|
335
340
|
|
|
336
341
|
break;
|
|
337
342
|
}
|
|
338
343
|
|
|
339
344
|
RealScalar rdiag = sqrt(numext::real(diag));
|
|
340
345
|
vals[colPtr[j]] = rdiag;
|
|
341
|
-
for (Index k = 0; k<col_nnz; ++k)
|
|
342
|
-
{
|
|
346
|
+
for (Index k = 0; k < col_nnz; ++k) {
|
|
343
347
|
Index i = col_irow[k];
|
|
344
|
-
//Scale
|
|
348
|
+
// Scale
|
|
345
349
|
col_vals(k) /= rdiag;
|
|
346
|
-
//Update the remaining diagonals with col_vals
|
|
350
|
+
// Update the remaining diagonals with col_vals
|
|
347
351
|
vals[colPtr[i]] -= numext::abs2(col_vals(k));
|
|
348
352
|
}
|
|
349
353
|
// Select the largest p elements
|
|
350
354
|
// p is the original number of elements in the column (without the diagonal)
|
|
351
|
-
Index p = colPtr[j+1] - colPtr[j] - 1
|
|
355
|
+
Index p = colPtr[j + 1] - colPtr[j] - 1;
|
|
352
356
|
Ref<VectorSx> cvals = col_vals.head(col_nnz);
|
|
353
357
|
Ref<VectorIx> cirow = col_irow.head(col_nnz);
|
|
354
|
-
internal::QuickSplit(cvals,cirow, p);
|
|
358
|
+
internal::QuickSplit(cvals, cirow, p);
|
|
355
359
|
// Insert the largest p elements in the matrix
|
|
356
360
|
Index cpt = 0;
|
|
357
|
-
for (Index i = colPtr[j]+1; i < colPtr[j+1]; i++)
|
|
358
|
-
{
|
|
361
|
+
for (Index i = colPtr[j] + 1; i < colPtr[j + 1]; i++) {
|
|
359
362
|
vals[i] = col_vals(cpt);
|
|
360
363
|
rowIdx[i] = col_irow(cpt);
|
|
361
364
|
// restore col_pattern:
|
|
@@ -363,38 +366,37 @@ void IncompleteCholesky<Scalar,_UpLo, OrderingType>::factorize(const _MatrixType
|
|
|
363
366
|
cpt++;
|
|
364
367
|
}
|
|
365
368
|
// Get the first smallest row index and put it after the diagonal element
|
|
366
|
-
Index jk = colPtr(j)+1;
|
|
367
|
-
updateList(colPtr,rowIdx,vals,j,jk,firstElt,listCol);
|
|
369
|
+
Index jk = colPtr(j) + 1;
|
|
370
|
+
updateList(colPtr, rowIdx, vals, j, jk, firstElt, listCol);
|
|
368
371
|
}
|
|
369
372
|
|
|
370
|
-
if(j==n)
|
|
371
|
-
{
|
|
373
|
+
if (j == n) {
|
|
372
374
|
m_factorizationIsOk = true;
|
|
373
375
|
m_info = Success;
|
|
374
376
|
}
|
|
375
|
-
} while(m_info!=Success);
|
|
377
|
+
} while (m_info != Success);
|
|
376
378
|
}
|
|
377
379
|
|
|
378
|
-
template<typename Scalar, int
|
|
379
|
-
inline void IncompleteCholesky<Scalar,
|
|
380
|
-
|
|
381
|
-
|
|
382
|
-
|
|
383
|
-
|
|
384
|
-
Index
|
|
385
|
-
|
|
380
|
+
template <typename Scalar, int UpLo_, typename OrderingType>
|
|
381
|
+
inline void IncompleteCholesky<Scalar, UpLo_, OrderingType>::updateList(Ref<const VectorIx> colPtr,
|
|
382
|
+
Ref<VectorIx> rowIdx, Ref<VectorSx> vals,
|
|
383
|
+
const Index& col, const Index& jk,
|
|
384
|
+
VectorIx& firstElt, VectorList& listCol) {
|
|
385
|
+
if (jk < colPtr(col + 1)) {
|
|
386
|
+
Index p = colPtr(col + 1) - jk;
|
|
387
|
+
Index minpos;
|
|
388
|
+
rowIdx.segment(jk, p).minCoeff(&minpos);
|
|
386
389
|
minpos += jk;
|
|
387
|
-
if (rowIdx(minpos) != rowIdx(jk))
|
|
388
|
-
|
|
389
|
-
|
|
390
|
-
std::swap(
|
|
391
|
-
std::swap(vals(jk),vals(minpos));
|
|
390
|
+
if (rowIdx(minpos) != rowIdx(jk)) {
|
|
391
|
+
// Swap
|
|
392
|
+
std::swap(rowIdx(jk), rowIdx(minpos));
|
|
393
|
+
std::swap(vals(jk), vals(minpos));
|
|
392
394
|
}
|
|
393
|
-
firstElt(col) = internal::convert_index<StorageIndex,Index>(jk);
|
|
394
|
-
listCol[rowIdx(jk)].push_back(internal::convert_index<StorageIndex,Index>(col));
|
|
395
|
+
firstElt(col) = internal::convert_index<StorageIndex, Index>(jk);
|
|
396
|
+
listCol[rowIdx(jk)].push_back(internal::convert_index<StorageIndex, Index>(col));
|
|
395
397
|
}
|
|
396
398
|
}
|
|
397
399
|
|
|
398
|
-
}
|
|
400
|
+
} // end namespace Eigen
|
|
399
401
|
|
|
400
402
|
#endif
|