@smake/eigen 1.1.0 → 1.1.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/eigen/Eigen/AccelerateSupport +52 -0
- package/eigen/Eigen/Cholesky +18 -20
- package/eigen/Eigen/CholmodSupport +28 -28
- package/eigen/Eigen/Core +187 -120
- package/eigen/Eigen/Eigenvalues +16 -13
- package/eigen/Eigen/Geometry +18 -18
- package/eigen/Eigen/Householder +9 -7
- package/eigen/Eigen/IterativeLinearSolvers +8 -4
- package/eigen/Eigen/Jacobi +14 -13
- package/eigen/Eigen/KLUSupport +23 -21
- package/eigen/Eigen/LU +15 -16
- package/eigen/Eigen/MetisSupport +12 -12
- package/eigen/Eigen/OrderingMethods +54 -51
- package/eigen/Eigen/PaStiXSupport +23 -21
- package/eigen/Eigen/PardisoSupport +17 -14
- package/eigen/Eigen/QR +18 -20
- package/eigen/Eigen/QtAlignedMalloc +5 -12
- package/eigen/Eigen/SPQRSupport +21 -14
- package/eigen/Eigen/SVD +23 -17
- package/eigen/Eigen/Sparse +1 -2
- package/eigen/Eigen/SparseCholesky +18 -15
- package/eigen/Eigen/SparseCore +18 -17
- package/eigen/Eigen/SparseLU +9 -9
- package/eigen/Eigen/SparseQR +16 -14
- package/eigen/Eigen/StdDeque +5 -2
- package/eigen/Eigen/StdList +5 -2
- package/eigen/Eigen/StdVector +5 -2
- package/eigen/Eigen/SuperLUSupport +30 -24
- package/eigen/Eigen/ThreadPool +80 -0
- package/eigen/Eigen/UmfPackSupport +19 -17
- package/eigen/Eigen/Version +14 -0
- package/eigen/Eigen/src/AccelerateSupport/AccelerateSupport.h +423 -0
- package/eigen/Eigen/src/AccelerateSupport/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/Cholesky/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/Cholesky/LDLT.h +366 -405
- package/eigen/Eigen/src/Cholesky/LLT.h +323 -367
- package/eigen/Eigen/src/Cholesky/LLT_LAPACKE.h +81 -56
- package/eigen/Eigen/src/CholmodSupport/CholmodSupport.h +585 -529
- package/eigen/Eigen/src/CholmodSupport/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/Core/ArithmeticSequence.h +143 -317
- package/eigen/Eigen/src/Core/Array.h +329 -370
- package/eigen/Eigen/src/Core/ArrayBase.h +190 -203
- package/eigen/Eigen/src/Core/ArrayWrapper.h +126 -170
- package/eigen/Eigen/src/Core/Assign.h +30 -40
- package/eigen/Eigen/src/Core/AssignEvaluator.h +651 -604
- package/eigen/Eigen/src/Core/Assign_MKL.h +125 -120
- package/eigen/Eigen/src/Core/BandMatrix.h +267 -282
- package/eigen/Eigen/src/Core/Block.h +371 -390
- package/eigen/Eigen/src/Core/CommaInitializer.h +85 -100
- package/eigen/Eigen/src/Core/ConditionEstimator.h +51 -53
- package/eigen/Eigen/src/Core/CoreEvaluators.h +1214 -937
- package/eigen/Eigen/src/Core/CoreIterators.h +72 -63
- package/eigen/Eigen/src/Core/CwiseBinaryOp.h +112 -129
- package/eigen/Eigen/src/Core/CwiseNullaryOp.h +676 -702
- package/eigen/Eigen/src/Core/CwiseTernaryOp.h +77 -103
- package/eigen/Eigen/src/Core/CwiseUnaryOp.h +55 -67
- package/eigen/Eigen/src/Core/CwiseUnaryView.h +127 -92
- package/eigen/Eigen/src/Core/DenseBase.h +630 -658
- package/eigen/Eigen/src/Core/DenseCoeffsBase.h +511 -628
- package/eigen/Eigen/src/Core/DenseStorage.h +511 -590
- package/eigen/Eigen/src/Core/DeviceWrapper.h +153 -0
- package/eigen/Eigen/src/Core/Diagonal.h +168 -207
- package/eigen/Eigen/src/Core/DiagonalMatrix.h +346 -317
- package/eigen/Eigen/src/Core/DiagonalProduct.h +12 -10
- package/eigen/Eigen/src/Core/Dot.h +167 -217
- package/eigen/Eigen/src/Core/EigenBase.h +74 -85
- package/eigen/Eigen/src/Core/Fill.h +138 -0
- package/eigen/Eigen/src/Core/FindCoeff.h +464 -0
- package/eigen/Eigen/src/Core/ForceAlignedAccess.h +90 -113
- package/eigen/Eigen/src/Core/Fuzzy.h +82 -105
- package/eigen/Eigen/src/Core/GeneralProduct.h +315 -261
- package/eigen/Eigen/src/Core/GenericPacketMath.h +1182 -520
- package/eigen/Eigen/src/Core/GlobalFunctions.h +193 -157
- package/eigen/Eigen/src/Core/IO.h +131 -156
- package/eigen/Eigen/src/Core/IndexedView.h +209 -125
- package/eigen/Eigen/src/Core/InnerProduct.h +260 -0
- package/eigen/Eigen/src/Core/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/Core/Inverse.h +50 -59
- package/eigen/Eigen/src/Core/Map.h +123 -141
- package/eigen/Eigen/src/Core/MapBase.h +255 -282
- package/eigen/Eigen/src/Core/MathFunctions.h +1247 -1201
- package/eigen/Eigen/src/Core/MathFunctionsImpl.h +162 -99
- package/eigen/Eigen/src/Core/Matrix.h +463 -494
- package/eigen/Eigen/src/Core/MatrixBase.h +468 -470
- package/eigen/Eigen/src/Core/NestByValue.h +58 -52
- package/eigen/Eigen/src/Core/NoAlias.h +79 -86
- package/eigen/Eigen/src/Core/NumTraits.h +206 -206
- package/eigen/Eigen/src/Core/PartialReduxEvaluator.h +163 -142
- package/eigen/Eigen/src/Core/PermutationMatrix.h +461 -511
- package/eigen/Eigen/src/Core/PlainObjectBase.h +858 -972
- package/eigen/Eigen/src/Core/Product.h +246 -130
- package/eigen/Eigen/src/Core/ProductEvaluators.h +779 -671
- package/eigen/Eigen/src/Core/Random.h +153 -164
- package/eigen/Eigen/src/Core/RandomImpl.h +262 -0
- package/eigen/Eigen/src/Core/RealView.h +250 -0
- package/eigen/Eigen/src/Core/Redux.h +334 -314
- package/eigen/Eigen/src/Core/Ref.h +259 -257
- package/eigen/Eigen/src/Core/Replicate.h +92 -104
- package/eigen/Eigen/src/Core/Reshaped.h +215 -271
- package/eigen/Eigen/src/Core/ReturnByValue.h +47 -55
- package/eigen/Eigen/src/Core/Reverse.h +133 -148
- package/eigen/Eigen/src/Core/Select.h +68 -140
- package/eigen/Eigen/src/Core/SelfAdjointView.h +254 -290
- package/eigen/Eigen/src/Core/SelfCwiseBinaryOp.h +23 -20
- package/eigen/Eigen/src/Core/SkewSymmetricMatrix3.h +382 -0
- package/eigen/Eigen/src/Core/Solve.h +88 -102
- package/eigen/Eigen/src/Core/SolveTriangular.h +126 -124
- package/eigen/Eigen/src/Core/SolverBase.h +132 -133
- package/eigen/Eigen/src/Core/StableNorm.h +113 -147
- package/eigen/Eigen/src/Core/StlIterators.h +404 -248
- package/eigen/Eigen/src/Core/Stride.h +90 -92
- package/eigen/Eigen/src/Core/Swap.h +70 -39
- package/eigen/Eigen/src/Core/Transpose.h +258 -295
- package/eigen/Eigen/src/Core/Transpositions.h +270 -333
- package/eigen/Eigen/src/Core/TriangularMatrix.h +642 -743
- package/eigen/Eigen/src/Core/VectorBlock.h +59 -72
- package/eigen/Eigen/src/Core/VectorwiseOp.h +653 -704
- package/eigen/Eigen/src/Core/Visitor.h +464 -308
- package/eigen/Eigen/src/Core/arch/AVX/Complex.h +380 -187
- package/eigen/Eigen/src/Core/arch/AVX/MathFunctions.h +65 -163
- package/eigen/Eigen/src/Core/arch/AVX/PacketMath.h +2145 -638
- package/eigen/Eigen/src/Core/arch/AVX/Reductions.h +353 -0
- package/eigen/Eigen/src/Core/arch/AVX/TypeCasting.h +253 -60
- package/eigen/Eigen/src/Core/arch/AVX512/Complex.h +278 -228
- package/eigen/Eigen/src/Core/arch/AVX512/GemmKernel.h +1245 -0
- package/eigen/Eigen/src/Core/arch/AVX512/MathFunctions.h +48 -269
- package/eigen/Eigen/src/Core/arch/AVX512/MathFunctionsFP16.h +75 -0
- package/eigen/Eigen/src/Core/arch/AVX512/PacketMath.h +1597 -754
- package/eigen/Eigen/src/Core/arch/AVX512/PacketMathFP16.h +1413 -0
- package/eigen/Eigen/src/Core/arch/AVX512/Reductions.h +297 -0
- package/eigen/Eigen/src/Core/arch/AVX512/TrsmKernel.h +1167 -0
- package/eigen/Eigen/src/Core/arch/AVX512/TrsmUnrolls.inc +1219 -0
- package/eigen/Eigen/src/Core/arch/AVX512/TypeCasting.h +229 -41
- package/eigen/Eigen/src/Core/arch/AVX512/TypeCastingFP16.h +130 -0
- package/eigen/Eigen/src/Core/arch/AltiVec/Complex.h +420 -184
- package/eigen/Eigen/src/Core/arch/AltiVec/MathFunctions.h +40 -49
- package/eigen/Eigen/src/Core/arch/AltiVec/MatrixProduct.h +2962 -2213
- package/eigen/Eigen/src/Core/arch/AltiVec/MatrixProductCommon.h +196 -212
- package/eigen/Eigen/src/Core/arch/AltiVec/MatrixProductMMA.h +713 -441
- package/eigen/Eigen/src/Core/arch/AltiVec/MatrixProductMMAbfloat16.h +742 -0
- package/eigen/Eigen/src/Core/arch/AltiVec/MatrixVectorProduct.inc +2818 -0
- package/eigen/Eigen/src/Core/arch/AltiVec/PacketMath.h +2380 -1362
- package/eigen/Eigen/src/Core/arch/AltiVec/TypeCasting.h +153 -0
- package/eigen/Eigen/src/Core/arch/Default/BFloat16.h +390 -224
- package/eigen/Eigen/src/Core/arch/Default/ConjHelper.h +78 -67
- package/eigen/Eigen/src/Core/arch/Default/GenericPacketMathFunctions.h +1784 -799
- package/eigen/Eigen/src/Core/arch/Default/GenericPacketMathFunctionsFwd.h +167 -50
- package/eigen/Eigen/src/Core/arch/Default/Half.h +528 -379
- package/eigen/Eigen/src/Core/arch/Default/Settings.h +10 -12
- package/eigen/Eigen/src/Core/arch/GPU/Complex.h +244 -0
- package/eigen/Eigen/src/Core/arch/GPU/MathFunctions.h +41 -40
- package/eigen/Eigen/src/Core/arch/GPU/PacketMath.h +550 -523
- package/eigen/Eigen/src/Core/arch/GPU/Tuple.h +268 -0
- package/eigen/Eigen/src/Core/arch/GPU/TypeCasting.h +27 -30
- package/eigen/Eigen/src/Core/arch/HIP/hcc/math_constants.h +8 -8
- package/eigen/Eigen/src/Core/arch/HVX/PacketMath.h +1088 -0
- package/eigen/Eigen/src/Core/arch/LSX/Complex.h +520 -0
- package/eigen/Eigen/src/Core/arch/LSX/GeneralBlockPanelKernel.h +23 -0
- package/eigen/Eigen/src/Core/arch/LSX/MathFunctions.h +43 -0
- package/eigen/Eigen/src/Core/arch/LSX/PacketMath.h +2866 -0
- package/eigen/Eigen/src/Core/arch/LSX/TypeCasting.h +526 -0
- package/eigen/Eigen/src/Core/arch/MSA/Complex.h +54 -82
- package/eigen/Eigen/src/Core/arch/MSA/MathFunctions.h +84 -92
- package/eigen/Eigen/src/Core/arch/MSA/PacketMath.h +51 -47
- package/eigen/Eigen/src/Core/arch/NEON/Complex.h +454 -306
- package/eigen/Eigen/src/Core/arch/NEON/GeneralBlockPanelKernel.h +175 -115
- package/eigen/Eigen/src/Core/arch/NEON/MathFunctions.h +23 -30
- package/eigen/Eigen/src/Core/arch/NEON/PacketMath.h +4366 -2857
- package/eigen/Eigen/src/Core/arch/NEON/TypeCasting.h +616 -393
- package/eigen/Eigen/src/Core/arch/NEON/UnaryFunctors.h +57 -0
- package/eigen/Eigen/src/Core/arch/SSE/Complex.h +350 -198
- package/eigen/Eigen/src/Core/arch/SSE/MathFunctions.h +38 -149
- package/eigen/Eigen/src/Core/arch/SSE/PacketMath.h +1791 -912
- package/eigen/Eigen/src/Core/arch/SSE/Reductions.h +324 -0
- package/eigen/Eigen/src/Core/arch/SSE/TypeCasting.h +128 -40
- package/eigen/Eigen/src/Core/arch/SVE/MathFunctions.h +10 -6
- package/eigen/Eigen/src/Core/arch/SVE/PacketMath.h +156 -234
- package/eigen/Eigen/src/Core/arch/SVE/TypeCasting.h +6 -3
- package/eigen/Eigen/src/Core/arch/SYCL/InteropHeaders.h +27 -32
- package/eigen/Eigen/src/Core/arch/SYCL/MathFunctions.h +119 -117
- package/eigen/Eigen/src/Core/arch/SYCL/PacketMath.h +325 -419
- package/eigen/Eigen/src/Core/arch/SYCL/TypeCasting.h +15 -17
- package/eigen/Eigen/src/Core/arch/ZVector/Complex.h +325 -181
- package/eigen/Eigen/src/Core/arch/ZVector/MathFunctions.h +94 -83
- package/eigen/Eigen/src/Core/arch/ZVector/PacketMath.h +811 -458
- package/eigen/Eigen/src/Core/functors/AssignmentFunctors.h +121 -124
- package/eigen/Eigen/src/Core/functors/BinaryFunctors.h +576 -370
- package/eigen/Eigen/src/Core/functors/NullaryFunctors.h +194 -109
- package/eigen/Eigen/src/Core/functors/StlFunctors.h +95 -112
- package/eigen/Eigen/src/Core/functors/TernaryFunctors.h +34 -7
- package/eigen/Eigen/src/Core/functors/UnaryFunctors.h +1038 -749
- package/eigen/Eigen/src/Core/products/GeneralBlockPanelKernel.h +1883 -1375
- package/eigen/Eigen/src/Core/products/GeneralMatrixMatrix.h +312 -370
- package/eigen/Eigen/src/Core/products/GeneralMatrixMatrixTriangular.h +189 -176
- package/eigen/Eigen/src/Core/products/GeneralMatrixMatrixTriangular_BLAS.h +84 -81
- package/eigen/Eigen/src/Core/products/GeneralMatrixMatrix_BLAS.h +154 -73
- package/eigen/Eigen/src/Core/products/GeneralMatrixVector.h +292 -337
- package/eigen/Eigen/src/Core/products/GeneralMatrixVector_BLAS.h +80 -77
- package/eigen/Eigen/src/Core/products/Parallelizer.h +207 -105
- package/eigen/Eigen/src/Core/products/SelfadjointMatrixMatrix.h +327 -388
- package/eigen/Eigen/src/Core/products/SelfadjointMatrixMatrix_BLAS.h +206 -224
- package/eigen/Eigen/src/Core/products/SelfadjointMatrixVector.h +138 -147
- package/eigen/Eigen/src/Core/products/SelfadjointMatrixVector_BLAS.h +58 -61
- package/eigen/Eigen/src/Core/products/SelfadjointProduct.h +71 -71
- package/eigen/Eigen/src/Core/products/SelfadjointRank2Update.h +48 -47
- package/eigen/Eigen/src/Core/products/TriangularMatrixMatrix.h +294 -369
- package/eigen/Eigen/src/Core/products/TriangularMatrixMatrix_BLAS.h +246 -238
- package/eigen/Eigen/src/Core/products/TriangularMatrixVector.h +244 -247
- package/eigen/Eigen/src/Core/products/TriangularMatrixVector_BLAS.h +212 -192
- package/eigen/Eigen/src/Core/products/TriangularSolverMatrix.h +328 -277
- package/eigen/Eigen/src/Core/products/TriangularSolverMatrix_BLAS.h +108 -109
- package/eigen/Eigen/src/Core/products/TriangularSolverVector.h +68 -94
- package/eigen/Eigen/src/Core/util/Assert.h +158 -0
- package/eigen/Eigen/src/Core/util/BlasUtil.h +342 -303
- package/eigen/Eigen/src/Core/util/ConfigureVectorization.h +348 -317
- package/eigen/Eigen/src/Core/util/Constants.h +297 -262
- package/eigen/Eigen/src/Core/util/DisableStupidWarnings.h +130 -90
- package/eigen/Eigen/src/Core/util/EmulateArray.h +270 -0
- package/eigen/Eigen/src/Core/util/ForwardDeclarations.h +449 -247
- package/eigen/Eigen/src/Core/util/GpuHipCudaDefines.inc +101 -0
- package/eigen/Eigen/src/Core/util/GpuHipCudaUndefines.inc +45 -0
- package/eigen/Eigen/src/Core/util/IndexedViewHelper.h +417 -116
- package/eigen/Eigen/src/Core/util/IntegralConstant.h +211 -204
- package/eigen/Eigen/src/Core/util/MKL_support.h +39 -37
- package/eigen/Eigen/src/Core/util/Macros.h +655 -773
- package/eigen/Eigen/src/Core/util/MaxSizeVector.h +139 -0
- package/eigen/Eigen/src/Core/util/Memory.h +970 -748
- package/eigen/Eigen/src/Core/util/Meta.h +581 -633
- package/eigen/Eigen/src/Core/util/MoreMeta.h +638 -0
- package/eigen/Eigen/src/Core/util/ReenableStupidWarnings.h +32 -19
- package/eigen/Eigen/src/Core/util/ReshapedHelper.h +17 -17
- package/eigen/Eigen/src/Core/util/Serializer.h +209 -0
- package/eigen/Eigen/src/Core/util/StaticAssert.h +50 -166
- package/eigen/Eigen/src/Core/util/SymbolicIndex.h +377 -225
- package/eigen/Eigen/src/Core/util/XprHelper.h +784 -547
- package/eigen/Eigen/src/Eigenvalues/ComplexEigenSolver.h +246 -277
- package/eigen/Eigen/src/Eigenvalues/ComplexSchur.h +299 -319
- package/eigen/Eigen/src/Eigenvalues/ComplexSchur_LAPACKE.h +52 -48
- package/eigen/Eigen/src/Eigenvalues/EigenSolver.h +413 -456
- package/eigen/Eigen/src/Eigenvalues/GeneralizedEigenSolver.h +309 -325
- package/eigen/Eigen/src/Eigenvalues/GeneralizedSelfAdjointEigenSolver.h +157 -171
- package/eigen/Eigen/src/Eigenvalues/HessenbergDecomposition.h +292 -310
- package/eigen/Eigen/src/Eigenvalues/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/Eigenvalues/MatrixBaseEigenvalues.h +89 -105
- package/eigen/Eigen/src/Eigenvalues/RealQZ.h +537 -607
- package/eigen/Eigen/src/Eigenvalues/RealSchur.h +342 -381
- package/eigen/Eigen/src/Eigenvalues/RealSchur_LAPACKE.h +41 -35
- package/eigen/Eigen/src/Eigenvalues/SelfAdjointEigenSolver.h +541 -595
- package/eigen/Eigen/src/Eigenvalues/SelfAdjointEigenSolver_LAPACKE.h +47 -44
- package/eigen/Eigen/src/Eigenvalues/Tridiagonalization.h +430 -462
- package/eigen/Eigen/src/Geometry/AlignedBox.h +226 -227
- package/eigen/Eigen/src/Geometry/AngleAxis.h +131 -133
- package/eigen/Eigen/src/Geometry/EulerAngles.h +163 -74
- package/eigen/Eigen/src/Geometry/Homogeneous.h +285 -333
- package/eigen/Eigen/src/Geometry/Hyperplane.h +151 -160
- package/eigen/Eigen/src/Geometry/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/Geometry/OrthoMethods.h +168 -146
- package/eigen/Eigen/src/Geometry/ParametrizedLine.h +127 -127
- package/eigen/Eigen/src/Geometry/Quaternion.h +566 -506
- package/eigen/Eigen/src/Geometry/Rotation2D.h +107 -105
- package/eigen/Eigen/src/Geometry/RotationBase.h +148 -145
- package/eigen/Eigen/src/Geometry/Scaling.h +113 -106
- package/eigen/Eigen/src/Geometry/Transform.h +858 -936
- package/eigen/Eigen/src/Geometry/Translation.h +94 -92
- package/eigen/Eigen/src/Geometry/Umeyama.h +79 -84
- package/eigen/Eigen/src/Geometry/arch/Geometry_SIMD.h +90 -104
- package/eigen/Eigen/src/Householder/BlockHouseholder.h +51 -46
- package/eigen/Eigen/src/Householder/Householder.h +102 -124
- package/eigen/Eigen/src/Householder/HouseholderSequence.h +412 -453
- package/eigen/Eigen/src/Householder/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/IterativeLinearSolvers/BasicPreconditioners.h +149 -162
- package/eigen/Eigen/src/IterativeLinearSolvers/BiCGSTAB.h +124 -119
- package/eigen/Eigen/src/IterativeLinearSolvers/ConjugateGradient.h +92 -104
- package/eigen/Eigen/src/IterativeLinearSolvers/IncompleteCholesky.h +251 -243
- package/eigen/Eigen/src/IterativeLinearSolvers/IncompleteLUT.h +224 -228
- package/eigen/Eigen/src/IterativeLinearSolvers/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/IterativeLinearSolvers/IterativeSolverBase.h +178 -227
- package/eigen/Eigen/src/IterativeLinearSolvers/LeastSquareConjugateGradient.h +79 -84
- package/eigen/Eigen/src/IterativeLinearSolvers/SolveWithGuess.h +54 -60
- package/eigen/Eigen/src/Jacobi/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/Jacobi/Jacobi.h +252 -308
- package/eigen/Eigen/src/KLUSupport/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/KLUSupport/KLUSupport.h +208 -227
- package/eigen/Eigen/src/LU/Determinant.h +50 -69
- package/eigen/Eigen/src/LU/FullPivLU.h +545 -596
- package/eigen/Eigen/src/LU/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/LU/InverseImpl.h +206 -285
- package/eigen/Eigen/src/LU/PartialPivLU.h +390 -428
- package/eigen/Eigen/src/LU/PartialPivLU_LAPACKE.h +54 -40
- package/eigen/Eigen/src/LU/arch/InverseSize4.h +72 -70
- package/eigen/Eigen/src/MetisSupport/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/MetisSupport/MetisSupport.h +81 -93
- package/eigen/Eigen/src/OrderingMethods/Amd.h +243 -265
- package/eigen/Eigen/src/OrderingMethods/Eigen_Colamd.h +831 -1004
- package/eigen/Eigen/src/OrderingMethods/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/OrderingMethods/Ordering.h +112 -119
- package/eigen/Eigen/src/PaStiXSupport/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/PaStiXSupport/PaStiXSupport.h +524 -570
- package/eigen/Eigen/src/PardisoSupport/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/PardisoSupport/PardisoSupport.h +385 -430
- package/eigen/Eigen/src/QR/ColPivHouseholderQR.h +479 -479
- package/eigen/Eigen/src/QR/ColPivHouseholderQR_LAPACKE.h +120 -56
- package/eigen/Eigen/src/QR/CompleteOrthogonalDecomposition.h +166 -153
- package/eigen/Eigen/src/QR/FullPivHouseholderQR.h +495 -475
- package/eigen/Eigen/src/QR/HouseholderQR.h +394 -285
- package/eigen/Eigen/src/QR/HouseholderQR_LAPACKE.h +32 -23
- package/eigen/Eigen/src/QR/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/SPQRSupport/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/SPQRSupport/SuiteSparseQRSupport.h +244 -264
- package/eigen/Eigen/src/SVD/BDCSVD.h +817 -713
- package/eigen/Eigen/src/SVD/BDCSVD_LAPACKE.h +174 -0
- package/eigen/Eigen/src/SVD/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/SVD/JacobiSVD.h +577 -543
- package/eigen/Eigen/src/SVD/JacobiSVD_LAPACKE.h +85 -49
- package/eigen/Eigen/src/SVD/SVDBase.h +242 -182
- package/eigen/Eigen/src/SVD/UpperBidiagonalization.h +200 -235
- package/eigen/Eigen/src/SparseCholesky/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/SparseCholesky/SimplicialCholesky.h +765 -594
- package/eigen/Eigen/src/SparseCholesky/SimplicialCholesky_impl.h +308 -94
- package/eigen/Eigen/src/SparseCore/AmbiVector.h +202 -251
- package/eigen/Eigen/src/SparseCore/CompressedStorage.h +184 -252
- package/eigen/Eigen/src/SparseCore/ConservativeSparseSparseProduct.h +134 -178
- package/eigen/Eigen/src/SparseCore/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/SparseCore/SparseAssign.h +149 -140
- package/eigen/Eigen/src/SparseCore/SparseBlock.h +403 -440
- package/eigen/Eigen/src/SparseCore/SparseColEtree.h +100 -112
- package/eigen/Eigen/src/SparseCore/SparseCompressedBase.h +525 -303
- package/eigen/Eigen/src/SparseCore/SparseCwiseBinaryOp.h +555 -339
- package/eigen/Eigen/src/SparseCore/SparseCwiseUnaryOp.h +100 -108
- package/eigen/Eigen/src/SparseCore/SparseDenseProduct.h +169 -197
- package/eigen/Eigen/src/SparseCore/SparseDiagonalProduct.h +71 -71
- package/eigen/Eigen/src/SparseCore/SparseDot.h +49 -47
- package/eigen/Eigen/src/SparseCore/SparseFuzzy.h +13 -11
- package/eigen/Eigen/src/SparseCore/SparseMap.h +243 -253
- package/eigen/Eigen/src/SparseCore/SparseMatrix.h +1603 -1245
- package/eigen/Eigen/src/SparseCore/SparseMatrixBase.h +403 -350
- package/eigen/Eigen/src/SparseCore/SparsePermutation.h +186 -115
- package/eigen/Eigen/src/SparseCore/SparseProduct.h +94 -97
- package/eigen/Eigen/src/SparseCore/SparseRedux.h +22 -24
- package/eigen/Eigen/src/SparseCore/SparseRef.h +268 -295
- package/eigen/Eigen/src/SparseCore/SparseSelfAdjointView.h +370 -416
- package/eigen/Eigen/src/SparseCore/SparseSolverBase.h +78 -87
- package/eigen/Eigen/src/SparseCore/SparseSparseProductWithPruning.h +81 -95
- package/eigen/Eigen/src/SparseCore/SparseTranspose.h +62 -71
- package/eigen/Eigen/src/SparseCore/SparseTriangularView.h +132 -144
- package/eigen/Eigen/src/SparseCore/SparseUtil.h +138 -115
- package/eigen/Eigen/src/SparseCore/SparseVector.h +426 -372
- package/eigen/Eigen/src/SparseCore/SparseView.h +164 -193
- package/eigen/Eigen/src/SparseCore/TriangularSolver.h +129 -170
- package/eigen/Eigen/src/SparseLU/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/SparseLU/SparseLU.h +756 -710
- package/eigen/Eigen/src/SparseLU/SparseLUImpl.h +61 -48
- package/eigen/Eigen/src/SparseLU/SparseLU_Memory.h +102 -118
- package/eigen/Eigen/src/SparseLU/SparseLU_Structs.h +38 -35
- package/eigen/Eigen/src/SparseLU/SparseLU_SupernodalMatrix.h +245 -301
- package/eigen/Eigen/src/SparseLU/SparseLU_Utils.h +44 -49
- package/eigen/Eigen/src/SparseLU/SparseLU_column_bmod.h +104 -108
- package/eigen/Eigen/src/SparseLU/SparseLU_column_dfs.h +89 -100
- package/eigen/Eigen/src/SparseLU/SparseLU_copy_to_ucol.h +57 -58
- package/eigen/Eigen/src/SparseLU/SparseLU_heap_relax_snode.h +43 -55
- package/eigen/Eigen/src/SparseLU/SparseLU_kernel_bmod.h +74 -71
- package/eigen/Eigen/src/SparseLU/SparseLU_panel_bmod.h +124 -132
- package/eigen/Eigen/src/SparseLU/SparseLU_panel_dfs.h +136 -159
- package/eigen/Eigen/src/SparseLU/SparseLU_pivotL.h +51 -52
- package/eigen/Eigen/src/SparseLU/SparseLU_pruneL.h +67 -73
- package/eigen/Eigen/src/SparseLU/SparseLU_relax_snode.h +24 -26
- package/eigen/Eigen/src/SparseQR/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/SparseQR/SparseQR.h +450 -502
- package/eigen/Eigen/src/StlSupport/StdDeque.h +28 -93
- package/eigen/Eigen/src/StlSupport/StdList.h +28 -84
- package/eigen/Eigen/src/StlSupport/StdVector.h +28 -108
- package/eigen/Eigen/src/StlSupport/details.h +48 -50
- package/eigen/Eigen/src/SuperLUSupport/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/SuperLUSupport/SuperLUSupport.h +634 -730
- package/eigen/Eigen/src/ThreadPool/Barrier.h +70 -0
- package/eigen/Eigen/src/ThreadPool/CoreThreadPoolDevice.h +336 -0
- package/eigen/Eigen/src/ThreadPool/EventCount.h +241 -0
- package/eigen/Eigen/src/ThreadPool/ForkJoin.h +140 -0
- package/eigen/Eigen/src/ThreadPool/InternalHeaderCheck.h +4 -0
- package/eigen/Eigen/src/ThreadPool/NonBlockingThreadPool.h +587 -0
- package/eigen/Eigen/src/ThreadPool/RunQueue.h +230 -0
- package/eigen/Eigen/src/ThreadPool/ThreadCancel.h +21 -0
- package/eigen/Eigen/src/ThreadPool/ThreadEnvironment.h +43 -0
- package/eigen/Eigen/src/ThreadPool/ThreadLocal.h +289 -0
- package/eigen/Eigen/src/ThreadPool/ThreadPoolInterface.h +50 -0
- package/eigen/Eigen/src/ThreadPool/ThreadYield.h +16 -0
- package/eigen/Eigen/src/UmfPackSupport/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/UmfPackSupport/UmfPackSupport.h +428 -464
- package/eigen/Eigen/src/misc/Image.h +41 -43
- package/eigen/Eigen/src/misc/InternalHeaderCheck.h +3 -0
- package/eigen/Eigen/src/misc/Kernel.h +39 -41
- package/eigen/Eigen/src/misc/RealSvd2x2.h +19 -21
- package/eigen/Eigen/src/misc/blas.h +83 -426
- package/eigen/Eigen/src/misc/lapacke.h +9972 -16179
- package/eigen/Eigen/src/misc/lapacke_helpers.h +163 -0
- package/eigen/Eigen/src/misc/lapacke_mangling.h +4 -5
- package/eigen/Eigen/src/plugins/ArrayCwiseBinaryOps.inc +344 -0
- package/eigen/Eigen/src/plugins/ArrayCwiseUnaryOps.inc +544 -0
- package/eigen/Eigen/src/plugins/{BlockMethods.h → BlockMethods.inc} +434 -506
- package/eigen/Eigen/src/plugins/CommonCwiseBinaryOps.inc +116 -0
- package/eigen/Eigen/src/plugins/{CommonCwiseUnaryOps.h → CommonCwiseUnaryOps.inc} +58 -68
- package/eigen/Eigen/src/plugins/IndexedViewMethods.inc +192 -0
- package/eigen/Eigen/src/plugins/InternalHeaderCheck.inc +3 -0
- package/eigen/Eigen/src/plugins/MatrixCwiseBinaryOps.inc +331 -0
- package/eigen/Eigen/src/plugins/MatrixCwiseUnaryOps.inc +118 -0
- package/eigen/Eigen/src/plugins/ReshapedMethods.inc +133 -0
- package/package.json +1 -1
- package/eigen/COPYING.APACHE +0 -203
- package/eigen/COPYING.BSD +0 -26
- package/eigen/COPYING.GPL +0 -674
- package/eigen/COPYING.LGPL +0 -502
- package/eigen/COPYING.MINPACK +0 -51
- package/eigen/COPYING.MPL2 +0 -373
- package/eigen/COPYING.README +0 -18
- package/eigen/Eigen/src/Core/BooleanRedux.h +0 -162
- package/eigen/Eigen/src/Core/arch/CUDA/Complex.h +0 -258
- package/eigen/Eigen/src/Core/arch/Default/TypeCasting.h +0 -120
- package/eigen/Eigen/src/Core/arch/SYCL/SyclMemoryModel.h +0 -694
- package/eigen/Eigen/src/Core/util/NonMPL2.h +0 -3
- package/eigen/Eigen/src/SparseCore/MappedSparseMatrix.h +0 -67
- package/eigen/Eigen/src/SparseLU/SparseLU_gemm_kernel.h +0 -280
- package/eigen/Eigen/src/misc/lapack.h +0 -152
- package/eigen/Eigen/src/plugins/ArrayCwiseBinaryOps.h +0 -358
- package/eigen/Eigen/src/plugins/ArrayCwiseUnaryOps.h +0 -696
- package/eigen/Eigen/src/plugins/CommonCwiseBinaryOps.h +0 -115
- package/eigen/Eigen/src/plugins/IndexedViewMethods.h +0 -262
- package/eigen/Eigen/src/plugins/MatrixCwiseBinaryOps.h +0 -152
- package/eigen/Eigen/src/plugins/MatrixCwiseUnaryOps.h +0 -95
- package/eigen/Eigen/src/plugins/ReshapedMethods.h +0 -149
- package/eigen/README.md +0 -5
|
@@ -0,0 +1,331 @@
|
|
|
1
|
+
// This file is part of Eigen, a lightweight C++ template library
|
|
2
|
+
// for linear algebra.
|
|
3
|
+
//
|
|
4
|
+
// Copyright (C) 2008-2009 Gael Guennebaud <gael.guennebaud@inria.fr>
|
|
5
|
+
// Copyright (C) 2006-2008 Benoit Jacob <jacob.benoit.1@gmail.com>
|
|
6
|
+
//
|
|
7
|
+
// This Source Code Form is subject to the terms of the Mozilla
|
|
8
|
+
// Public License v. 2.0. If a copy of the MPL was not distributed
|
|
9
|
+
// with this file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
10
|
+
|
|
11
|
+
// This file is a base class plugin containing matrix specifics coefficient wise functions.
|
|
12
|
+
|
|
13
|
+
/** \returns an expression of the Schur product (coefficient wise product) of *this and \a other
|
|
14
|
+
*
|
|
15
|
+
* Example: \include MatrixBase_cwiseProduct.cpp
|
|
16
|
+
* Output: \verbinclude MatrixBase_cwiseProduct.out
|
|
17
|
+
*
|
|
18
|
+
* \sa class CwiseBinaryOp, cwiseAbs2
|
|
19
|
+
*/
|
|
20
|
+
template <typename OtherDerived>
|
|
21
|
+
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const EIGEN_CWISE_BINARY_RETURN_TYPE(Derived, OtherDerived, product)
|
|
22
|
+
cwiseProduct(const EIGEN_CURRENT_STORAGE_BASE_CLASS<OtherDerived>& other) const {
|
|
23
|
+
return EIGEN_CWISE_BINARY_RETURN_TYPE(Derived, OtherDerived, product)(derived(), other.derived());
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
template <typename OtherDerived>
|
|
27
|
+
using CwiseBinaryEqualReturnType =
|
|
28
|
+
CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_EQ>, const Derived, const OtherDerived>;
|
|
29
|
+
template <typename OtherDerived>
|
|
30
|
+
using CwiseBinaryNotEqualReturnType =
|
|
31
|
+
CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_NEQ>, const Derived, const OtherDerived>;
|
|
32
|
+
template <typename OtherDerived>
|
|
33
|
+
using CwiseBinaryLessReturnType =
|
|
34
|
+
CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_LT>, const Derived, const OtherDerived>;
|
|
35
|
+
template <typename OtherDerived>
|
|
36
|
+
using CwiseBinaryGreaterReturnType =
|
|
37
|
+
CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_GT>, const Derived, const OtherDerived>;
|
|
38
|
+
template <typename OtherDerived>
|
|
39
|
+
using CwiseBinaryLessOrEqualReturnType =
|
|
40
|
+
CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_LE>, const Derived, const OtherDerived>;
|
|
41
|
+
template <typename OtherDerived>
|
|
42
|
+
using CwiseBinaryGreaterOrEqualReturnType =
|
|
43
|
+
CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_GE>, const Derived, const OtherDerived>;
|
|
44
|
+
|
|
45
|
+
/** \returns an expression of the coefficient-wise == operator of *this and \a other
|
|
46
|
+
*
|
|
47
|
+
* \warning this performs an exact comparison, which is generally a bad idea with floating-point types.
|
|
48
|
+
* In order to check for equality between two vectors or matrices with floating-point coefficients, it is
|
|
49
|
+
* generally a far better idea to use a fuzzy comparison as provided by isApprox() and
|
|
50
|
+
* isMuchSmallerThan().
|
|
51
|
+
*
|
|
52
|
+
* Example: \include MatrixBase_cwiseEqual.cpp
|
|
53
|
+
* Output: \verbinclude MatrixBase_cwiseEqual.out
|
|
54
|
+
*
|
|
55
|
+
* \sa cwiseNotEqual(), isApprox(), isMuchSmallerThan()
|
|
56
|
+
*/
|
|
57
|
+
template <typename OtherDerived>
|
|
58
|
+
EIGEN_DEVICE_FUNC inline const CwiseBinaryEqualReturnType<OtherDerived> cwiseEqual(
|
|
59
|
+
const EIGEN_CURRENT_STORAGE_BASE_CLASS<OtherDerived>& other) const {
|
|
60
|
+
return CwiseBinaryEqualReturnType<OtherDerived>(derived(), other.derived());
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
/** \returns an expression of the coefficient-wise != operator of *this and \a other
|
|
64
|
+
*
|
|
65
|
+
* \warning this performs an exact comparison, which is generally a bad idea with floating-point types.
|
|
66
|
+
* In order to check for equality between two vectors or matrices with floating-point coefficients, it is
|
|
67
|
+
* generally a far better idea to use a fuzzy comparison as provided by isApprox() and
|
|
68
|
+
* isMuchSmallerThan().
|
|
69
|
+
*
|
|
70
|
+
* Example: \include MatrixBase_cwiseNotEqual.cpp
|
|
71
|
+
* Output: \verbinclude MatrixBase_cwiseNotEqual.out
|
|
72
|
+
*
|
|
73
|
+
* \sa cwiseEqual(), isApprox(), isMuchSmallerThan()
|
|
74
|
+
*/
|
|
75
|
+
template <typename OtherDerived>
|
|
76
|
+
EIGEN_DEVICE_FUNC inline const CwiseBinaryNotEqualReturnType<OtherDerived> cwiseNotEqual(
|
|
77
|
+
const EIGEN_CURRENT_STORAGE_BASE_CLASS<OtherDerived>& other) const {
|
|
78
|
+
return CwiseBinaryNotEqualReturnType<OtherDerived>(derived(), other.derived());
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
/** \returns an expression of the coefficient-wise < operator of *this and \a other */
|
|
82
|
+
template <typename OtherDerived>
|
|
83
|
+
EIGEN_DEVICE_FUNC inline const CwiseBinaryLessReturnType<OtherDerived> cwiseLess(
|
|
84
|
+
const EIGEN_CURRENT_STORAGE_BASE_CLASS<OtherDerived>& other) const {
|
|
85
|
+
return CwiseBinaryLessReturnType<OtherDerived>(derived(), other.derived());
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
/** \returns an expression of the coefficient-wise > operator of *this and \a other */
|
|
89
|
+
template <typename OtherDerived>
|
|
90
|
+
EIGEN_DEVICE_FUNC inline const CwiseBinaryGreaterReturnType<OtherDerived> cwiseGreater(
|
|
91
|
+
const EIGEN_CURRENT_STORAGE_BASE_CLASS<OtherDerived>& other) const {
|
|
92
|
+
return CwiseBinaryGreaterReturnType<OtherDerived>(derived(), other.derived());
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
/** \returns an expression of the coefficient-wise <= operator of *this and \a other */
|
|
96
|
+
template <typename OtherDerived>
|
|
97
|
+
EIGEN_DEVICE_FUNC inline const CwiseBinaryLessOrEqualReturnType<OtherDerived> cwiseLessOrEqual(
|
|
98
|
+
const EIGEN_CURRENT_STORAGE_BASE_CLASS<OtherDerived>& other) const {
|
|
99
|
+
return CwiseBinaryLessOrEqualReturnType<OtherDerived>(derived(), other.derived());
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
/** \returns an expression of the coefficient-wise >= operator of *this and \a other */
|
|
103
|
+
template <typename OtherDerived>
|
|
104
|
+
EIGEN_DEVICE_FUNC inline const CwiseBinaryGreaterOrEqualReturnType<OtherDerived> cwiseGreaterOrEqual(
|
|
105
|
+
const EIGEN_CURRENT_STORAGE_BASE_CLASS<OtherDerived>& other) const {
|
|
106
|
+
return CwiseBinaryGreaterOrEqualReturnType<OtherDerived>(derived(), other.derived());
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
/** \returns an expression of the coefficient-wise min of *this and \a other
|
|
110
|
+
*
|
|
111
|
+
* Example: \include MatrixBase_cwiseMin.cpp
|
|
112
|
+
* Output: \verbinclude MatrixBase_cwiseMin.out
|
|
113
|
+
*
|
|
114
|
+
* \sa class CwiseBinaryOp, max()
|
|
115
|
+
*/
|
|
116
|
+
template <int NaNPropagation = PropagateFast, typename OtherDerived>
|
|
117
|
+
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const
|
|
118
|
+
CwiseBinaryOp<internal::scalar_min_op<Scalar, Scalar, NaNPropagation>, const Derived, const OtherDerived>
|
|
119
|
+
cwiseMin(const EIGEN_CURRENT_STORAGE_BASE_CLASS<OtherDerived>& other) const {
|
|
120
|
+
return CwiseBinaryOp<internal::scalar_min_op<Scalar, Scalar, NaNPropagation>, const Derived, const OtherDerived>(
|
|
121
|
+
derived(), other.derived());
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
/** \returns an expression of the coefficient-wise min of *this and scalar \a other
|
|
125
|
+
*
|
|
126
|
+
* \sa class CwiseBinaryOp, min()
|
|
127
|
+
*/
|
|
128
|
+
template <int NaNPropagation = PropagateFast>
|
|
129
|
+
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const
|
|
130
|
+
CwiseBinaryOp<internal::scalar_min_op<Scalar, Scalar, NaNPropagation>, const Derived, const ConstantReturnType>
|
|
131
|
+
cwiseMin(const Scalar& other) const {
|
|
132
|
+
return cwiseMin<NaNPropagation>(Derived::Constant(rows(), cols(), other));
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
/** \returns an expression of the coefficient-wise max of *this and \a other
|
|
136
|
+
*
|
|
137
|
+
* Example: \include MatrixBase_cwiseMax.cpp
|
|
138
|
+
* Output: \verbinclude MatrixBase_cwiseMax.out
|
|
139
|
+
*
|
|
140
|
+
* \sa class CwiseBinaryOp, min()
|
|
141
|
+
*/
|
|
142
|
+
template <int NaNPropagation = PropagateFast, typename OtherDerived>
|
|
143
|
+
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const
|
|
144
|
+
CwiseBinaryOp<internal::scalar_max_op<Scalar, Scalar, NaNPropagation>, const Derived, const OtherDerived>
|
|
145
|
+
cwiseMax(const EIGEN_CURRENT_STORAGE_BASE_CLASS<OtherDerived>& other) const {
|
|
146
|
+
return CwiseBinaryOp<internal::scalar_max_op<Scalar, Scalar, NaNPropagation>, const Derived, const OtherDerived>(
|
|
147
|
+
derived(), other.derived());
|
|
148
|
+
}
|
|
149
|
+
|
|
150
|
+
/** \returns an expression of the coefficient-wise max of *this and scalar \a other
|
|
151
|
+
*
|
|
152
|
+
* \sa class CwiseBinaryOp, min()
|
|
153
|
+
*/
|
|
154
|
+
template <int NaNPropagation = PropagateFast>
|
|
155
|
+
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const
|
|
156
|
+
CwiseBinaryOp<internal::scalar_max_op<Scalar, Scalar, NaNPropagation>, const Derived, const ConstantReturnType>
|
|
157
|
+
cwiseMax(const Scalar& other) const {
|
|
158
|
+
return cwiseMax<NaNPropagation>(Derived::Constant(rows(), cols(), other));
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
/** \returns an expression of the coefficient-wise quotient of *this and \a other
|
|
162
|
+
*
|
|
163
|
+
* Example: \include MatrixBase_cwiseQuotient.cpp
|
|
164
|
+
* Output: \verbinclude MatrixBase_cwiseQuotient.out
|
|
165
|
+
*
|
|
166
|
+
* \sa class CwiseBinaryOp, cwiseProduct(), cwiseInverse()
|
|
167
|
+
*/
|
|
168
|
+
template <typename OtherDerived>
|
|
169
|
+
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const
|
|
170
|
+
CwiseBinaryOp<internal::scalar_quotient_op<Scalar>, const Derived, const OtherDerived>
|
|
171
|
+
cwiseQuotient(const EIGEN_CURRENT_STORAGE_BASE_CLASS<OtherDerived>& other) const {
|
|
172
|
+
return CwiseBinaryOp<internal::scalar_quotient_op<Scalar>, const Derived, const OtherDerived>(derived(),
|
|
173
|
+
other.derived());
|
|
174
|
+
}
|
|
175
|
+
|
|
176
|
+
using CwiseScalarEqualReturnType =
|
|
177
|
+
CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_EQ>, const Derived, const ConstantReturnType>;
|
|
178
|
+
using CwiseScalarNotEqualReturnType =
|
|
179
|
+
CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_NEQ>, const Derived, const ConstantReturnType>;
|
|
180
|
+
using CwiseScalarLessReturnType =
|
|
181
|
+
CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_LT>, const Derived, const ConstantReturnType>;
|
|
182
|
+
using CwiseScalarGreaterReturnType =
|
|
183
|
+
CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_GT>, const Derived, const ConstantReturnType>;
|
|
184
|
+
using CwiseScalarLessOrEqualReturnType =
|
|
185
|
+
CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_LE>, const Derived, const ConstantReturnType>;
|
|
186
|
+
using CwiseScalarGreaterOrEqualReturnType =
|
|
187
|
+
CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_GE>, const Derived, const ConstantReturnType>;
|
|
188
|
+
|
|
189
|
+
/** \returns an expression of the coefficient-wise == operator of \c *this and a scalar \a s
|
|
190
|
+
*
|
|
191
|
+
* \warning this performs an exact comparison, which is generally a bad idea with floating-point types.
|
|
192
|
+
* In order to check for equality between two vectors or matrices with floating-point coefficients, it is
|
|
193
|
+
* generally a far better idea to use a fuzzy comparison as provided by isApprox() and
|
|
194
|
+
* isMuchSmallerThan().
|
|
195
|
+
*
|
|
196
|
+
* \sa cwiseEqual(const MatrixBase<OtherDerived> &) const
|
|
197
|
+
*/
|
|
198
|
+
EIGEN_DEVICE_FUNC inline const CwiseScalarEqualReturnType cwiseEqual(const Scalar& s) const {
|
|
199
|
+
return CwiseScalarEqualReturnType(derived(), Derived::Constant(rows(), cols(), s));
|
|
200
|
+
}
|
|
201
|
+
|
|
202
|
+
/** \returns an expression of the coefficient-wise == operator of \c *this and a scalar \a s
|
|
203
|
+
*
|
|
204
|
+
* \warning this performs an exact comparison, which is generally a bad idea with floating-point types.
|
|
205
|
+
* In order to check for equality between two vectors or matrices with floating-point coefficients, it is
|
|
206
|
+
* generally a far better idea to use a fuzzy comparison as provided by isApprox() and
|
|
207
|
+
* isMuchSmallerThan().
|
|
208
|
+
*
|
|
209
|
+
* \sa cwiseEqual(const MatrixBase<OtherDerived> &) const
|
|
210
|
+
*/
|
|
211
|
+
EIGEN_DEVICE_FUNC inline const CwiseScalarNotEqualReturnType cwiseNotEqual(const Scalar& s) const {
|
|
212
|
+
return CwiseScalarNotEqualReturnType(derived(), Derived::Constant(rows(), cols(), s));
|
|
213
|
+
}
|
|
214
|
+
|
|
215
|
+
/** \returns an expression of the coefficient-wise < operator of \c *this and a scalar \a s */
|
|
216
|
+
EIGEN_DEVICE_FUNC inline const CwiseScalarLessReturnType cwiseLess(const Scalar& s) const {
|
|
217
|
+
return CwiseScalarLessReturnType(derived(), Derived::Constant(rows(), cols(), s));
|
|
218
|
+
}
|
|
219
|
+
|
|
220
|
+
/** \returns an expression of the coefficient-wise > operator of \c *this and a scalar \a s */
|
|
221
|
+
EIGEN_DEVICE_FUNC inline const CwiseScalarGreaterReturnType cwiseGreater(const Scalar& s) const {
|
|
222
|
+
return CwiseScalarGreaterReturnType(derived(), Derived::Constant(rows(), cols(), s));
|
|
223
|
+
}
|
|
224
|
+
|
|
225
|
+
/** \returns an expression of the coefficient-wise <= operator of \c *this and a scalar \a s */
|
|
226
|
+
EIGEN_DEVICE_FUNC inline const CwiseScalarLessOrEqualReturnType cwiseLessOrEqual(const Scalar& s) const {
|
|
227
|
+
return CwiseScalarLessOrEqualReturnType(derived(), Derived::Constant(rows(), cols(), s));
|
|
228
|
+
}
|
|
229
|
+
|
|
230
|
+
/** \returns an expression of the coefficient-wise >= operator of \c *this and a scalar \a s */
|
|
231
|
+
EIGEN_DEVICE_FUNC inline const CwiseScalarGreaterOrEqualReturnType cwiseGreaterOrEqual(const Scalar& s) const {
|
|
232
|
+
return CwiseScalarGreaterOrEqualReturnType(derived(), Derived::Constant(rows(), cols(), s));
|
|
233
|
+
}
|
|
234
|
+
|
|
235
|
+
template <typename OtherDerived>
|
|
236
|
+
using CwiseBinaryTypedEqualReturnType =
|
|
237
|
+
CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_EQ, true>, const Derived, const OtherDerived>;
|
|
238
|
+
template <typename OtherDerived>
|
|
239
|
+
using CwiseBinaryTypedNotEqualReturnType =
|
|
240
|
+
CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_NEQ, true>, const Derived, const OtherDerived>;
|
|
241
|
+
template <typename OtherDerived>
|
|
242
|
+
using CwiseBinaryTypedLessReturnType =
|
|
243
|
+
CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_LT, true>, const Derived, const OtherDerived>;
|
|
244
|
+
template <typename OtherDerived>
|
|
245
|
+
using CwiseBinaryTypedGreaterReturnType =
|
|
246
|
+
CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_GT, true>, const Derived, const OtherDerived>;
|
|
247
|
+
template <typename OtherDerived>
|
|
248
|
+
using CwiseBinaryTypedLessOrEqualReturnType =
|
|
249
|
+
CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_LE, true>, const Derived, const OtherDerived>;
|
|
250
|
+
template <typename OtherDerived>
|
|
251
|
+
using CwiseBinaryTypedGreaterOrEqualReturnType =
|
|
252
|
+
CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_GE, true>, const Derived, const OtherDerived>;
|
|
253
|
+
|
|
254
|
+
template <typename OtherDerived>
|
|
255
|
+
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const CwiseBinaryTypedEqualReturnType<OtherDerived> cwiseTypedEqual(
|
|
256
|
+
const EIGEN_CURRENT_STORAGE_BASE_CLASS<OtherDerived>& other) const {
|
|
257
|
+
return CwiseBinaryTypedEqualReturnType<OtherDerived>(derived(), other.derived());
|
|
258
|
+
}
|
|
259
|
+
|
|
260
|
+
template <typename OtherDerived>
|
|
261
|
+
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const CwiseBinaryTypedNotEqualReturnType<OtherDerived> cwiseTypedNotEqual(
|
|
262
|
+
const EIGEN_CURRENT_STORAGE_BASE_CLASS<OtherDerived>& other) const {
|
|
263
|
+
return CwiseBinaryTypedNotEqualReturnType<OtherDerived>(derived(), other.derived());
|
|
264
|
+
}
|
|
265
|
+
|
|
266
|
+
template <typename OtherDerived>
|
|
267
|
+
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const CwiseBinaryTypedLessReturnType<OtherDerived> cwiseTypedLess(
|
|
268
|
+
const EIGEN_CURRENT_STORAGE_BASE_CLASS<OtherDerived>& other) const {
|
|
269
|
+
return CwiseBinaryTypedLessReturnType<OtherDerived>(derived(), other.derived());
|
|
270
|
+
}
|
|
271
|
+
|
|
272
|
+
template <typename OtherDerived>
|
|
273
|
+
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const CwiseBinaryTypedGreaterReturnType<OtherDerived> cwiseTypedGreater(
|
|
274
|
+
const EIGEN_CURRENT_STORAGE_BASE_CLASS<OtherDerived>& other) const {
|
|
275
|
+
return CwiseBinaryTypedGreaterReturnType<OtherDerived>(derived(), other.derived());
|
|
276
|
+
}
|
|
277
|
+
|
|
278
|
+
template <typename OtherDerived>
|
|
279
|
+
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const CwiseBinaryTypedLessOrEqualReturnType<OtherDerived> cwiseTypedLessOrEqual(
|
|
280
|
+
const EIGEN_CURRENT_STORAGE_BASE_CLASS<OtherDerived>& other) const {
|
|
281
|
+
return CwiseBinaryTypedLessOrEqualReturnType<OtherDerived>(derived(), other.derived());
|
|
282
|
+
}
|
|
283
|
+
|
|
284
|
+
template <typename OtherDerived>
|
|
285
|
+
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const CwiseBinaryTypedGreaterOrEqualReturnType<OtherDerived>
|
|
286
|
+
cwiseTypedGreaterOrEqual(const EIGEN_CURRENT_STORAGE_BASE_CLASS<OtherDerived>& other) const {
|
|
287
|
+
return CwiseBinaryTypedGreaterOrEqualReturnType<OtherDerived>(derived(), other.derived());
|
|
288
|
+
}
|
|
289
|
+
|
|
290
|
+
using CwiseScalarTypedEqualReturnType = CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_EQ, true>,
|
|
291
|
+
const Derived, const ConstantReturnType>;
|
|
292
|
+
using CwiseScalarTypedNotEqualReturnType =
|
|
293
|
+
CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_NEQ, true>, const Derived,
|
|
294
|
+
const ConstantReturnType>;
|
|
295
|
+
using CwiseScalarTypedLessReturnType = CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_LT, true>,
|
|
296
|
+
const Derived, const ConstantReturnType>;
|
|
297
|
+
using CwiseScalarTypedGreaterReturnType = CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_GT, true>,
|
|
298
|
+
const Derived, const ConstantReturnType>;
|
|
299
|
+
using CwiseScalarTypedLessOrEqualReturnType =
|
|
300
|
+
CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_LE, true>, const Derived,
|
|
301
|
+
const ConstantReturnType>;
|
|
302
|
+
using CwiseScalarTypedGreaterOrEqualReturnType =
|
|
303
|
+
CwiseBinaryOp<internal::scalar_cmp_op<Scalar, Scalar, internal::cmp_GE, true>, const Derived,
|
|
304
|
+
const ConstantReturnType>;
|
|
305
|
+
|
|
306
|
+
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const CwiseScalarTypedEqualReturnType cwiseTypedEqual(const Scalar& s) const {
|
|
307
|
+
return CwiseScalarTypedEqualReturnType(derived(), ConstantReturnType(rows(), cols(), s));
|
|
308
|
+
}
|
|
309
|
+
|
|
310
|
+
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const CwiseScalarTypedNotEqualReturnType
|
|
311
|
+
cwiseTypedNotEqual(const Scalar& s) const {
|
|
312
|
+
return CwiseScalarTypedNotEqualReturnType(derived(), ConstantReturnType(rows(), cols(), s));
|
|
313
|
+
}
|
|
314
|
+
|
|
315
|
+
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const CwiseScalarTypedLessReturnType cwiseTypedLess(const Scalar& s) const {
|
|
316
|
+
return CwiseScalarTypedLessReturnType(derived(), ConstantReturnType(rows(), cols(), s));
|
|
317
|
+
}
|
|
318
|
+
|
|
319
|
+
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const CwiseScalarTypedGreaterReturnType cwiseTypedGreater(const Scalar& s) const {
|
|
320
|
+
return CwiseScalarTypedGreaterReturnType(derived(), ConstantReturnType(rows(), cols(), s));
|
|
321
|
+
}
|
|
322
|
+
|
|
323
|
+
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const CwiseScalarTypedLessOrEqualReturnType
|
|
324
|
+
cwiseTypedLessOrEqual(const Scalar& s) const {
|
|
325
|
+
return CwiseScalarTypedLessOrEqualReturnType(derived(), ConstantReturnType(rows(), cols(), s));
|
|
326
|
+
}
|
|
327
|
+
|
|
328
|
+
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const CwiseScalarTypedGreaterOrEqualReturnType
|
|
329
|
+
cwiseTypedGreaterOrEqual(const Scalar& s) const {
|
|
330
|
+
return CwiseScalarTypedGreaterOrEqualReturnType(derived(), ConstantReturnType(rows(), cols(), s));
|
|
331
|
+
}
|
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
// This file is part of Eigen, a lightweight C++ template library
|
|
2
|
+
// for linear algebra.
|
|
3
|
+
//
|
|
4
|
+
// Copyright (C) 2008-2009 Gael Guennebaud <gael.guennebaud@inria.fr>
|
|
5
|
+
// Copyright (C) 2006-2008 Benoit Jacob <jacob.benoit.1@gmail.com>
|
|
6
|
+
//
|
|
7
|
+
// This Source Code Form is subject to the terms of the Mozilla
|
|
8
|
+
// Public License v. 2.0. If a copy of the MPL was not distributed
|
|
9
|
+
// with this file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
10
|
+
|
|
11
|
+
// This file is included into the body of the base classes supporting matrix specific coefficient-wise functions.
|
|
12
|
+
// This include MatrixBase and SparseMatrixBase.
|
|
13
|
+
|
|
14
|
+
typedef CwiseUnaryOp<internal::scalar_abs_op<Scalar>, const Derived> CwiseAbsReturnType;
|
|
15
|
+
typedef CwiseUnaryOp<internal::scalar_abs2_op<Scalar>, const Derived> CwiseAbs2ReturnType;
|
|
16
|
+
typedef CwiseUnaryOp<internal::scalar_arg_op<Scalar>, const Derived> CwiseArgReturnType;
|
|
17
|
+
typedef CwiseUnaryOp<internal::scalar_carg_op<Scalar>, const Derived> CwiseCArgReturnType;
|
|
18
|
+
typedef CwiseUnaryOp<internal::scalar_sqrt_op<Scalar>, const Derived> CwiseSqrtReturnType;
|
|
19
|
+
typedef CwiseUnaryOp<internal::scalar_cbrt_op<Scalar>, const Derived> CwiseCbrtReturnType;
|
|
20
|
+
typedef CwiseUnaryOp<internal::scalar_square_op<Scalar>, const Derived> CwiseSquareReturnType;
|
|
21
|
+
typedef CwiseUnaryOp<internal::scalar_sign_op<Scalar>, const Derived> CwiseSignReturnType;
|
|
22
|
+
typedef CwiseUnaryOp<internal::scalar_inverse_op<Scalar>, const Derived> CwiseInverseReturnType;
|
|
23
|
+
|
|
24
|
+
/// \returns an expression of the coefficient-wise absolute value of \c *this
|
|
25
|
+
///
|
|
26
|
+
/// Example: \include MatrixBase_cwiseAbs.cpp
|
|
27
|
+
/// Output: \verbinclude MatrixBase_cwiseAbs.out
|
|
28
|
+
///
|
|
29
|
+
EIGEN_DOC_UNARY_ADDONS(cwiseAbs, absolute value)
|
|
30
|
+
///
|
|
31
|
+
/// \sa cwiseAbs2()
|
|
32
|
+
///
|
|
33
|
+
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const CwiseAbsReturnType cwiseAbs() const {
|
|
34
|
+
return CwiseAbsReturnType(derived());
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
/// \returns an expression of the coefficient-wise squared absolute value of \c *this
|
|
38
|
+
///
|
|
39
|
+
/// Example: \include MatrixBase_cwiseAbs2.cpp
|
|
40
|
+
/// Output: \verbinclude MatrixBase_cwiseAbs2.out
|
|
41
|
+
///
|
|
42
|
+
EIGEN_DOC_UNARY_ADDONS(cwiseAbs2, squared absolute value)
|
|
43
|
+
///
|
|
44
|
+
/// \sa cwiseAbs()
|
|
45
|
+
///
|
|
46
|
+
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const CwiseAbs2ReturnType cwiseAbs2() const {
|
|
47
|
+
return CwiseAbs2ReturnType(derived());
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
/// \returns an expression of the coefficient-wise square root of *this.
|
|
51
|
+
///
|
|
52
|
+
/// Example: \include MatrixBase_cwiseSqrt.cpp
|
|
53
|
+
/// Output: \verbinclude MatrixBase_cwiseSqrt.out
|
|
54
|
+
///
|
|
55
|
+
EIGEN_DOC_UNARY_ADDONS(cwiseSqrt, square - root)
|
|
56
|
+
///
|
|
57
|
+
/// \sa cwisePow(), cwiseSquare(), cwiseCbrt()
|
|
58
|
+
///
|
|
59
|
+
EIGEN_DEVICE_FUNC inline const CwiseSqrtReturnType cwiseSqrt() const { return CwiseSqrtReturnType(derived()); }
|
|
60
|
+
|
|
61
|
+
/// \returns an expression of the coefficient-wise cube root of *this.
|
|
62
|
+
///
|
|
63
|
+
EIGEN_DOC_UNARY_ADDONS(cwiseCbrt, cube - root)
|
|
64
|
+
///
|
|
65
|
+
/// \sa cwiseSqrt(), cwiseSquare(), cwisePow()
|
|
66
|
+
///
|
|
67
|
+
EIGEN_DEVICE_FUNC inline const CwiseCbrtReturnType cwiseCbrt() const { return CwiseCbrtReturnType(derived()); }
|
|
68
|
+
|
|
69
|
+
/// \returns an expression of the coefficient-wise square of *this.
|
|
70
|
+
///
|
|
71
|
+
EIGEN_DOC_UNARY_ADDONS(cwiseSquare, square)
|
|
72
|
+
///
|
|
73
|
+
/// \sa cwisePow(), cwiseSqrt(), cwiseCbrt()
|
|
74
|
+
///
|
|
75
|
+
EIGEN_DEVICE_FUNC inline const CwiseSquareReturnType cwiseSquare() const { return CwiseSquareReturnType(derived()); }
|
|
76
|
+
|
|
77
|
+
/// \returns an expression of the coefficient-wise signum of *this.
|
|
78
|
+
///
|
|
79
|
+
/// Example: \include MatrixBase_cwiseSign.cpp
|
|
80
|
+
/// Output: \verbinclude MatrixBase_cwiseSign.out
|
|
81
|
+
///
|
|
82
|
+
EIGEN_DOC_UNARY_ADDONS(cwiseSign, sign function)
|
|
83
|
+
///
|
|
84
|
+
EIGEN_DEVICE_FUNC inline const CwiseSignReturnType cwiseSign() const { return CwiseSignReturnType(derived()); }
|
|
85
|
+
|
|
86
|
+
/// \returns an expression of the coefficient-wise inverse of *this.
|
|
87
|
+
///
|
|
88
|
+
/// Example: \include MatrixBase_cwiseInverse.cpp
|
|
89
|
+
/// Output: \verbinclude MatrixBase_cwiseInverse.out
|
|
90
|
+
///
|
|
91
|
+
EIGEN_DOC_UNARY_ADDONS(cwiseInverse, inverse)
|
|
92
|
+
///
|
|
93
|
+
/// \sa cwiseProduct()
|
|
94
|
+
///
|
|
95
|
+
EIGEN_DEVICE_FUNC inline const CwiseInverseReturnType cwiseInverse() const { return CwiseInverseReturnType(derived()); }
|
|
96
|
+
|
|
97
|
+
/// \returns an expression of the coefficient-wise phase angle of \c *this
|
|
98
|
+
///
|
|
99
|
+
/// Example: \include MatrixBase_cwiseArg.cpp
|
|
100
|
+
/// Output: \verbinclude MatrixBase_cwiseArg.out
|
|
101
|
+
///
|
|
102
|
+
EIGEN_DOC_UNARY_ADDONS(cwiseArg, arg)
|
|
103
|
+
|
|
104
|
+
EIGEN_DEVICE_FUNC inline const CwiseArgReturnType cwiseArg() const { return CwiseArgReturnType(derived()); }
|
|
105
|
+
|
|
106
|
+
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const CwiseCArgReturnType cwiseCArg() const {
|
|
107
|
+
return CwiseCArgReturnType(derived());
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
template <typename ScalarExponent>
|
|
111
|
+
using CwisePowReturnType =
|
|
112
|
+
std::enable_if_t<internal::is_arithmetic<typename NumTraits<ScalarExponent>::Real>::value,
|
|
113
|
+
CwiseUnaryOp<internal::scalar_unary_pow_op<Scalar, ScalarExponent>, const Derived>>;
|
|
114
|
+
|
|
115
|
+
template <typename ScalarExponent>
|
|
116
|
+
EIGEN_DEVICE_FUNC inline const CwisePowReturnType<ScalarExponent> cwisePow(const ScalarExponent& exponent) const {
|
|
117
|
+
return CwisePowReturnType<ScalarExponent>(derived(), internal::scalar_unary_pow_op<Scalar, ScalarExponent>(exponent));
|
|
118
|
+
}
|
|
@@ -0,0 +1,133 @@
|
|
|
1
|
+
|
|
2
|
+
#ifdef EIGEN_PARSED_BY_DOXYGEN
|
|
3
|
+
|
|
4
|
+
/// \returns an expression of \c *this with reshaped sizes.
|
|
5
|
+
///
|
|
6
|
+
/// \param nRows the number of rows in the reshaped expression, specified at either run-time or compile-time, or
|
|
7
|
+
/// AutoSize \param nCols the number of columns in the reshaped expression, specified at either run-time or
|
|
8
|
+
/// compile-time, or AutoSize \tparam Order specifies whether the coefficients should be processed in column-major-order
|
|
9
|
+
/// (ColMajor), in row-major-order (RowMajor),
|
|
10
|
+
/// or follows the \em natural order of the nested expression (AutoOrder). The default is ColMajor.
|
|
11
|
+
/// \tparam NRowsType the type of the value handling the number of rows, typically Index.
|
|
12
|
+
/// \tparam NColsType the type of the value handling the number of columns, typically Index.
|
|
13
|
+
///
|
|
14
|
+
/// Dynamic size example: \include MatrixBase_reshaped_int_int.cpp
|
|
15
|
+
/// Output: \verbinclude MatrixBase_reshaped_int_int.out
|
|
16
|
+
///
|
|
17
|
+
/// The number of rows \a nRows and columns \a nCols can also be specified at compile-time by passing Eigen::fix<N>,
|
|
18
|
+
/// or Eigen::fix<N>(n) as arguments. In the later case, \c n plays the role of a runtime fallback value in case \c N
|
|
19
|
+
/// equals Eigen::Dynamic. Here is an example with a fixed number of rows and columns: \include
|
|
20
|
+
/// MatrixBase_reshaped_fixed.cpp Output: \verbinclude MatrixBase_reshaped_fixed.out
|
|
21
|
+
///
|
|
22
|
+
/// Finally, one of the sizes parameter can be automatically deduced from the other one by passing AutoSize as in the
|
|
23
|
+
/// following example: \include MatrixBase_reshaped_auto.cpp Output: \verbinclude MatrixBase_reshaped_auto.out AutoSize
|
|
24
|
+
/// does preserve compile-time sizes when possible, i.e., when the sizes of the input are known at compile time \b and
|
|
25
|
+
/// that the other size is passed at compile-time using Eigen::fix<N> as above.
|
|
26
|
+
///
|
|
27
|
+
/// \sa class Reshaped, fix, fix<N>(int)
|
|
28
|
+
///
|
|
29
|
+
template <int Order = ColMajor, typename NRowsType, typename NColsType>
|
|
30
|
+
EIGEN_DEVICE_FUNC inline Reshaped<Derived, ...> reshaped(NRowsType nRows, NColsType nCols);
|
|
31
|
+
|
|
32
|
+
/// This is the const version of reshaped(NRowsType,NColsType).
|
|
33
|
+
template <int Order = ColMajor, typename NRowsType, typename NColsType>
|
|
34
|
+
EIGEN_DEVICE_FUNC inline const Reshaped<const Derived, ...> reshaped(NRowsType nRows, NColsType nCols) const;
|
|
35
|
+
|
|
36
|
+
/// \returns an expression of \c *this with columns (or rows) stacked to a linear column vector
|
|
37
|
+
///
|
|
38
|
+
/// \tparam Order specifies whether the coefficients should be processed in column-major-order (ColMajor), in
|
|
39
|
+
/// row-major-order (RowMajor),
|
|
40
|
+
/// or follows the \em natural order of the nested expression (AutoOrder). The default is ColMajor.
|
|
41
|
+
///
|
|
42
|
+
/// This overloads is essentially a shortcut for `A.reshaped<Order>(AutoSize,fix<1>)`.
|
|
43
|
+
///
|
|
44
|
+
/// - If `Order==ColMajor` (the default), then it returns a column-vector from the stacked columns of \c *this.
|
|
45
|
+
/// - If `Order==RowMajor`, then it returns a column-vector from the stacked rows of \c *this.
|
|
46
|
+
/// - If `Order==AutoOrder`, then it returns a column-vector with elements stacked following the storage order of \c
|
|
47
|
+
/// *this.
|
|
48
|
+
/// This mode is the recommended one when the particular ordering of the element is not relevant.
|
|
49
|
+
///
|
|
50
|
+
/// Example:
|
|
51
|
+
/// \include MatrixBase_reshaped_to_vector.cpp
|
|
52
|
+
/// Output: \verbinclude MatrixBase_reshaped_to_vector.out
|
|
53
|
+
///
|
|
54
|
+
/// If you want more control, you can still fall back to reshaped(NRowsType,NColsType).
|
|
55
|
+
///
|
|
56
|
+
/// \sa reshaped(NRowsType,NColsType), class Reshaped
|
|
57
|
+
///
|
|
58
|
+
template <int Order = ColMajor>
|
|
59
|
+
EIGEN_DEVICE_FUNC inline Reshaped<Derived, ...> reshaped();
|
|
60
|
+
|
|
61
|
+
/// This is the const version of reshaped().
|
|
62
|
+
template <int Order = ColMajor>
|
|
63
|
+
EIGEN_DEVICE_FUNC inline const Reshaped<const Derived, ...> reshaped() const;
|
|
64
|
+
|
|
65
|
+
#else
|
|
66
|
+
|
|
67
|
+
// This file is automatically included twice to generate const and non-const versions
|
|
68
|
+
|
|
69
|
+
#ifndef EIGEN_RESHAPED_METHOD_2ND_PASS
|
|
70
|
+
#define EIGEN_RESHAPED_METHOD_CONST const
|
|
71
|
+
#else
|
|
72
|
+
#define EIGEN_RESHAPED_METHOD_CONST
|
|
73
|
+
#endif
|
|
74
|
+
|
|
75
|
+
#ifndef EIGEN_RESHAPED_METHOD_2ND_PASS
|
|
76
|
+
|
|
77
|
+
// This part is included once
|
|
78
|
+
|
|
79
|
+
#endif
|
|
80
|
+
|
|
81
|
+
template <typename NRowsType, typename NColsType>
|
|
82
|
+
EIGEN_DEVICE_FUNC inline Reshaped<
|
|
83
|
+
EIGEN_RESHAPED_METHOD_CONST Derived,
|
|
84
|
+
internal::get_compiletime_reshape_size<NRowsType, NColsType, SizeAtCompileTime>::value,
|
|
85
|
+
internal::get_compiletime_reshape_size<NColsType, NRowsType, SizeAtCompileTime>::value>
|
|
86
|
+
reshaped(NRowsType nRows, NColsType nCols) EIGEN_RESHAPED_METHOD_CONST {
|
|
87
|
+
return Reshaped<EIGEN_RESHAPED_METHOD_CONST Derived,
|
|
88
|
+
internal::get_compiletime_reshape_size<NRowsType, NColsType, SizeAtCompileTime>::value,
|
|
89
|
+
internal::get_compiletime_reshape_size<NColsType, NRowsType, SizeAtCompileTime>::value>(
|
|
90
|
+
derived(), internal::get_runtime_reshape_size(nRows, internal::get_runtime_value(nCols), size()),
|
|
91
|
+
internal::get_runtime_reshape_size(nCols, internal::get_runtime_value(nRows), size()));
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
template <int Order, typename NRowsType, typename NColsType>
|
|
95
|
+
EIGEN_DEVICE_FUNC inline Reshaped<
|
|
96
|
+
EIGEN_RESHAPED_METHOD_CONST Derived,
|
|
97
|
+
internal::get_compiletime_reshape_size<NRowsType, NColsType, SizeAtCompileTime>::value,
|
|
98
|
+
internal::get_compiletime_reshape_size<NColsType, NRowsType, SizeAtCompileTime>::value,
|
|
99
|
+
internal::get_compiletime_reshape_order(Flags, Order)>
|
|
100
|
+
reshaped(NRowsType nRows, NColsType nCols) EIGEN_RESHAPED_METHOD_CONST {
|
|
101
|
+
return Reshaped<EIGEN_RESHAPED_METHOD_CONST Derived,
|
|
102
|
+
internal::get_compiletime_reshape_size<NRowsType, NColsType, SizeAtCompileTime>::value,
|
|
103
|
+
internal::get_compiletime_reshape_size<NColsType, NRowsType, SizeAtCompileTime>::value,
|
|
104
|
+
internal::get_compiletime_reshape_order(Flags, Order)>(
|
|
105
|
+
derived(), internal::get_runtime_reshape_size(nRows, internal::get_runtime_value(nCols), size()),
|
|
106
|
+
internal::get_runtime_reshape_size(nCols, internal::get_runtime_value(nRows), size()));
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
// Views as linear vectors
|
|
110
|
+
|
|
111
|
+
EIGEN_DEVICE_FUNC inline Reshaped<EIGEN_RESHAPED_METHOD_CONST Derived, SizeAtCompileTime, 1> reshaped()
|
|
112
|
+
EIGEN_RESHAPED_METHOD_CONST {
|
|
113
|
+
return Reshaped<EIGEN_RESHAPED_METHOD_CONST Derived, SizeAtCompileTime, 1>(derived(), size(), 1);
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
template <int Order>
|
|
117
|
+
EIGEN_DEVICE_FUNC inline Reshaped<EIGEN_RESHAPED_METHOD_CONST Derived, SizeAtCompileTime, 1,
|
|
118
|
+
internal::get_compiletime_reshape_order(Flags, Order)>
|
|
119
|
+
reshaped() EIGEN_RESHAPED_METHOD_CONST {
|
|
120
|
+
EIGEN_STATIC_ASSERT(Order == RowMajor || Order == ColMajor || Order == AutoOrder, INVALID_TEMPLATE_PARAMETER);
|
|
121
|
+
return Reshaped<EIGEN_RESHAPED_METHOD_CONST Derived, SizeAtCompileTime, 1,
|
|
122
|
+
internal::get_compiletime_reshape_order(Flags, Order)>(derived(), size(), 1);
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
#undef EIGEN_RESHAPED_METHOD_CONST
|
|
126
|
+
|
|
127
|
+
#ifndef EIGEN_RESHAPED_METHOD_2ND_PASS
|
|
128
|
+
#define EIGEN_RESHAPED_METHOD_2ND_PASS
|
|
129
|
+
#include "ReshapedMethods.inc"
|
|
130
|
+
#undef EIGEN_RESHAPED_METHOD_2ND_PASS
|
|
131
|
+
#endif
|
|
132
|
+
|
|
133
|
+
#endif // EIGEN_PARSED_BY_DOXYGEN
|