@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
|
@@ -11,6 +11,9 @@
|
|
|
11
11
|
#ifndef EIGEN_MATRIXBASE_H
|
|
12
12
|
#define EIGEN_MATRIXBASE_H
|
|
13
13
|
|
|
14
|
+
// IWYU pragma: private
|
|
15
|
+
#include "./InternalHeaderCheck.h"
|
|
16
|
+
|
|
14
17
|
namespace Eigen {
|
|
15
18
|
|
|
16
19
|
/** \class MatrixBase
|
|
@@ -45,486 +48,498 @@ namespace Eigen {
|
|
|
45
48
|
*
|
|
46
49
|
* \sa \blank \ref TopicClassHierarchy
|
|
47
50
|
*/
|
|
48
|
-
template<typename Derived>
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
public:
|
|
51
|
+
template <typename Derived>
|
|
52
|
+
class MatrixBase : public DenseBase<Derived> {
|
|
53
|
+
public:
|
|
52
54
|
#ifndef EIGEN_PARSED_BY_DOXYGEN
|
|
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
|
-
|
|
55
|
+
typedef MatrixBase StorageBaseType;
|
|
56
|
+
typedef typename internal::traits<Derived>::StorageKind StorageKind;
|
|
57
|
+
typedef typename internal::traits<Derived>::StorageIndex StorageIndex;
|
|
58
|
+
typedef typename internal::traits<Derived>::Scalar Scalar;
|
|
59
|
+
typedef typename internal::packet_traits<Scalar>::type PacketScalar;
|
|
60
|
+
typedef typename NumTraits<Scalar>::Real RealScalar;
|
|
61
|
+
|
|
62
|
+
typedef DenseBase<Derived> Base;
|
|
63
|
+
using Base::ColsAtCompileTime;
|
|
64
|
+
using Base::Flags;
|
|
65
|
+
using Base::IsVectorAtCompileTime;
|
|
66
|
+
using Base::MaxColsAtCompileTime;
|
|
67
|
+
using Base::MaxRowsAtCompileTime;
|
|
68
|
+
using Base::MaxSizeAtCompileTime;
|
|
69
|
+
using Base::RowsAtCompileTime;
|
|
70
|
+
using Base::SizeAtCompileTime;
|
|
71
|
+
|
|
72
|
+
using Base::coeff;
|
|
73
|
+
using Base::coeffRef;
|
|
74
|
+
using Base::cols;
|
|
75
|
+
using Base::const_cast_derived;
|
|
76
|
+
using Base::derived;
|
|
77
|
+
using Base::eval;
|
|
78
|
+
using Base::lazyAssign;
|
|
79
|
+
using Base::rows;
|
|
80
|
+
using Base::size;
|
|
81
|
+
using Base::operator-;
|
|
82
|
+
using Base::operator+=;
|
|
83
|
+
using Base::operator-=;
|
|
84
|
+
using Base::operator*=;
|
|
85
|
+
using Base::operator/=;
|
|
86
|
+
|
|
87
|
+
typedef typename Base::CoeffReturnType CoeffReturnType;
|
|
88
|
+
typedef typename Base::ConstTransposeReturnType ConstTransposeReturnType;
|
|
89
|
+
typedef typename Base::RowXpr RowXpr;
|
|
90
|
+
typedef typename Base::ColXpr ColXpr;
|
|
91
|
+
#endif // not EIGEN_PARSED_BY_DOXYGEN
|
|
91
92
|
|
|
92
93
|
#ifndef EIGEN_PARSED_BY_DOXYGEN
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
94
|
+
/** type of the equivalent square matrix */
|
|
95
|
+
typedef Matrix<Scalar, internal::max_size_prefer_dynamic(RowsAtCompileTime, ColsAtCompileTime),
|
|
96
|
+
internal::max_size_prefer_dynamic(RowsAtCompileTime, ColsAtCompileTime)>
|
|
97
|
+
SquareMatrixType;
|
|
98
|
+
#endif // not EIGEN_PARSED_BY_DOXYGEN
|
|
97
99
|
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
inline Index diagonalSize() const { return (numext::mini)(rows(),cols()); }
|
|
100
|
+
/** \returns the size of the main diagonal, which is min(rows(),cols()).
|
|
101
|
+
* \sa rows(), cols(), SizeAtCompileTime. */
|
|
102
|
+
EIGEN_DEVICE_FUNC inline Index diagonalSize() const { return (numext::mini)(rows(), cols()); }
|
|
102
103
|
|
|
103
|
-
|
|
104
|
+
typedef typename Base::PlainObject PlainObject;
|
|
104
105
|
|
|
105
106
|
#ifndef EIGEN_PARSED_BY_DOXYGEN
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
107
|
+
/** \internal Represents a matrix with all coefficients equal to one another*/
|
|
108
|
+
typedef CwiseNullaryOp<internal::scalar_constant_op<Scalar>, PlainObject> ConstantReturnType;
|
|
109
|
+
/** \internal the return type of MatrixBase::adjoint() */
|
|
110
|
+
typedef std::conditional_t<NumTraits<Scalar>::IsComplex,
|
|
111
|
+
CwiseUnaryOp<internal::scalar_conjugate_op<Scalar>, ConstTransposeReturnType>,
|
|
112
|
+
ConstTransposeReturnType>
|
|
113
|
+
AdjointReturnType;
|
|
114
|
+
/** \internal Return type of eigenvalues() */
|
|
115
|
+
typedef Matrix<internal::make_complex_t<Scalar>, internal::traits<Derived>::ColsAtCompileTime, 1, ColMajor>
|
|
116
|
+
EigenvaluesReturnType;
|
|
117
|
+
/** \internal the return type of identity */
|
|
118
|
+
typedef CwiseNullaryOp<internal::scalar_identity_op<Scalar>, PlainObject> IdentityReturnType;
|
|
119
|
+
/** \internal the return type of unit vectors */
|
|
120
|
+
typedef Block<const CwiseNullaryOp<internal::scalar_identity_op<Scalar>, SquareMatrixType>,
|
|
121
|
+
internal::traits<Derived>::RowsAtCompileTime, internal::traits<Derived>::ColsAtCompileTime>
|
|
122
|
+
BasisReturnType;
|
|
123
|
+
#endif // not EIGEN_PARSED_BY_DOXYGEN
|
|
122
124
|
|
|
123
125
|
#define EIGEN_CURRENT_STORAGE_BASE_CLASS Eigen::MatrixBase
|
|
124
|
-
#define EIGEN_DOC_UNARY_ADDONS(X,Y)
|
|
125
|
-
#
|
|
126
|
-
#
|
|
127
|
-
#
|
|
128
|
-
#
|
|
129
|
-
#
|
|
130
|
-
#
|
|
131
|
-
# endif
|
|
126
|
+
#define EIGEN_DOC_UNARY_ADDONS(X, Y)
|
|
127
|
+
#include "../plugins/CommonCwiseBinaryOps.inc"
|
|
128
|
+
#include "../plugins/MatrixCwiseUnaryOps.inc"
|
|
129
|
+
#include "../plugins/MatrixCwiseBinaryOps.inc"
|
|
130
|
+
#ifdef EIGEN_MATRIXBASE_PLUGIN
|
|
131
|
+
#include EIGEN_MATRIXBASE_PLUGIN
|
|
132
|
+
#endif
|
|
132
133
|
#undef EIGEN_CURRENT_STORAGE_BASE_CLASS
|
|
133
134
|
#undef EIGEN_DOC_UNARY_ADDONS
|
|
134
135
|
|
|
135
|
-
|
|
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
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
|
|
333
|
-
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
ResultType& inverse,
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
|
|
351
|
-
|
|
352
|
-
|
|
353
|
-
|
|
354
|
-
|
|
355
|
-
|
|
356
|
-
|
|
357
|
-
|
|
358
|
-
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
|
|
362
|
-
|
|
363
|
-
|
|
364
|
-
|
|
365
|
-
|
|
366
|
-
|
|
367
|
-
|
|
368
|
-
|
|
369
|
-
|
|
370
|
-
|
|
371
|
-
|
|
372
|
-
|
|
373
|
-
|
|
374
|
-
|
|
375
|
-
|
|
376
|
-
|
|
377
|
-
|
|
378
|
-
|
|
379
|
-
|
|
380
|
-
|
|
381
|
-
|
|
382
|
-
|
|
383
|
-
|
|
384
|
-
|
|
385
|
-
|
|
386
|
-
|
|
387
|
-
|
|
388
|
-
|
|
389
|
-
|
|
390
|
-
|
|
391
|
-
|
|
392
|
-
|
|
393
|
-
|
|
394
|
-
|
|
395
|
-
|
|
396
|
-
|
|
397
|
-
|
|
398
|
-
|
|
399
|
-
|
|
400
|
-
|
|
401
|
-
|
|
402
|
-
|
|
403
|
-
|
|
404
|
-
|
|
405
|
-
|
|
406
|
-
|
|
407
|
-
|
|
408
|
-
|
|
409
|
-
|
|
410
|
-
|
|
411
|
-
|
|
412
|
-
|
|
413
|
-
|
|
414
|
-
|
|
415
|
-
|
|
416
|
-
|
|
417
|
-
|
|
418
|
-
|
|
419
|
-
|
|
420
|
-
|
|
421
|
-
|
|
422
|
-
|
|
423
|
-
|
|
424
|
-
|
|
425
|
-
|
|
426
|
-
|
|
427
|
-
|
|
428
|
-
|
|
429
|
-
|
|
430
|
-
|
|
431
|
-
|
|
432
|
-
|
|
433
|
-
|
|
434
|
-
|
|
435
|
-
|
|
436
|
-
|
|
437
|
-
|
|
438
|
-
|
|
439
|
-
|
|
440
|
-
|
|
441
|
-
|
|
442
|
-
|
|
443
|
-
|
|
444
|
-
|
|
445
|
-
|
|
446
|
-
|
|
447
|
-
|
|
448
|
-
|
|
449
|
-
|
|
450
|
-
|
|
451
|
-
|
|
452
|
-
|
|
453
|
-
|
|
454
|
-
|
|
455
|
-
|
|
456
|
-
|
|
457
|
-
|
|
458
|
-
|
|
459
|
-
|
|
460
|
-
|
|
461
|
-
|
|
462
|
-
|
|
463
|
-
|
|
464
|
-
|
|
465
|
-
|
|
466
|
-
|
|
467
|
-
|
|
468
|
-
|
|
469
|
-
|
|
470
|
-
|
|
471
|
-
|
|
472
|
-
|
|
473
|
-
|
|
474
|
-
|
|
475
|
-
|
|
476
|
-
|
|
477
|
-
|
|
478
|
-
|
|
479
|
-
|
|
480
|
-
|
|
136
|
+
/** Special case of the template operator=, in order to prevent the compiler
|
|
137
|
+
* from generating a default operator= (issue hit with g++ 4.1)
|
|
138
|
+
*/
|
|
139
|
+
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Derived& operator=(const MatrixBase& other);
|
|
140
|
+
|
|
141
|
+
// We cannot inherit here via Base::operator= since it is causing
|
|
142
|
+
// trouble with MSVC.
|
|
143
|
+
|
|
144
|
+
template <typename OtherDerived>
|
|
145
|
+
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Derived& operator=(const DenseBase<OtherDerived>& other);
|
|
146
|
+
|
|
147
|
+
template <typename OtherDerived>
|
|
148
|
+
EIGEN_DEVICE_FUNC Derived& operator=(const EigenBase<OtherDerived>& other);
|
|
149
|
+
|
|
150
|
+
template <typename OtherDerived>
|
|
151
|
+
EIGEN_DEVICE_FUNC Derived& operator=(const ReturnByValue<OtherDerived>& other);
|
|
152
|
+
|
|
153
|
+
template <typename OtherDerived>
|
|
154
|
+
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Derived& operator+=(const MatrixBase<OtherDerived>& other);
|
|
155
|
+
template <typename OtherDerived>
|
|
156
|
+
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Derived& operator-=(const MatrixBase<OtherDerived>& other);
|
|
157
|
+
|
|
158
|
+
template <typename OtherDerived>
|
|
159
|
+
EIGEN_DEVICE_FUNC const Product<Derived, OtherDerived> operator*(const MatrixBase<OtherDerived>& other) const;
|
|
160
|
+
|
|
161
|
+
template <typename OtherDerived>
|
|
162
|
+
EIGEN_DEVICE_FUNC const Product<Derived, OtherDerived, LazyProduct> lazyProduct(
|
|
163
|
+
const MatrixBase<OtherDerived>& other) const;
|
|
164
|
+
|
|
165
|
+
template <typename OtherDerived>
|
|
166
|
+
Derived& operator*=(const EigenBase<OtherDerived>& other);
|
|
167
|
+
|
|
168
|
+
template <typename OtherDerived>
|
|
169
|
+
void applyOnTheLeft(const EigenBase<OtherDerived>& other);
|
|
170
|
+
|
|
171
|
+
template <typename OtherDerived>
|
|
172
|
+
void applyOnTheRight(const EigenBase<OtherDerived>& other);
|
|
173
|
+
|
|
174
|
+
template <typename DiagonalDerived>
|
|
175
|
+
EIGEN_DEVICE_FUNC const Product<Derived, DiagonalDerived, LazyProduct> operator*(
|
|
176
|
+
const DiagonalBase<DiagonalDerived>& diagonal) const;
|
|
177
|
+
|
|
178
|
+
template <typename SkewDerived>
|
|
179
|
+
EIGEN_DEVICE_FUNC const Product<Derived, SkewDerived, LazyProduct> operator*(
|
|
180
|
+
const SkewSymmetricBase<SkewDerived>& skew) const;
|
|
181
|
+
|
|
182
|
+
template <typename OtherDerived>
|
|
183
|
+
EIGEN_DEVICE_FUNC typename ScalarBinaryOpTraits<typename internal::traits<Derived>::Scalar,
|
|
184
|
+
typename internal::traits<OtherDerived>::Scalar>::ReturnType
|
|
185
|
+
dot(const MatrixBase<OtherDerived>& other) const;
|
|
186
|
+
|
|
187
|
+
EIGEN_DEVICE_FUNC RealScalar squaredNorm() const;
|
|
188
|
+
EIGEN_DEVICE_FUNC RealScalar norm() const;
|
|
189
|
+
RealScalar stableNorm() const;
|
|
190
|
+
RealScalar blueNorm() const;
|
|
191
|
+
RealScalar hypotNorm() const;
|
|
192
|
+
EIGEN_DEVICE_FUNC const PlainObject normalized() const;
|
|
193
|
+
EIGEN_DEVICE_FUNC const PlainObject stableNormalized() const;
|
|
194
|
+
EIGEN_DEVICE_FUNC void normalize();
|
|
195
|
+
EIGEN_DEVICE_FUNC void stableNormalize();
|
|
196
|
+
|
|
197
|
+
EIGEN_DEVICE_FUNC const AdjointReturnType adjoint() const;
|
|
198
|
+
EIGEN_DEVICE_FUNC void adjointInPlace();
|
|
199
|
+
|
|
200
|
+
typedef Diagonal<Derived> DiagonalReturnType;
|
|
201
|
+
EIGEN_DEVICE_FUNC DiagonalReturnType diagonal();
|
|
202
|
+
|
|
203
|
+
typedef Diagonal<const Derived> ConstDiagonalReturnType;
|
|
204
|
+
EIGEN_DEVICE_FUNC const ConstDiagonalReturnType diagonal() const;
|
|
205
|
+
|
|
206
|
+
template <int Index>
|
|
207
|
+
EIGEN_DEVICE_FUNC Diagonal<Derived, Index> diagonal();
|
|
208
|
+
|
|
209
|
+
template <int Index>
|
|
210
|
+
EIGEN_DEVICE_FUNC const Diagonal<const Derived, Index> diagonal() const;
|
|
211
|
+
|
|
212
|
+
EIGEN_DEVICE_FUNC Diagonal<Derived, DynamicIndex> diagonal(Index index);
|
|
213
|
+
EIGEN_DEVICE_FUNC const Diagonal<const Derived, DynamicIndex> diagonal(Index index) const;
|
|
214
|
+
|
|
215
|
+
template <unsigned int Mode>
|
|
216
|
+
struct TriangularViewReturnType {
|
|
217
|
+
typedef TriangularView<Derived, Mode> Type;
|
|
218
|
+
};
|
|
219
|
+
template <unsigned int Mode>
|
|
220
|
+
struct ConstTriangularViewReturnType {
|
|
221
|
+
typedef const TriangularView<const Derived, Mode> Type;
|
|
222
|
+
};
|
|
223
|
+
|
|
224
|
+
template <unsigned int Mode>
|
|
225
|
+
EIGEN_DEVICE_FUNC typename TriangularViewReturnType<Mode>::Type triangularView();
|
|
226
|
+
template <unsigned int Mode>
|
|
227
|
+
EIGEN_DEVICE_FUNC typename ConstTriangularViewReturnType<Mode>::Type triangularView() const;
|
|
228
|
+
|
|
229
|
+
template <unsigned int UpLo>
|
|
230
|
+
struct SelfAdjointViewReturnType {
|
|
231
|
+
typedef SelfAdjointView<Derived, UpLo> Type;
|
|
232
|
+
};
|
|
233
|
+
template <unsigned int UpLo>
|
|
234
|
+
struct ConstSelfAdjointViewReturnType {
|
|
235
|
+
typedef const SelfAdjointView<const Derived, UpLo> Type;
|
|
236
|
+
};
|
|
237
|
+
|
|
238
|
+
template <unsigned int UpLo>
|
|
239
|
+
EIGEN_DEVICE_FUNC typename SelfAdjointViewReturnType<UpLo>::Type selfadjointView();
|
|
240
|
+
template <unsigned int UpLo>
|
|
241
|
+
EIGEN_DEVICE_FUNC typename ConstSelfAdjointViewReturnType<UpLo>::Type selfadjointView() const;
|
|
242
|
+
|
|
243
|
+
const SparseView<Derived> sparseView(
|
|
244
|
+
const Scalar& m_reference = Scalar(0),
|
|
245
|
+
const typename NumTraits<Scalar>::Real& m_epsilon = NumTraits<Scalar>::dummy_precision()) const;
|
|
246
|
+
EIGEN_DEVICE_FUNC static const IdentityReturnType Identity();
|
|
247
|
+
EIGEN_DEVICE_FUNC static const IdentityReturnType Identity(Index rows, Index cols);
|
|
248
|
+
EIGEN_DEVICE_FUNC static const BasisReturnType Unit(Index size, Index i);
|
|
249
|
+
EIGEN_DEVICE_FUNC static const BasisReturnType Unit(Index i);
|
|
250
|
+
EIGEN_DEVICE_FUNC static const BasisReturnType UnitX();
|
|
251
|
+
EIGEN_DEVICE_FUNC static const BasisReturnType UnitY();
|
|
252
|
+
EIGEN_DEVICE_FUNC static const BasisReturnType UnitZ();
|
|
253
|
+
EIGEN_DEVICE_FUNC static const BasisReturnType UnitW();
|
|
254
|
+
|
|
255
|
+
EIGEN_DEVICE_FUNC const DiagonalWrapper<const Derived> asDiagonal() const;
|
|
256
|
+
const PermutationWrapper<const Derived> asPermutation() const;
|
|
257
|
+
EIGEN_DEVICE_FUNC const SkewSymmetricWrapper<const Derived> asSkewSymmetric() const;
|
|
258
|
+
|
|
259
|
+
EIGEN_DEVICE_FUNC Derived& setIdentity();
|
|
260
|
+
EIGEN_DEVICE_FUNC Derived& setIdentity(Index rows, Index cols);
|
|
261
|
+
EIGEN_DEVICE_FUNC Derived& setUnit(Index i);
|
|
262
|
+
EIGEN_DEVICE_FUNC Derived& setUnit(Index newSize, Index i);
|
|
263
|
+
|
|
264
|
+
bool isIdentity(const RealScalar& prec = NumTraits<Scalar>::dummy_precision()) const;
|
|
265
|
+
bool isDiagonal(const RealScalar& prec = NumTraits<Scalar>::dummy_precision()) const;
|
|
266
|
+
|
|
267
|
+
bool isUpperTriangular(const RealScalar& prec = NumTraits<Scalar>::dummy_precision()) const;
|
|
268
|
+
bool isLowerTriangular(const RealScalar& prec = NumTraits<Scalar>::dummy_precision()) const;
|
|
269
|
+
|
|
270
|
+
bool isSkewSymmetric(const RealScalar& prec = NumTraits<Scalar>::dummy_precision()) const;
|
|
271
|
+
|
|
272
|
+
template <typename OtherDerived>
|
|
273
|
+
bool isOrthogonal(const MatrixBase<OtherDerived>& other,
|
|
274
|
+
const RealScalar& prec = NumTraits<Scalar>::dummy_precision()) const;
|
|
275
|
+
bool isUnitary(const RealScalar& prec = NumTraits<Scalar>::dummy_precision()) const;
|
|
276
|
+
|
|
277
|
+
/** \returns true if each coefficients of \c *this and \a other are all exactly equal.
|
|
278
|
+
* \warning When using floating point scalar values you probably should rather use a
|
|
279
|
+
* fuzzy comparison such as isApprox()
|
|
280
|
+
* \sa isApprox(), operator!= */
|
|
281
|
+
template <typename OtherDerived>
|
|
282
|
+
EIGEN_DEVICE_FUNC inline bool operator==(const MatrixBase<OtherDerived>& other) const {
|
|
283
|
+
return (this->rows() == other.rows()) && (this->cols() == other.cols()) && cwiseEqual(other).all();
|
|
284
|
+
}
|
|
285
|
+
|
|
286
|
+
/** \returns true if at least one pair of coefficients of \c *this and \a other are not exactly equal to each other.
|
|
287
|
+
* \warning When using floating point scalar values you probably should rather use a
|
|
288
|
+
* fuzzy comparison such as isApprox()
|
|
289
|
+
* \sa isApprox(), operator== */
|
|
290
|
+
template <typename OtherDerived>
|
|
291
|
+
EIGEN_DEVICE_FUNC inline bool operator!=(const MatrixBase<OtherDerived>& other) const {
|
|
292
|
+
return !(*this == other);
|
|
293
|
+
}
|
|
294
|
+
|
|
295
|
+
NoAlias<Derived, Eigen::MatrixBase> EIGEN_DEVICE_FUNC noalias();
|
|
296
|
+
|
|
297
|
+
// TODO forceAlignedAccess is temporarily disabled
|
|
298
|
+
// Need to find a nicer workaround.
|
|
299
|
+
inline const Derived& forceAlignedAccess() const { return derived(); }
|
|
300
|
+
inline Derived& forceAlignedAccess() { return derived(); }
|
|
301
|
+
template <bool Enable>
|
|
302
|
+
inline const Derived& forceAlignedAccessIf() const {
|
|
303
|
+
return derived();
|
|
304
|
+
}
|
|
305
|
+
template <bool Enable>
|
|
306
|
+
inline Derived& forceAlignedAccessIf() {
|
|
307
|
+
return derived();
|
|
308
|
+
}
|
|
309
|
+
|
|
310
|
+
EIGEN_DEVICE_FUNC Scalar trace() const;
|
|
311
|
+
|
|
312
|
+
template <int p>
|
|
313
|
+
EIGEN_DEVICE_FUNC RealScalar lpNorm() const;
|
|
314
|
+
|
|
315
|
+
EIGEN_DEVICE_FUNC MatrixBase<Derived>& matrix() { return *this; }
|
|
316
|
+
EIGEN_DEVICE_FUNC const MatrixBase<Derived>& matrix() const { return *this; }
|
|
317
|
+
|
|
318
|
+
/** \returns an \link Eigen::ArrayBase Array \endlink expression of this matrix
|
|
319
|
+
* \sa ArrayBase::matrix() */
|
|
320
|
+
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE ArrayWrapper<Derived> array() { return ArrayWrapper<Derived>(derived()); }
|
|
321
|
+
/** \returns a const \link Eigen::ArrayBase Array \endlink expression of this matrix
|
|
322
|
+
* \sa ArrayBase::matrix() */
|
|
323
|
+
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const ArrayWrapper<const Derived> array() const {
|
|
324
|
+
return ArrayWrapper<const Derived>(derived());
|
|
325
|
+
}
|
|
326
|
+
|
|
327
|
+
/////////// LU module ///////////
|
|
328
|
+
|
|
329
|
+
template <typename PermutationIndex = DefaultPermutationIndex>
|
|
330
|
+
inline const FullPivLU<PlainObject, PermutationIndex> fullPivLu() const;
|
|
331
|
+
template <typename PermutationIndex = DefaultPermutationIndex>
|
|
332
|
+
inline const PartialPivLU<PlainObject, PermutationIndex> partialPivLu() const;
|
|
333
|
+
|
|
334
|
+
template <typename PermutationIndex = DefaultPermutationIndex>
|
|
335
|
+
inline const PartialPivLU<PlainObject, PermutationIndex> lu() const;
|
|
336
|
+
|
|
337
|
+
EIGEN_DEVICE_FUNC inline const Inverse<Derived> inverse() const;
|
|
338
|
+
|
|
339
|
+
template <typename ResultType>
|
|
340
|
+
inline void computeInverseAndDetWithCheck(
|
|
341
|
+
ResultType& inverse, typename ResultType::Scalar& determinant, bool& invertible,
|
|
342
|
+
const RealScalar& absDeterminantThreshold = NumTraits<Scalar>::dummy_precision()) const;
|
|
343
|
+
|
|
344
|
+
template <typename ResultType>
|
|
345
|
+
inline void computeInverseWithCheck(
|
|
346
|
+
ResultType& inverse, bool& invertible,
|
|
347
|
+
const RealScalar& absDeterminantThreshold = NumTraits<Scalar>::dummy_precision()) const;
|
|
348
|
+
|
|
349
|
+
EIGEN_DEVICE_FUNC Scalar determinant() const;
|
|
350
|
+
|
|
351
|
+
/////////// Cholesky module ///////////
|
|
352
|
+
|
|
353
|
+
inline const LLT<PlainObject> llt() const;
|
|
354
|
+
inline const LDLT<PlainObject> ldlt() const;
|
|
355
|
+
|
|
356
|
+
/////////// QR module ///////////
|
|
357
|
+
|
|
358
|
+
inline const HouseholderQR<PlainObject> householderQr() const;
|
|
359
|
+
template <typename PermutationIndex = DefaultPermutationIndex>
|
|
360
|
+
inline const ColPivHouseholderQR<PlainObject, PermutationIndex> colPivHouseholderQr() const;
|
|
361
|
+
template <typename PermutationIndex = DefaultPermutationIndex>
|
|
362
|
+
inline const FullPivHouseholderQR<PlainObject, PermutationIndex> fullPivHouseholderQr() const;
|
|
363
|
+
template <typename PermutationIndex = DefaultPermutationIndex>
|
|
364
|
+
inline const CompleteOrthogonalDecomposition<PlainObject, PermutationIndex> completeOrthogonalDecomposition() const;
|
|
365
|
+
|
|
366
|
+
/////////// Eigenvalues module ///////////
|
|
367
|
+
|
|
368
|
+
inline EigenvaluesReturnType eigenvalues() const;
|
|
369
|
+
inline RealScalar operatorNorm() const;
|
|
370
|
+
|
|
371
|
+
/////////// SVD module ///////////
|
|
372
|
+
|
|
373
|
+
template <int Options = 0>
|
|
374
|
+
inline JacobiSVD<PlainObject, Options> jacobiSvd() const;
|
|
375
|
+
template <int Options = 0>
|
|
376
|
+
EIGEN_DEPRECATED_WITH_REASON("Options should be specified using method's template parameter.")
|
|
377
|
+
inline JacobiSVD<PlainObject, Options> jacobiSvd(unsigned int computationOptions) const;
|
|
378
|
+
|
|
379
|
+
template <int Options = 0>
|
|
380
|
+
inline BDCSVD<PlainObject, Options> bdcSvd() const;
|
|
381
|
+
template <int Options = 0>
|
|
382
|
+
EIGEN_DEPRECATED_WITH_REASON("Options should be specified using method's template parameter.")
|
|
383
|
+
inline BDCSVD<PlainObject, Options> bdcSvd(unsigned int computationOptions) const;
|
|
384
|
+
|
|
385
|
+
/////////// Geometry module ///////////
|
|
386
|
+
|
|
387
|
+
template <typename OtherDerived>
|
|
388
|
+
EIGEN_DEVICE_FUNC inline typename internal::cross_impl<Derived, OtherDerived>::return_type cross(
|
|
389
|
+
const MatrixBase<OtherDerived>& other) const;
|
|
390
|
+
|
|
391
|
+
template <typename OtherDerived>
|
|
392
|
+
EIGEN_DEVICE_FUNC inline PlainObject cross3(const MatrixBase<OtherDerived>& other) const;
|
|
393
|
+
|
|
394
|
+
EIGEN_DEVICE_FUNC inline PlainObject unitOrthogonal(void) const;
|
|
395
|
+
|
|
396
|
+
EIGEN_DEPRECATED_WITH_REASON("Use .canonicalEulerAngles() instead.")
|
|
397
|
+
EIGEN_DEVICE_FUNC inline Matrix<Scalar, 3, 1> eulerAngles(Index a0, Index a1, Index a2) const;
|
|
398
|
+
|
|
399
|
+
EIGEN_DEVICE_FUNC inline Matrix<Scalar, 3, 1> canonicalEulerAngles(Index a0, Index a1, Index a2) const;
|
|
400
|
+
|
|
401
|
+
// put this as separate enum value to work around possible GCC 4.3 bug (?)
|
|
402
|
+
enum {
|
|
403
|
+
HomogeneousReturnTypeDirection =
|
|
404
|
+
ColsAtCompileTime == 1 && RowsAtCompileTime == 1
|
|
405
|
+
? ((internal::traits<Derived>::Flags & RowMajorBit) == RowMajorBit ? Horizontal : Vertical)
|
|
406
|
+
: ColsAtCompileTime == 1 ? Vertical
|
|
407
|
+
: Horizontal
|
|
408
|
+
};
|
|
409
|
+
typedef Homogeneous<Derived, HomogeneousReturnTypeDirection> HomogeneousReturnType;
|
|
410
|
+
EIGEN_DEVICE_FUNC inline HomogeneousReturnType homogeneous() const;
|
|
411
|
+
|
|
412
|
+
enum { SizeMinusOne = SizeAtCompileTime == Dynamic ? Dynamic : SizeAtCompileTime - 1 };
|
|
413
|
+
typedef Block<const Derived, internal::traits<Derived>::ColsAtCompileTime == 1 ? SizeMinusOne : 1,
|
|
414
|
+
internal::traits<Derived>::ColsAtCompileTime == 1 ? 1 : SizeMinusOne>
|
|
415
|
+
ConstStartMinusOne;
|
|
416
|
+
typedef EIGEN_EXPR_BINARYOP_SCALAR_RETURN_TYPE(ConstStartMinusOne, Scalar, quotient) HNormalizedReturnType;
|
|
417
|
+
EIGEN_DEVICE_FUNC inline const HNormalizedReturnType hnormalized() const;
|
|
418
|
+
|
|
419
|
+
////////// Householder module ///////////
|
|
420
|
+
|
|
421
|
+
EIGEN_DEVICE_FUNC void makeHouseholderInPlace(Scalar& tau, RealScalar& beta);
|
|
422
|
+
template <typename EssentialPart>
|
|
423
|
+
EIGEN_DEVICE_FUNC void makeHouseholder(EssentialPart& essential, Scalar& tau, RealScalar& beta) const;
|
|
424
|
+
template <typename EssentialPart>
|
|
425
|
+
EIGEN_DEVICE_FUNC void applyHouseholderOnTheLeft(const EssentialPart& essential, const Scalar& tau,
|
|
426
|
+
Scalar* workspace);
|
|
427
|
+
template <typename EssentialPart>
|
|
428
|
+
EIGEN_DEVICE_FUNC void applyHouseholderOnTheRight(const EssentialPart& essential, const Scalar& tau,
|
|
429
|
+
Scalar* workspace);
|
|
430
|
+
|
|
431
|
+
///////// Jacobi module /////////
|
|
432
|
+
|
|
433
|
+
template <typename OtherScalar>
|
|
434
|
+
EIGEN_DEVICE_FUNC void applyOnTheLeft(Index p, Index q, const JacobiRotation<OtherScalar>& j);
|
|
435
|
+
template <typename OtherScalar>
|
|
436
|
+
EIGEN_DEVICE_FUNC void applyOnTheRight(Index p, Index q, const JacobiRotation<OtherScalar>& j);
|
|
437
|
+
|
|
438
|
+
///////// SparseCore module /////////
|
|
439
|
+
|
|
440
|
+
template <typename OtherDerived>
|
|
441
|
+
EIGEN_STRONG_INLINE const typename SparseMatrixBase<OtherDerived>::template CwiseProductDenseReturnType<Derived>::Type
|
|
442
|
+
cwiseProduct(const SparseMatrixBase<OtherDerived>& other) const {
|
|
443
|
+
return other.cwiseProduct(derived());
|
|
444
|
+
}
|
|
445
|
+
|
|
446
|
+
///////// MatrixFunctions module /////////
|
|
447
|
+
|
|
448
|
+
typedef typename internal::stem_function<Scalar>::type StemFunction;
|
|
449
|
+
#define EIGEN_MATRIX_FUNCTION(ReturnType, Name, Description) \
|
|
450
|
+
/** \returns an expression of the matrix Description of \c *this. \brief This function requires the <a \
|
|
451
|
+
* href="unsupported/group__MatrixFunctions__Module.html"> unsupported MatrixFunctions module</a>. To compute the \
|
|
452
|
+
* coefficient-wise Description use ArrayBase::##Name . */ \
|
|
453
|
+
const ReturnType<Derived> Name() const;
|
|
454
|
+
#define EIGEN_MATRIX_FUNCTION_1(ReturnType, Name, Description, Argument) \
|
|
455
|
+
/** \returns an expression of the matrix Description of \c *this. \brief This function requires the <a \
|
|
456
|
+
* href="unsupported/group__MatrixFunctions__Module.html"> unsupported MatrixFunctions module</a>. To compute the \
|
|
457
|
+
* coefficient-wise Description use ArrayBase::##Name . */ \
|
|
458
|
+
const ReturnType<Derived> Name(Argument) const;
|
|
459
|
+
|
|
460
|
+
EIGEN_MATRIX_FUNCTION(MatrixExponentialReturnValue, exp, exponential)
|
|
461
|
+
/** \brief Helper function for the <a href="unsupported/group__MatrixFunctions__Module.html"> unsupported
|
|
462
|
+
* MatrixFunctions module</a>.*/
|
|
463
|
+
const MatrixFunctionReturnValue<Derived> matrixFunction(StemFunction f) const;
|
|
464
|
+
EIGEN_MATRIX_FUNCTION(MatrixFunctionReturnValue, cosh, hyperbolic cosine)
|
|
465
|
+
EIGEN_MATRIX_FUNCTION(MatrixFunctionReturnValue, sinh, hyperbolic sine)
|
|
466
|
+
EIGEN_MATRIX_FUNCTION(MatrixFunctionReturnValue, atanh, inverse hyperbolic cosine)
|
|
467
|
+
EIGEN_MATRIX_FUNCTION(MatrixFunctionReturnValue, acosh, inverse hyperbolic cosine)
|
|
468
|
+
EIGEN_MATRIX_FUNCTION(MatrixFunctionReturnValue, asinh, inverse hyperbolic sine)
|
|
469
|
+
EIGEN_MATRIX_FUNCTION(MatrixFunctionReturnValue, cos, cosine)
|
|
470
|
+
EIGEN_MATRIX_FUNCTION(MatrixFunctionReturnValue, sin, sine)
|
|
471
|
+
EIGEN_MATRIX_FUNCTION(MatrixSquareRootReturnValue, sqrt, square root)
|
|
472
|
+
EIGEN_MATRIX_FUNCTION(MatrixLogarithmReturnValue, log, logarithm)
|
|
473
|
+
EIGEN_MATRIX_FUNCTION_1(MatrixPowerReturnValue, pow, power to \c p, const RealScalar& p)
|
|
474
|
+
EIGEN_MATRIX_FUNCTION_1(MatrixComplexPowerReturnValue, pow, power to \c p, const internal::make_complex_t<Scalar>& p)
|
|
475
|
+
|
|
476
|
+
protected:
|
|
477
|
+
EIGEN_DEFAULT_COPY_CONSTRUCTOR(MatrixBase)
|
|
478
|
+
EIGEN_DEFAULT_EMPTY_CONSTRUCTOR_AND_DESTRUCTOR(MatrixBase)
|
|
479
|
+
|
|
480
|
+
private:
|
|
481
|
+
EIGEN_DEVICE_FUNC explicit MatrixBase(int);
|
|
482
|
+
EIGEN_DEVICE_FUNC MatrixBase(int, int);
|
|
483
|
+
template <typename OtherDerived>
|
|
484
|
+
EIGEN_DEVICE_FUNC explicit MatrixBase(const MatrixBase<OtherDerived>&);
|
|
485
|
+
|
|
486
|
+
protected:
|
|
487
|
+
// mixing arrays and matrices is not legal
|
|
488
|
+
template <typename OtherDerived>
|
|
489
|
+
Derived& operator+=(const ArrayBase<OtherDerived>&) {
|
|
490
|
+
EIGEN_STATIC_ASSERT(std::ptrdiff_t(sizeof(typename OtherDerived::Scalar)) == -1,
|
|
491
|
+
YOU_CANNOT_MIX_ARRAYS_AND_MATRICES);
|
|
492
|
+
return *this;
|
|
493
|
+
}
|
|
494
|
+
// mixing arrays and matrices is not legal
|
|
495
|
+
template <typename OtherDerived>
|
|
496
|
+
Derived& operator-=(const ArrayBase<OtherDerived>&) {
|
|
497
|
+
EIGEN_STATIC_ASSERT(std::ptrdiff_t(sizeof(typename OtherDerived::Scalar)) == -1,
|
|
498
|
+
YOU_CANNOT_MIX_ARRAYS_AND_MATRICES);
|
|
499
|
+
return *this;
|
|
500
|
+
}
|
|
481
501
|
};
|
|
482
502
|
|
|
483
|
-
|
|
484
503
|
/***************************************************************************
|
|
485
|
-
* Implementation of matrix base methods
|
|
486
|
-
***************************************************************************/
|
|
504
|
+
* Implementation of matrix base methods
|
|
505
|
+
***************************************************************************/
|
|
487
506
|
|
|
488
507
|
/** replaces \c *this by \c *this * \a other.
|
|
489
|
-
|
|
490
|
-
|
|
491
|
-
|
|
492
|
-
|
|
493
|
-
|
|
494
|
-
|
|
495
|
-
template<typename Derived>
|
|
496
|
-
template<typename OtherDerived>
|
|
497
|
-
inline Derived&
|
|
498
|
-
MatrixBase<Derived>::operator*=(const EigenBase<OtherDerived> &other)
|
|
499
|
-
{
|
|
508
|
+
*
|
|
509
|
+
* \returns a reference to \c *this
|
|
510
|
+
*
|
|
511
|
+
* Example: \include MatrixBase_applyOnTheRight.cpp
|
|
512
|
+
* Output: \verbinclude MatrixBase_applyOnTheRight.out
|
|
513
|
+
*/
|
|
514
|
+
template <typename Derived>
|
|
515
|
+
template <typename OtherDerived>
|
|
516
|
+
inline Derived& MatrixBase<Derived>::operator*=(const EigenBase<OtherDerived>& other) {
|
|
500
517
|
other.derived().applyThisOnTheRight(derived());
|
|
501
518
|
return derived();
|
|
502
519
|
}
|
|
503
520
|
|
|
504
521
|
/** replaces \c *this by \c *this * \a other. It is equivalent to MatrixBase::operator*=().
|
|
505
|
-
|
|
506
|
-
|
|
507
|
-
|
|
508
|
-
|
|
509
|
-
template<typename Derived>
|
|
510
|
-
template<typename OtherDerived>
|
|
511
|
-
inline void MatrixBase<Derived>::applyOnTheRight(const EigenBase<OtherDerived
|
|
512
|
-
{
|
|
522
|
+
*
|
|
523
|
+
* Example: \include MatrixBase_applyOnTheRight.cpp
|
|
524
|
+
* Output: \verbinclude MatrixBase_applyOnTheRight.out
|
|
525
|
+
*/
|
|
526
|
+
template <typename Derived>
|
|
527
|
+
template <typename OtherDerived>
|
|
528
|
+
inline void MatrixBase<Derived>::applyOnTheRight(const EigenBase<OtherDerived>& other) {
|
|
513
529
|
other.derived().applyThisOnTheRight(derived());
|
|
514
530
|
}
|
|
515
531
|
|
|
516
532
|
/** replaces \c *this by \a other * \c *this.
|
|
517
|
-
|
|
518
|
-
|
|
519
|
-
|
|
520
|
-
|
|
521
|
-
template<typename Derived>
|
|
522
|
-
template<typename OtherDerived>
|
|
523
|
-
inline void MatrixBase<Derived>::applyOnTheLeft(const EigenBase<OtherDerived
|
|
524
|
-
{
|
|
533
|
+
*
|
|
534
|
+
* Example: \include MatrixBase_applyOnTheLeft.cpp
|
|
535
|
+
* Output: \verbinclude MatrixBase_applyOnTheLeft.out
|
|
536
|
+
*/
|
|
537
|
+
template <typename Derived>
|
|
538
|
+
template <typename OtherDerived>
|
|
539
|
+
inline void MatrixBase<Derived>::applyOnTheLeft(const EigenBase<OtherDerived>& other) {
|
|
525
540
|
other.derived().applyThisOnTheLeft(derived());
|
|
526
541
|
}
|
|
527
542
|
|
|
528
|
-
}
|
|
543
|
+
} // end namespace Eigen
|
|
529
544
|
|
|
530
|
-
#endif
|
|
545
|
+
#endif // EIGEN_MATRIXBASE_H
|