pylibsparseir 0.1.0__cp311-cp311-macosx_15_0_arm64.whl → 0.6.0__cp311-cp311-macosx_15_0_arm64.whl
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.
Potentially problematic release.
This version of pylibsparseir might be problematic. Click here for more details.
- include/eigen3/Eigen/Cholesky +45 -0
- include/eigen3/Eigen/CholmodSupport +48 -0
- include/eigen3/Eigen/Core +384 -0
- include/eigen3/Eigen/Dense +7 -0
- include/eigen3/Eigen/Eigen +2 -0
- include/eigen3/Eigen/Eigenvalues +60 -0
- include/eigen3/Eigen/Geometry +59 -0
- include/eigen3/Eigen/Householder +29 -0
- include/eigen3/Eigen/IterativeLinearSolvers +48 -0
- include/eigen3/Eigen/Jacobi +32 -0
- include/eigen3/Eigen/KLUSupport +41 -0
- include/eigen3/Eigen/LU +47 -0
- include/eigen3/Eigen/MetisSupport +35 -0
- include/eigen3/Eigen/OrderingMethods +70 -0
- include/eigen3/Eigen/PaStiXSupport +49 -0
- include/eigen3/Eigen/PardisoSupport +35 -0
- include/eigen3/Eigen/QR +50 -0
- include/eigen3/Eigen/QtAlignedMalloc +39 -0
- include/eigen3/Eigen/SPQRSupport +34 -0
- include/eigen3/Eigen/SVD +50 -0
- include/eigen3/Eigen/Sparse +34 -0
- include/eigen3/Eigen/SparseCholesky +37 -0
- include/eigen3/Eigen/SparseCore +69 -0
- include/eigen3/Eigen/SparseLU +50 -0
- include/eigen3/Eigen/SparseQR +36 -0
- include/eigen3/Eigen/StdDeque +27 -0
- include/eigen3/Eigen/StdList +26 -0
- include/eigen3/Eigen/StdVector +27 -0
- include/eigen3/Eigen/SuperLUSupport +64 -0
- include/eigen3/Eigen/UmfPackSupport +40 -0
- include/eigen3/Eigen/src/Cholesky/LDLT.h +688 -0
- include/eigen3/Eigen/src/Cholesky/LLT.h +558 -0
- include/eigen3/Eigen/src/Cholesky/LLT_LAPACKE.h +99 -0
- include/eigen3/Eigen/src/CholmodSupport/CholmodSupport.h +682 -0
- include/eigen3/Eigen/src/Core/ArithmeticSequence.h +413 -0
- include/eigen3/Eigen/src/Core/Array.h +417 -0
- include/eigen3/Eigen/src/Core/ArrayBase.h +226 -0
- include/eigen3/Eigen/src/Core/ArrayWrapper.h +209 -0
- include/eigen3/Eigen/src/Core/Assign.h +90 -0
- include/eigen3/Eigen/src/Core/AssignEvaluator.h +1010 -0
- include/eigen3/Eigen/src/Core/Assign_MKL.h +178 -0
- include/eigen3/Eigen/src/Core/BandMatrix.h +353 -0
- include/eigen3/Eigen/src/Core/Block.h +448 -0
- include/eigen3/Eigen/src/Core/BooleanRedux.h +162 -0
- include/eigen3/Eigen/src/Core/CommaInitializer.h +164 -0
- include/eigen3/Eigen/src/Core/ConditionEstimator.h +175 -0
- include/eigen3/Eigen/src/Core/CoreEvaluators.h +1741 -0
- include/eigen3/Eigen/src/Core/CoreIterators.h +132 -0
- include/eigen3/Eigen/src/Core/CwiseBinaryOp.h +183 -0
- include/eigen3/Eigen/src/Core/CwiseNullaryOp.h +1001 -0
- include/eigen3/Eigen/src/Core/CwiseTernaryOp.h +197 -0
- include/eigen3/Eigen/src/Core/CwiseUnaryOp.h +103 -0
- include/eigen3/Eigen/src/Core/CwiseUnaryView.h +132 -0
- include/eigen3/Eigen/src/Core/DenseBase.h +701 -0
- include/eigen3/Eigen/src/Core/DenseCoeffsBase.h +685 -0
- include/eigen3/Eigen/src/Core/DenseStorage.h +652 -0
- include/eigen3/Eigen/src/Core/Diagonal.h +258 -0
- include/eigen3/Eigen/src/Core/DiagonalMatrix.h +391 -0
- include/eigen3/Eigen/src/Core/DiagonalProduct.h +28 -0
- include/eigen3/Eigen/src/Core/Dot.h +318 -0
- include/eigen3/Eigen/src/Core/EigenBase.h +160 -0
- include/eigen3/Eigen/src/Core/ForceAlignedAccess.h +150 -0
- include/eigen3/Eigen/src/Core/Fuzzy.h +155 -0
- include/eigen3/Eigen/src/Core/GeneralProduct.h +465 -0
- include/eigen3/Eigen/src/Core/GenericPacketMath.h +1040 -0
- include/eigen3/Eigen/src/Core/GlobalFunctions.h +194 -0
- include/eigen3/Eigen/src/Core/IO.h +258 -0
- include/eigen3/Eigen/src/Core/IndexedView.h +237 -0
- include/eigen3/Eigen/src/Core/Inverse.h +117 -0
- include/eigen3/Eigen/src/Core/Map.h +171 -0
- include/eigen3/Eigen/src/Core/MapBase.h +310 -0
- include/eigen3/Eigen/src/Core/MathFunctions.h +2057 -0
- include/eigen3/Eigen/src/Core/MathFunctionsImpl.h +200 -0
- include/eigen3/Eigen/src/Core/Matrix.h +565 -0
- include/eigen3/Eigen/src/Core/MatrixBase.h +547 -0
- include/eigen3/Eigen/src/Core/NestByValue.h +85 -0
- include/eigen3/Eigen/src/Core/NoAlias.h +109 -0
- include/eigen3/Eigen/src/Core/NumTraits.h +335 -0
- include/eigen3/Eigen/src/Core/PartialReduxEvaluator.h +232 -0
- include/eigen3/Eigen/src/Core/PermutationMatrix.h +605 -0
- include/eigen3/Eigen/src/Core/PlainObjectBase.h +1128 -0
- include/eigen3/Eigen/src/Core/Product.h +191 -0
- include/eigen3/Eigen/src/Core/ProductEvaluators.h +1179 -0
- include/eigen3/Eigen/src/Core/Random.h +218 -0
- include/eigen3/Eigen/src/Core/Redux.h +515 -0
- include/eigen3/Eigen/src/Core/Ref.h +381 -0
- include/eigen3/Eigen/src/Core/Replicate.h +142 -0
- include/eigen3/Eigen/src/Core/Reshaped.h +454 -0
- include/eigen3/Eigen/src/Core/ReturnByValue.h +119 -0
- include/eigen3/Eigen/src/Core/Reverse.h +217 -0
- include/eigen3/Eigen/src/Core/Select.h +164 -0
- include/eigen3/Eigen/src/Core/SelfAdjointView.h +365 -0
- include/eigen3/Eigen/src/Core/SelfCwiseBinaryOp.h +47 -0
- include/eigen3/Eigen/src/Core/Solve.h +188 -0
- include/eigen3/Eigen/src/Core/SolveTriangular.h +235 -0
- include/eigen3/Eigen/src/Core/SolverBase.h +168 -0
- include/eigen3/Eigen/src/Core/StableNorm.h +251 -0
- include/eigen3/Eigen/src/Core/StlIterators.h +463 -0
- include/eigen3/Eigen/src/Core/Stride.h +116 -0
- include/eigen3/Eigen/src/Core/Swap.h +68 -0
- include/eigen3/Eigen/src/Core/Transpose.h +464 -0
- include/eigen3/Eigen/src/Core/Transpositions.h +386 -0
- include/eigen3/Eigen/src/Core/TriangularMatrix.h +1001 -0
- include/eigen3/Eigen/src/Core/VectorBlock.h +96 -0
- include/eigen3/Eigen/src/Core/VectorwiseOp.h +784 -0
- include/eigen3/Eigen/src/Core/Visitor.h +381 -0
- include/eigen3/Eigen/src/Core/arch/AVX/Complex.h +372 -0
- include/eigen3/Eigen/src/Core/arch/AVX/MathFunctions.h +228 -0
- include/eigen3/Eigen/src/Core/arch/AVX/PacketMath.h +1574 -0
- include/eigen3/Eigen/src/Core/arch/AVX/TypeCasting.h +115 -0
- include/eigen3/Eigen/src/Core/arch/AVX512/Complex.h +422 -0
- include/eigen3/Eigen/src/Core/arch/AVX512/MathFunctions.h +362 -0
- include/eigen3/Eigen/src/Core/arch/AVX512/PacketMath.h +2303 -0
- include/eigen3/Eigen/src/Core/arch/AVX512/TypeCasting.h +89 -0
- include/eigen3/Eigen/src/Core/arch/AltiVec/Complex.h +417 -0
- include/eigen3/Eigen/src/Core/arch/AltiVec/MathFunctions.h +90 -0
- include/eigen3/Eigen/src/Core/arch/AltiVec/MatrixProduct.h +2937 -0
- include/eigen3/Eigen/src/Core/arch/AltiVec/MatrixProductCommon.h +221 -0
- include/eigen3/Eigen/src/Core/arch/AltiVec/MatrixProductMMA.h +629 -0
- include/eigen3/Eigen/src/Core/arch/AltiVec/PacketMath.h +2711 -0
- include/eigen3/Eigen/src/Core/arch/CUDA/Complex.h +258 -0
- include/eigen3/Eigen/src/Core/arch/Default/BFloat16.h +700 -0
- include/eigen3/Eigen/src/Core/arch/Default/ConjHelper.h +117 -0
- include/eigen3/Eigen/src/Core/arch/Default/GenericPacketMathFunctions.h +1649 -0
- include/eigen3/Eigen/src/Core/arch/Default/GenericPacketMathFunctionsFwd.h +110 -0
- include/eigen3/Eigen/src/Core/arch/Default/Half.h +942 -0
- include/eigen3/Eigen/src/Core/arch/Default/Settings.h +49 -0
- include/eigen3/Eigen/src/Core/arch/Default/TypeCasting.h +120 -0
- include/eigen3/Eigen/src/Core/arch/GPU/MathFunctions.h +103 -0
- include/eigen3/Eigen/src/Core/arch/GPU/PacketMath.h +1685 -0
- include/eigen3/Eigen/src/Core/arch/GPU/TypeCasting.h +80 -0
- include/eigen3/Eigen/src/Core/arch/HIP/hcc/math_constants.h +23 -0
- include/eigen3/Eigen/src/Core/arch/MSA/Complex.h +648 -0
- include/eigen3/Eigen/src/Core/arch/MSA/MathFunctions.h +387 -0
- include/eigen3/Eigen/src/Core/arch/MSA/PacketMath.h +1233 -0
- include/eigen3/Eigen/src/Core/arch/NEON/Complex.h +584 -0
- include/eigen3/Eigen/src/Core/arch/NEON/GeneralBlockPanelKernel.h +183 -0
- include/eigen3/Eigen/src/Core/arch/NEON/MathFunctions.h +75 -0
- include/eigen3/Eigen/src/Core/arch/NEON/PacketMath.h +4587 -0
- include/eigen3/Eigen/src/Core/arch/NEON/TypeCasting.h +1419 -0
- include/eigen3/Eigen/src/Core/arch/SSE/Complex.h +351 -0
- include/eigen3/Eigen/src/Core/arch/SSE/MathFunctions.h +199 -0
- include/eigen3/Eigen/src/Core/arch/SSE/PacketMath.h +1505 -0
- include/eigen3/Eigen/src/Core/arch/SSE/TypeCasting.h +142 -0
- include/eigen3/Eigen/src/Core/arch/SVE/MathFunctions.h +44 -0
- include/eigen3/Eigen/src/Core/arch/SVE/PacketMath.h +752 -0
- include/eigen3/Eigen/src/Core/arch/SVE/TypeCasting.h +49 -0
- include/eigen3/Eigen/src/Core/arch/SYCL/InteropHeaders.h +232 -0
- include/eigen3/Eigen/src/Core/arch/SYCL/MathFunctions.h +301 -0
- include/eigen3/Eigen/src/Core/arch/SYCL/PacketMath.h +670 -0
- include/eigen3/Eigen/src/Core/arch/SYCL/SyclMemoryModel.h +694 -0
- include/eigen3/Eigen/src/Core/arch/SYCL/TypeCasting.h +85 -0
- include/eigen3/Eigen/src/Core/arch/ZVector/Complex.h +426 -0
- include/eigen3/Eigen/src/Core/arch/ZVector/MathFunctions.h +233 -0
- include/eigen3/Eigen/src/Core/arch/ZVector/PacketMath.h +1060 -0
- include/eigen3/Eigen/src/Core/functors/AssignmentFunctors.h +177 -0
- include/eigen3/Eigen/src/Core/functors/BinaryFunctors.h +541 -0
- include/eigen3/Eigen/src/Core/functors/NullaryFunctors.h +189 -0
- include/eigen3/Eigen/src/Core/functors/StlFunctors.h +166 -0
- include/eigen3/Eigen/src/Core/functors/TernaryFunctors.h +25 -0
- include/eigen3/Eigen/src/Core/functors/UnaryFunctors.h +1131 -0
- include/eigen3/Eigen/src/Core/products/GeneralBlockPanelKernel.h +2645 -0
- include/eigen3/Eigen/src/Core/products/GeneralMatrixMatrix.h +517 -0
- include/eigen3/Eigen/src/Core/products/GeneralMatrixMatrixTriangular.h +317 -0
- include/eigen3/Eigen/src/Core/products/GeneralMatrixMatrixTriangular_BLAS.h +145 -0
- include/eigen3/Eigen/src/Core/products/GeneralMatrixMatrix_BLAS.h +124 -0
- include/eigen3/Eigen/src/Core/products/GeneralMatrixVector.h +518 -0
- include/eigen3/Eigen/src/Core/products/GeneralMatrixVector_BLAS.h +136 -0
- include/eigen3/Eigen/src/Core/products/Parallelizer.h +180 -0
- include/eigen3/Eigen/src/Core/products/SelfadjointMatrixMatrix.h +544 -0
- include/eigen3/Eigen/src/Core/products/SelfadjointMatrixMatrix_BLAS.h +295 -0
- include/eigen3/Eigen/src/Core/products/SelfadjointMatrixVector.h +262 -0
- include/eigen3/Eigen/src/Core/products/SelfadjointMatrixVector_BLAS.h +118 -0
- include/eigen3/Eigen/src/Core/products/SelfadjointProduct.h +133 -0
- include/eigen3/Eigen/src/Core/products/SelfadjointRank2Update.h +94 -0
- include/eigen3/Eigen/src/Core/products/TriangularMatrixMatrix.h +472 -0
- include/eigen3/Eigen/src/Core/products/TriangularMatrixMatrix_BLAS.h +317 -0
- include/eigen3/Eigen/src/Core/products/TriangularMatrixVector.h +350 -0
- include/eigen3/Eigen/src/Core/products/TriangularMatrixVector_BLAS.h +255 -0
- include/eigen3/Eigen/src/Core/products/TriangularSolverMatrix.h +337 -0
- include/eigen3/Eigen/src/Core/products/TriangularSolverMatrix_BLAS.h +167 -0
- include/eigen3/Eigen/src/Core/products/TriangularSolverVector.h +148 -0
- include/eigen3/Eigen/src/Core/util/BlasUtil.h +583 -0
- include/eigen3/Eigen/src/Core/util/ConfigureVectorization.h +512 -0
- include/eigen3/Eigen/src/Core/util/Constants.h +563 -0
- include/eigen3/Eigen/src/Core/util/DisableStupidWarnings.h +106 -0
- include/eigen3/Eigen/src/Core/util/ForwardDeclarations.h +322 -0
- include/eigen3/Eigen/src/Core/util/IndexedViewHelper.h +186 -0
- include/eigen3/Eigen/src/Core/util/IntegralConstant.h +272 -0
- include/eigen3/Eigen/src/Core/util/MKL_support.h +137 -0
- include/eigen3/Eigen/src/Core/util/Macros.h +1464 -0
- include/eigen3/Eigen/src/Core/util/Memory.h +1163 -0
- include/eigen3/Eigen/src/Core/util/Meta.h +812 -0
- include/eigen3/Eigen/src/Core/util/NonMPL2.h +3 -0
- include/eigen3/Eigen/src/Core/util/ReenableStupidWarnings.h +31 -0
- include/eigen3/Eigen/src/Core/util/ReshapedHelper.h +51 -0
- include/eigen3/Eigen/src/Core/util/StaticAssert.h +221 -0
- include/eigen3/Eigen/src/Core/util/SymbolicIndex.h +293 -0
- include/eigen3/Eigen/src/Core/util/XprHelper.h +856 -0
- include/eigen3/Eigen/src/Eigenvalues/ComplexEigenSolver.h +346 -0
- include/eigen3/Eigen/src/Eigenvalues/ComplexSchur.h +462 -0
- include/eigen3/Eigen/src/Eigenvalues/ComplexSchur_LAPACKE.h +91 -0
- include/eigen3/Eigen/src/Eigenvalues/EigenSolver.h +622 -0
- include/eigen3/Eigen/src/Eigenvalues/GeneralizedEigenSolver.h +418 -0
- include/eigen3/Eigen/src/Eigenvalues/GeneralizedSelfAdjointEigenSolver.h +226 -0
- include/eigen3/Eigen/src/Eigenvalues/HessenbergDecomposition.h +374 -0
- include/eigen3/Eigen/src/Eigenvalues/MatrixBaseEigenvalues.h +158 -0
- include/eigen3/Eigen/src/Eigenvalues/RealQZ.h +657 -0
- include/eigen3/Eigen/src/Eigenvalues/RealSchur.h +558 -0
- include/eigen3/Eigen/src/Eigenvalues/RealSchur_LAPACKE.h +77 -0
- include/eigen3/Eigen/src/Eigenvalues/SelfAdjointEigenSolver.h +904 -0
- include/eigen3/Eigen/src/Eigenvalues/SelfAdjointEigenSolver_LAPACKE.h +87 -0
- include/eigen3/Eigen/src/Eigenvalues/Tridiagonalization.h +561 -0
- include/eigen3/Eigen/src/Geometry/AlignedBox.h +486 -0
- include/eigen3/Eigen/src/Geometry/AngleAxis.h +247 -0
- include/eigen3/Eigen/src/Geometry/EulerAngles.h +114 -0
- include/eigen3/Eigen/src/Geometry/Homogeneous.h +501 -0
- include/eigen3/Eigen/src/Geometry/Hyperplane.h +282 -0
- include/eigen3/Eigen/src/Geometry/OrthoMethods.h +235 -0
- include/eigen3/Eigen/src/Geometry/ParametrizedLine.h +232 -0
- include/eigen3/Eigen/src/Geometry/Quaternion.h +870 -0
- include/eigen3/Eigen/src/Geometry/Rotation2D.h +199 -0
- include/eigen3/Eigen/src/Geometry/RotationBase.h +206 -0
- include/eigen3/Eigen/src/Geometry/Scaling.h +188 -0
- include/eigen3/Eigen/src/Geometry/Transform.h +1563 -0
- include/eigen3/Eigen/src/Geometry/Translation.h +202 -0
- include/eigen3/Eigen/src/Geometry/Umeyama.h +166 -0
- include/eigen3/Eigen/src/Geometry/arch/Geometry_SIMD.h +168 -0
- include/eigen3/Eigen/src/Householder/BlockHouseholder.h +110 -0
- include/eigen3/Eigen/src/Householder/Householder.h +176 -0
- include/eigen3/Eigen/src/Householder/HouseholderSequence.h +545 -0
- include/eigen3/Eigen/src/IterativeLinearSolvers/BasicPreconditioners.h +226 -0
- include/eigen3/Eigen/src/IterativeLinearSolvers/BiCGSTAB.h +212 -0
- include/eigen3/Eigen/src/IterativeLinearSolvers/ConjugateGradient.h +229 -0
- include/eigen3/Eigen/src/IterativeLinearSolvers/IncompleteCholesky.h +394 -0
- include/eigen3/Eigen/src/IterativeLinearSolvers/IncompleteLUT.h +453 -0
- include/eigen3/Eigen/src/IterativeLinearSolvers/IterativeSolverBase.h +444 -0
- include/eigen3/Eigen/src/IterativeLinearSolvers/LeastSquareConjugateGradient.h +198 -0
- include/eigen3/Eigen/src/IterativeLinearSolvers/SolveWithGuess.h +117 -0
- include/eigen3/Eigen/src/Jacobi/Jacobi.h +483 -0
- include/eigen3/Eigen/src/KLUSupport/KLUSupport.h +358 -0
- include/eigen3/Eigen/src/LU/Determinant.h +117 -0
- include/eigen3/Eigen/src/LU/FullPivLU.h +877 -0
- include/eigen3/Eigen/src/LU/InverseImpl.h +432 -0
- include/eigen3/Eigen/src/LU/PartialPivLU.h +624 -0
- include/eigen3/Eigen/src/LU/PartialPivLU_LAPACKE.h +83 -0
- include/eigen3/Eigen/src/LU/arch/InverseSize4.h +351 -0
- include/eigen3/Eigen/src/MetisSupport/MetisSupport.h +137 -0
- include/eigen3/Eigen/src/OrderingMethods/Amd.h +435 -0
- include/eigen3/Eigen/src/OrderingMethods/Eigen_Colamd.h +1863 -0
- include/eigen3/Eigen/src/OrderingMethods/Ordering.h +153 -0
- include/eigen3/Eigen/src/PaStiXSupport/PaStiXSupport.h +678 -0
- include/eigen3/Eigen/src/PardisoSupport/PardisoSupport.h +545 -0
- include/eigen3/Eigen/src/QR/ColPivHouseholderQR.h +674 -0
- include/eigen3/Eigen/src/QR/ColPivHouseholderQR_LAPACKE.h +97 -0
- include/eigen3/Eigen/src/QR/CompleteOrthogonalDecomposition.h +635 -0
- include/eigen3/Eigen/src/QR/FullPivHouseholderQR.h +713 -0
- include/eigen3/Eigen/src/QR/HouseholderQR.h +434 -0
- include/eigen3/Eigen/src/QR/HouseholderQR_LAPACKE.h +68 -0
- include/eigen3/Eigen/src/SPQRSupport/SuiteSparseQRSupport.h +335 -0
- include/eigen3/Eigen/src/SVD/BDCSVD.h +1366 -0
- include/eigen3/Eigen/src/SVD/JacobiSVD.h +812 -0
- include/eigen3/Eigen/src/SVD/JacobiSVD_LAPACKE.h +91 -0
- include/eigen3/Eigen/src/SVD/SVDBase.h +376 -0
- include/eigen3/Eigen/src/SVD/UpperBidiagonalization.h +414 -0
- include/eigen3/Eigen/src/SparseCholesky/SimplicialCholesky.h +697 -0
- include/eigen3/Eigen/src/SparseCholesky/SimplicialCholesky_impl.h +174 -0
- include/eigen3/Eigen/src/SparseCore/AmbiVector.h +378 -0
- include/eigen3/Eigen/src/SparseCore/CompressedStorage.h +274 -0
- include/eigen3/Eigen/src/SparseCore/ConservativeSparseSparseProduct.h +352 -0
- include/eigen3/Eigen/src/SparseCore/MappedSparseMatrix.h +67 -0
- include/eigen3/Eigen/src/SparseCore/SparseAssign.h +270 -0
- include/eigen3/Eigen/src/SparseCore/SparseBlock.h +571 -0
- include/eigen3/Eigen/src/SparseCore/SparseColEtree.h +206 -0
- include/eigen3/Eigen/src/SparseCore/SparseCompressedBase.h +370 -0
- include/eigen3/Eigen/src/SparseCore/SparseCwiseBinaryOp.h +722 -0
- include/eigen3/Eigen/src/SparseCore/SparseCwiseUnaryOp.h +150 -0
- include/eigen3/Eigen/src/SparseCore/SparseDenseProduct.h +342 -0
- include/eigen3/Eigen/src/SparseCore/SparseDiagonalProduct.h +138 -0
- include/eigen3/Eigen/src/SparseCore/SparseDot.h +98 -0
- include/eigen3/Eigen/src/SparseCore/SparseFuzzy.h +29 -0
- include/eigen3/Eigen/src/SparseCore/SparseMap.h +305 -0
- include/eigen3/Eigen/src/SparseCore/SparseMatrix.h +1518 -0
- include/eigen3/Eigen/src/SparseCore/SparseMatrixBase.h +398 -0
- include/eigen3/Eigen/src/SparseCore/SparsePermutation.h +178 -0
- include/eigen3/Eigen/src/SparseCore/SparseProduct.h +181 -0
- include/eigen3/Eigen/src/SparseCore/SparseRedux.h +49 -0
- include/eigen3/Eigen/src/SparseCore/SparseRef.h +397 -0
- include/eigen3/Eigen/src/SparseCore/SparseSelfAdjointView.h +659 -0
- include/eigen3/Eigen/src/SparseCore/SparseSolverBase.h +124 -0
- include/eigen3/Eigen/src/SparseCore/SparseSparseProductWithPruning.h +198 -0
- include/eigen3/Eigen/src/SparseCore/SparseTranspose.h +92 -0
- include/eigen3/Eigen/src/SparseCore/SparseTriangularView.h +189 -0
- include/eigen3/Eigen/src/SparseCore/SparseUtil.h +186 -0
- include/eigen3/Eigen/src/SparseCore/SparseVector.h +478 -0
- include/eigen3/Eigen/src/SparseCore/SparseView.h +254 -0
- include/eigen3/Eigen/src/SparseCore/TriangularSolver.h +315 -0
- include/eigen3/Eigen/src/SparseLU/SparseLU.h +923 -0
- include/eigen3/Eigen/src/SparseLU/SparseLUImpl.h +66 -0
- include/eigen3/Eigen/src/SparseLU/SparseLU_Memory.h +226 -0
- include/eigen3/Eigen/src/SparseLU/SparseLU_Structs.h +110 -0
- include/eigen3/Eigen/src/SparseLU/SparseLU_SupernodalMatrix.h +375 -0
- include/eigen3/Eigen/src/SparseLU/SparseLU_Utils.h +80 -0
- include/eigen3/Eigen/src/SparseLU/SparseLU_column_bmod.h +181 -0
- include/eigen3/Eigen/src/SparseLU/SparseLU_column_dfs.h +179 -0
- include/eigen3/Eigen/src/SparseLU/SparseLU_copy_to_ucol.h +107 -0
- include/eigen3/Eigen/src/SparseLU/SparseLU_gemm_kernel.h +280 -0
- include/eigen3/Eigen/src/SparseLU/SparseLU_heap_relax_snode.h +126 -0
- include/eigen3/Eigen/src/SparseLU/SparseLU_kernel_bmod.h +130 -0
- include/eigen3/Eigen/src/SparseLU/SparseLU_panel_bmod.h +223 -0
- include/eigen3/Eigen/src/SparseLU/SparseLU_panel_dfs.h +258 -0
- include/eigen3/Eigen/src/SparseLU/SparseLU_pivotL.h +137 -0
- include/eigen3/Eigen/src/SparseLU/SparseLU_pruneL.h +136 -0
- include/eigen3/Eigen/src/SparseLU/SparseLU_relax_snode.h +83 -0
- include/eigen3/Eigen/src/SparseQR/SparseQR.h +758 -0
- include/eigen3/Eigen/src/StlSupport/StdDeque.h +116 -0
- include/eigen3/Eigen/src/StlSupport/StdList.h +106 -0
- include/eigen3/Eigen/src/StlSupport/StdVector.h +131 -0
- include/eigen3/Eigen/src/StlSupport/details.h +84 -0
- include/eigen3/Eigen/src/SuperLUSupport/SuperLUSupport.h +1025 -0
- include/eigen3/Eigen/src/UmfPackSupport/UmfPackSupport.h +642 -0
- include/eigen3/Eigen/src/misc/Image.h +82 -0
- include/eigen3/Eigen/src/misc/Kernel.h +79 -0
- include/eigen3/Eigen/src/misc/RealSvd2x2.h +55 -0
- include/eigen3/Eigen/src/misc/blas.h +440 -0
- include/eigen3/Eigen/src/misc/lapack.h +152 -0
- include/eigen3/Eigen/src/misc/lapacke.h +16292 -0
- include/eigen3/Eigen/src/misc/lapacke_mangling.h +17 -0
- include/eigen3/Eigen/src/plugins/ArrayCwiseBinaryOps.h +358 -0
- include/eigen3/Eigen/src/plugins/ArrayCwiseUnaryOps.h +696 -0
- include/eigen3/Eigen/src/plugins/BlockMethods.h +1442 -0
- include/eigen3/Eigen/src/plugins/CommonCwiseBinaryOps.h +115 -0
- include/eigen3/Eigen/src/plugins/CommonCwiseUnaryOps.h +177 -0
- include/eigen3/Eigen/src/plugins/IndexedViewMethods.h +262 -0
- include/eigen3/Eigen/src/plugins/MatrixCwiseBinaryOps.h +152 -0
- include/eigen3/Eigen/src/plugins/MatrixCwiseUnaryOps.h +95 -0
- include/eigen3/Eigen/src/plugins/ReshapedMethods.h +149 -0
- include/eigen3/signature_of_eigen3_matrix_library +1 -0
- include/eigen3/unsupported/Eigen/AdolcForward +159 -0
- include/eigen3/unsupported/Eigen/AlignedVector3 +234 -0
- include/eigen3/unsupported/Eigen/ArpackSupport +30 -0
- include/eigen3/unsupported/Eigen/AutoDiff +46 -0
- include/eigen3/unsupported/Eigen/BVH +95 -0
- include/eigen3/unsupported/Eigen/CXX11/Tensor +137 -0
- include/eigen3/unsupported/Eigen/CXX11/TensorSymmetry +42 -0
- include/eigen3/unsupported/Eigen/CXX11/ThreadPool +74 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/Tensor.h +554 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorArgMax.h +329 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorAssign.h +247 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorBase.h +1176 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorBlock.h +1559 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorBroadcasting.h +1093 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorChipping.h +518 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorConcatenation.h +377 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorContraction.h +1023 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorContractionBlocking.h +73 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorContractionCuda.h +6 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorContractionGpu.h +1413 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorContractionMapper.h +575 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorContractionSycl.h +1650 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorContractionThreadPool.h +1679 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorConversion.h +456 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorConvolution.h +1132 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorConvolutionSycl.h +544 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorCostModel.h +214 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorCustomOp.h +347 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorDevice.h +137 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorDeviceCuda.h +6 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorDeviceDefault.h +104 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorDeviceGpu.h +389 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorDeviceSycl.h +1048 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorDeviceThreadPool.h +409 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorDimensionList.h +236 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorDimensions.h +490 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorEvalTo.h +236 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorEvaluator.h +983 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorExecutor.h +703 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorExpr.h +388 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorFFT.h +669 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorFixedSize.h +379 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorForcedEval.h +237 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorForwardDeclarations.h +191 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorFunctors.h +488 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorGenerator.h +302 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorGlobalFunctions.h +33 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorGpuHipCudaDefines.h +99 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorGpuHipCudaUndefines.h +44 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorIO.h +79 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorImagePatch.h +603 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorIndexList.h +738 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorInflation.h +247 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorInitializer.h +82 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorIntDiv.h +263 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorLayoutSwap.h +216 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorMacros.h +98 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorMap.h +327 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorMeta.h +311 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorMorphing.h +1102 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorPadding.h +708 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorPatch.h +291 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorRandom.h +322 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorReduction.h +998 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorReductionCuda.h +6 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorReductionGpu.h +966 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorReductionSycl.h +582 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorRef.h +454 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorReverse.h +465 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorScan.h +528 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorScanSycl.h +513 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorShuffling.h +471 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorStorage.h +161 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorStriding.h +346 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorTrace.h +303 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorTraits.h +264 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorUInt128.h +249 -0
- include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorVolumePatch.h +629 -0
- include/eigen3/unsupported/Eigen/CXX11/src/TensorSymmetry/DynamicSymmetry.h +293 -0
- include/eigen3/unsupported/Eigen/CXX11/src/TensorSymmetry/StaticSymmetry.h +236 -0
- include/eigen3/unsupported/Eigen/CXX11/src/TensorSymmetry/Symmetry.h +338 -0
- include/eigen3/unsupported/Eigen/CXX11/src/TensorSymmetry/util/TemplateGroupTheory.h +669 -0
- include/eigen3/unsupported/Eigen/CXX11/src/ThreadPool/Barrier.h +67 -0
- include/eigen3/unsupported/Eigen/CXX11/src/ThreadPool/EventCount.h +249 -0
- include/eigen3/unsupported/Eigen/CXX11/src/ThreadPool/NonBlockingThreadPool.h +486 -0
- include/eigen3/unsupported/Eigen/CXX11/src/ThreadPool/RunQueue.h +236 -0
- include/eigen3/unsupported/Eigen/CXX11/src/ThreadPool/ThreadCancel.h +23 -0
- include/eigen3/unsupported/Eigen/CXX11/src/ThreadPool/ThreadEnvironment.h +40 -0
- include/eigen3/unsupported/Eigen/CXX11/src/ThreadPool/ThreadLocal.h +301 -0
- include/eigen3/unsupported/Eigen/CXX11/src/ThreadPool/ThreadPoolInterface.h +48 -0
- include/eigen3/unsupported/Eigen/CXX11/src/ThreadPool/ThreadYield.h +20 -0
- include/eigen3/unsupported/Eigen/CXX11/src/util/CXX11Meta.h +537 -0
- include/eigen3/unsupported/Eigen/CXX11/src/util/CXX11Workarounds.h +88 -0
- include/eigen3/unsupported/Eigen/CXX11/src/util/EmulateArray.h +261 -0
- include/eigen3/unsupported/Eigen/CXX11/src/util/MaxSizeVector.h +158 -0
- include/eigen3/unsupported/Eigen/EulerAngles +43 -0
- include/eigen3/unsupported/Eigen/FFT +419 -0
- include/eigen3/unsupported/Eigen/IterativeSolvers +51 -0
- include/eigen3/unsupported/Eigen/KroneckerProduct +36 -0
- include/eigen3/unsupported/Eigen/LevenbergMarquardt +49 -0
- include/eigen3/unsupported/Eigen/MPRealSupport +213 -0
- include/eigen3/unsupported/Eigen/MatrixFunctions +504 -0
- include/eigen3/unsupported/Eigen/MoreVectorization +24 -0
- include/eigen3/unsupported/Eigen/NonLinearOptimization +140 -0
- include/eigen3/unsupported/Eigen/NumericalDiff +56 -0
- include/eigen3/unsupported/Eigen/OpenGLSupport +322 -0
- include/eigen3/unsupported/Eigen/Polynomials +137 -0
- include/eigen3/unsupported/Eigen/Skyline +39 -0
- include/eigen3/unsupported/Eigen/SparseExtra +54 -0
- include/eigen3/unsupported/Eigen/SpecialFunctions +103 -0
- include/eigen3/unsupported/Eigen/Splines +35 -0
- include/eigen3/unsupported/Eigen/src/AutoDiff/AutoDiffJacobian.h +108 -0
- include/eigen3/unsupported/Eigen/src/AutoDiff/AutoDiffScalar.h +730 -0
- include/eigen3/unsupported/Eigen/src/AutoDiff/AutoDiffVector.h +220 -0
- include/eigen3/unsupported/Eigen/src/BVH/BVAlgorithms.h +293 -0
- include/eigen3/unsupported/Eigen/src/BVH/KdBVH.h +223 -0
- include/eigen3/unsupported/Eigen/src/Eigenvalues/ArpackSelfAdjointEigenSolver.h +790 -0
- include/eigen3/unsupported/Eigen/src/EulerAngles/EulerAngles.h +355 -0
- include/eigen3/unsupported/Eigen/src/EulerAngles/EulerSystem.h +305 -0
- include/eigen3/unsupported/Eigen/src/FFT/ei_fftw_impl.h +261 -0
- include/eigen3/unsupported/Eigen/src/FFT/ei_kissfft_impl.h +449 -0
- include/eigen3/unsupported/Eigen/src/IterativeSolvers/ConstrainedConjGrad.h +187 -0
- include/eigen3/unsupported/Eigen/src/IterativeSolvers/DGMRES.h +511 -0
- include/eigen3/unsupported/Eigen/src/IterativeSolvers/GMRES.h +335 -0
- include/eigen3/unsupported/Eigen/src/IterativeSolvers/IDRS.h +436 -0
- include/eigen3/unsupported/Eigen/src/IterativeSolvers/IncompleteLU.h +90 -0
- include/eigen3/unsupported/Eigen/src/IterativeSolvers/IterationController.h +154 -0
- include/eigen3/unsupported/Eigen/src/IterativeSolvers/MINRES.h +267 -0
- include/eigen3/unsupported/Eigen/src/IterativeSolvers/Scaling.h +193 -0
- include/eigen3/unsupported/Eigen/src/KroneckerProduct/KroneckerTensorProduct.h +305 -0
- include/eigen3/unsupported/Eigen/src/LevenbergMarquardt/LMcovar.h +84 -0
- include/eigen3/unsupported/Eigen/src/LevenbergMarquardt/LMonestep.h +202 -0
- include/eigen3/unsupported/Eigen/src/LevenbergMarquardt/LMpar.h +160 -0
- include/eigen3/unsupported/Eigen/src/LevenbergMarquardt/LMqrsolv.h +188 -0
- include/eigen3/unsupported/Eigen/src/LevenbergMarquardt/LevenbergMarquardt.h +396 -0
- include/eigen3/unsupported/Eigen/src/MatrixFunctions/MatrixExponential.h +441 -0
- include/eigen3/unsupported/Eigen/src/MatrixFunctions/MatrixFunction.h +569 -0
- include/eigen3/unsupported/Eigen/src/MatrixFunctions/MatrixLogarithm.h +373 -0
- include/eigen3/unsupported/Eigen/src/MatrixFunctions/MatrixPower.h +705 -0
- include/eigen3/unsupported/Eigen/src/MatrixFunctions/MatrixSquareRoot.h +368 -0
- include/eigen3/unsupported/Eigen/src/MatrixFunctions/StemFunction.h +117 -0
- include/eigen3/unsupported/Eigen/src/MoreVectorization/MathFunctions.h +95 -0
- include/eigen3/unsupported/Eigen/src/NonLinearOptimization/HybridNonLinearSolver.h +601 -0
- include/eigen3/unsupported/Eigen/src/NonLinearOptimization/LevenbergMarquardt.h +657 -0
- include/eigen3/unsupported/Eigen/src/NonLinearOptimization/chkder.h +66 -0
- include/eigen3/unsupported/Eigen/src/NonLinearOptimization/covar.h +70 -0
- include/eigen3/unsupported/Eigen/src/NonLinearOptimization/dogleg.h +107 -0
- include/eigen3/unsupported/Eigen/src/NonLinearOptimization/fdjac1.h +79 -0
- include/eigen3/unsupported/Eigen/src/NonLinearOptimization/lmpar.h +298 -0
- include/eigen3/unsupported/Eigen/src/NonLinearOptimization/qrsolv.h +91 -0
- include/eigen3/unsupported/Eigen/src/NonLinearOptimization/r1mpyq.h +30 -0
- include/eigen3/unsupported/Eigen/src/NonLinearOptimization/r1updt.h +99 -0
- include/eigen3/unsupported/Eigen/src/NonLinearOptimization/rwupdt.h +49 -0
- include/eigen3/unsupported/Eigen/src/NumericalDiff/NumericalDiff.h +130 -0
- include/eigen3/unsupported/Eigen/src/Polynomials/Companion.h +280 -0
- include/eigen3/unsupported/Eigen/src/Polynomials/PolynomialSolver.h +428 -0
- include/eigen3/unsupported/Eigen/src/Polynomials/PolynomialUtils.h +143 -0
- include/eigen3/unsupported/Eigen/src/Skyline/SkylineInplaceLU.h +352 -0
- include/eigen3/unsupported/Eigen/src/Skyline/SkylineMatrix.h +862 -0
- include/eigen3/unsupported/Eigen/src/Skyline/SkylineMatrixBase.h +212 -0
- include/eigen3/unsupported/Eigen/src/Skyline/SkylineProduct.h +295 -0
- include/eigen3/unsupported/Eigen/src/Skyline/SkylineStorage.h +259 -0
- include/eigen3/unsupported/Eigen/src/Skyline/SkylineUtil.h +89 -0
- include/eigen3/unsupported/Eigen/src/SparseExtra/BlockOfDynamicSparseMatrix.h +122 -0
- include/eigen3/unsupported/Eigen/src/SparseExtra/BlockSparseMatrix.h +1079 -0
- include/eigen3/unsupported/Eigen/src/SparseExtra/DynamicSparseMatrix.h +404 -0
- include/eigen3/unsupported/Eigen/src/SparseExtra/MarketIO.h +282 -0
- include/eigen3/unsupported/Eigen/src/SparseExtra/MatrixMarketIterator.h +247 -0
- include/eigen3/unsupported/Eigen/src/SparseExtra/RandomSetter.h +349 -0
- include/eigen3/unsupported/Eigen/src/SpecialFunctions/BesselFunctionsArrayAPI.h +286 -0
- include/eigen3/unsupported/Eigen/src/SpecialFunctions/BesselFunctionsBFloat16.h +68 -0
- include/eigen3/unsupported/Eigen/src/SpecialFunctions/BesselFunctionsFunctors.h +357 -0
- include/eigen3/unsupported/Eigen/src/SpecialFunctions/BesselFunctionsHalf.h +66 -0
- include/eigen3/unsupported/Eigen/src/SpecialFunctions/BesselFunctionsImpl.h +1959 -0
- include/eigen3/unsupported/Eigen/src/SpecialFunctions/BesselFunctionsPacketMath.h +118 -0
- include/eigen3/unsupported/Eigen/src/SpecialFunctions/HipVectorCompatibility.h +67 -0
- include/eigen3/unsupported/Eigen/src/SpecialFunctions/SpecialFunctionsArrayAPI.h +167 -0
- include/eigen3/unsupported/Eigen/src/SpecialFunctions/SpecialFunctionsBFloat16.h +58 -0
- include/eigen3/unsupported/Eigen/src/SpecialFunctions/SpecialFunctionsFunctors.h +330 -0
- include/eigen3/unsupported/Eigen/src/SpecialFunctions/SpecialFunctionsHalf.h +58 -0
- include/eigen3/unsupported/Eigen/src/SpecialFunctions/SpecialFunctionsImpl.h +2045 -0
- include/eigen3/unsupported/Eigen/src/SpecialFunctions/SpecialFunctionsPacketMath.h +79 -0
- include/eigen3/unsupported/Eigen/src/SpecialFunctions/arch/AVX/BesselFunctions.h +46 -0
- include/eigen3/unsupported/Eigen/src/SpecialFunctions/arch/AVX/SpecialFunctions.h +16 -0
- include/eigen3/unsupported/Eigen/src/SpecialFunctions/arch/AVX512/BesselFunctions.h +46 -0
- include/eigen3/unsupported/Eigen/src/SpecialFunctions/arch/AVX512/SpecialFunctions.h +16 -0
- include/eigen3/unsupported/Eigen/src/SpecialFunctions/arch/GPU/SpecialFunctions.h +369 -0
- include/eigen3/unsupported/Eigen/src/SpecialFunctions/arch/NEON/BesselFunctions.h +54 -0
- include/eigen3/unsupported/Eigen/src/SpecialFunctions/arch/NEON/SpecialFunctions.h +34 -0
- include/eigen3/unsupported/Eigen/src/Splines/Spline.h +507 -0
- include/eigen3/unsupported/Eigen/src/Splines/SplineFitting.h +431 -0
- include/eigen3/unsupported/Eigen/src/Splines/SplineFwd.h +93 -0
- pylibsparseir/__init__.py +31 -0
- pylibsparseir/clean_build_artifacts.py +0 -1
- pylibsparseir/core.py +178 -62
- pylibsparseir/libsparseir.dylib +0 -0
- pylibsparseir-0.6.0.dist-info/METADATA +213 -0
- pylibsparseir-0.6.0.dist-info/RECORD +545 -0
- {pylibsparseir-0.1.0.dist-info → pylibsparseir-0.6.0.dist-info}/WHEEL +1 -1
- pylibsparseir-0.6.0.dist-info/licenses/LICENSE +21 -0
- share/eigen3/cmake/Eigen3Config.cmake +37 -0
- share/eigen3/cmake/Eigen3ConfigVersion.cmake +65 -0
- share/eigen3/cmake/Eigen3Targets.cmake +106 -0
- share/eigen3/cmake/UseEigen3.cmake +6 -0
- share/pkgconfig/eigen3.pc +9 -0
- pylibsparseir/libsparseir.0.4.2.dylib +0 -0
- pylibsparseir/libsparseir.0.dylib +0 -0
- pylibsparseir-0.1.0.dist-info/METADATA +0 -130
- pylibsparseir-0.1.0.dist-info/RECORD +0 -12
- pylibsparseir-0.1.0.dist-info/entry_points.txt +0 -2
- pylibsparseir-0.1.0.dist-info/top_level.txt +0 -1
|
@@ -0,0 +1,302 @@
|
|
|
1
|
+
// This file is part of Eigen, a lightweight C++ template library
|
|
2
|
+
// for linear algebra.
|
|
3
|
+
//
|
|
4
|
+
// Copyright (C) 2015 Benoit Steiner <benoit.steiner.goog@gmail.com>
|
|
5
|
+
//
|
|
6
|
+
// This Source Code Form is subject to the terms of the Mozilla
|
|
7
|
+
// Public License v. 2.0. If a copy of the MPL was not distributed
|
|
8
|
+
// with this file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
9
|
+
|
|
10
|
+
#ifndef EIGEN_CXX11_TENSOR_TENSOR_GENERATOR_H
|
|
11
|
+
#define EIGEN_CXX11_TENSOR_TENSOR_GENERATOR_H
|
|
12
|
+
|
|
13
|
+
namespace Eigen {
|
|
14
|
+
|
|
15
|
+
/** \class TensorGeneratorOp
|
|
16
|
+
* \ingroup CXX11_Tensor_Module
|
|
17
|
+
*
|
|
18
|
+
* \brief Tensor generator class.
|
|
19
|
+
*
|
|
20
|
+
*
|
|
21
|
+
*/
|
|
22
|
+
namespace internal {
|
|
23
|
+
template<typename Generator, typename XprType>
|
|
24
|
+
struct traits<TensorGeneratorOp<Generator, XprType> > : public traits<XprType>
|
|
25
|
+
{
|
|
26
|
+
typedef typename XprType::Scalar Scalar;
|
|
27
|
+
typedef traits<XprType> XprTraits;
|
|
28
|
+
typedef typename XprTraits::StorageKind StorageKind;
|
|
29
|
+
typedef typename XprTraits::Index Index;
|
|
30
|
+
typedef typename XprType::Nested Nested;
|
|
31
|
+
typedef typename remove_reference<Nested>::type _Nested;
|
|
32
|
+
static const int NumDimensions = XprTraits::NumDimensions;
|
|
33
|
+
static const int Layout = XprTraits::Layout;
|
|
34
|
+
typedef typename XprTraits::PointerType PointerType;
|
|
35
|
+
};
|
|
36
|
+
|
|
37
|
+
template<typename Generator, typename XprType>
|
|
38
|
+
struct eval<TensorGeneratorOp<Generator, XprType>, Eigen::Dense>
|
|
39
|
+
{
|
|
40
|
+
typedef const TensorGeneratorOp<Generator, XprType>& type;
|
|
41
|
+
};
|
|
42
|
+
|
|
43
|
+
template<typename Generator, typename XprType>
|
|
44
|
+
struct nested<TensorGeneratorOp<Generator, XprType>, 1, typename eval<TensorGeneratorOp<Generator, XprType> >::type>
|
|
45
|
+
{
|
|
46
|
+
typedef TensorGeneratorOp<Generator, XprType> type;
|
|
47
|
+
};
|
|
48
|
+
|
|
49
|
+
} // end namespace internal
|
|
50
|
+
|
|
51
|
+
|
|
52
|
+
|
|
53
|
+
template<typename Generator, typename XprType>
|
|
54
|
+
class TensorGeneratorOp : public TensorBase<TensorGeneratorOp<Generator, XprType>, ReadOnlyAccessors>
|
|
55
|
+
{
|
|
56
|
+
public:
|
|
57
|
+
typedef typename Eigen::internal::traits<TensorGeneratorOp>::Scalar Scalar;
|
|
58
|
+
typedef typename Eigen::NumTraits<Scalar>::Real RealScalar;
|
|
59
|
+
typedef typename XprType::CoeffReturnType CoeffReturnType;
|
|
60
|
+
typedef typename Eigen::internal::nested<TensorGeneratorOp>::type Nested;
|
|
61
|
+
typedef typename Eigen::internal::traits<TensorGeneratorOp>::StorageKind StorageKind;
|
|
62
|
+
typedef typename Eigen::internal::traits<TensorGeneratorOp>::Index Index;
|
|
63
|
+
|
|
64
|
+
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE TensorGeneratorOp(const XprType& expr, const Generator& generator)
|
|
65
|
+
: m_xpr(expr), m_generator(generator) {}
|
|
66
|
+
|
|
67
|
+
EIGEN_DEVICE_FUNC
|
|
68
|
+
const Generator& generator() const { return m_generator; }
|
|
69
|
+
|
|
70
|
+
EIGEN_DEVICE_FUNC
|
|
71
|
+
const typename internal::remove_all<typename XprType::Nested>::type&
|
|
72
|
+
expression() const { return m_xpr; }
|
|
73
|
+
|
|
74
|
+
protected:
|
|
75
|
+
typename XprType::Nested m_xpr;
|
|
76
|
+
const Generator m_generator;
|
|
77
|
+
};
|
|
78
|
+
|
|
79
|
+
|
|
80
|
+
// Eval as rvalue
|
|
81
|
+
template<typename Generator, typename ArgType, typename Device>
|
|
82
|
+
struct TensorEvaluator<const TensorGeneratorOp<Generator, ArgType>, Device>
|
|
83
|
+
{
|
|
84
|
+
typedef TensorGeneratorOp<Generator, ArgType> XprType;
|
|
85
|
+
typedef typename XprType::Index Index;
|
|
86
|
+
typedef typename TensorEvaluator<ArgType, Device>::Dimensions Dimensions;
|
|
87
|
+
static const int NumDims = internal::array_size<Dimensions>::value;
|
|
88
|
+
typedef typename XprType::Scalar Scalar;
|
|
89
|
+
typedef typename XprType::CoeffReturnType CoeffReturnType;
|
|
90
|
+
typedef typename PacketType<CoeffReturnType, Device>::type PacketReturnType;
|
|
91
|
+
typedef StorageMemory<CoeffReturnType, Device> Storage;
|
|
92
|
+
typedef typename Storage::Type EvaluatorPointerType;
|
|
93
|
+
enum {
|
|
94
|
+
IsAligned = false,
|
|
95
|
+
PacketAccess = (PacketType<CoeffReturnType, Device>::size > 1),
|
|
96
|
+
BlockAccess = true,
|
|
97
|
+
PreferBlockAccess = true,
|
|
98
|
+
Layout = TensorEvaluator<ArgType, Device>::Layout,
|
|
99
|
+
CoordAccess = false, // to be implemented
|
|
100
|
+
RawAccess = false
|
|
101
|
+
};
|
|
102
|
+
|
|
103
|
+
typedef internal::TensorIntDivisor<Index> IndexDivisor;
|
|
104
|
+
|
|
105
|
+
//===- Tensor block evaluation strategy (see TensorBlock.h) -------------===//
|
|
106
|
+
typedef internal::TensorBlockDescriptor<NumDims, Index> TensorBlockDesc;
|
|
107
|
+
typedef internal::TensorBlockScratchAllocator<Device> TensorBlockScratch;
|
|
108
|
+
|
|
109
|
+
typedef typename internal::TensorMaterializedBlock<CoeffReturnType, NumDims,
|
|
110
|
+
Layout, Index>
|
|
111
|
+
TensorBlock;
|
|
112
|
+
//===--------------------------------------------------------------------===//
|
|
113
|
+
|
|
114
|
+
EIGEN_STRONG_INLINE TensorEvaluator(const XprType& op, const Device& device)
|
|
115
|
+
: m_device(device), m_generator(op.generator())
|
|
116
|
+
{
|
|
117
|
+
TensorEvaluator<ArgType, Device> argImpl(op.expression(), device);
|
|
118
|
+
m_dimensions = argImpl.dimensions();
|
|
119
|
+
|
|
120
|
+
if (static_cast<int>(Layout) == static_cast<int>(ColMajor)) {
|
|
121
|
+
m_strides[0] = 1;
|
|
122
|
+
EIGEN_UNROLL_LOOP
|
|
123
|
+
for (int i = 1; i < NumDims; ++i) {
|
|
124
|
+
m_strides[i] = m_strides[i - 1] * m_dimensions[i - 1];
|
|
125
|
+
if (m_strides[i] != 0) m_fast_strides[i] = IndexDivisor(m_strides[i]);
|
|
126
|
+
}
|
|
127
|
+
} else {
|
|
128
|
+
m_strides[NumDims - 1] = 1;
|
|
129
|
+
EIGEN_UNROLL_LOOP
|
|
130
|
+
for (int i = NumDims - 2; i >= 0; --i) {
|
|
131
|
+
m_strides[i] = m_strides[i + 1] * m_dimensions[i + 1];
|
|
132
|
+
if (m_strides[i] != 0) m_fast_strides[i] = IndexDivisor(m_strides[i]);
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const Dimensions& dimensions() const { return m_dimensions; }
|
|
138
|
+
|
|
139
|
+
EIGEN_STRONG_INLINE bool evalSubExprsIfNeeded(EvaluatorPointerType /*data*/) {
|
|
140
|
+
return true;
|
|
141
|
+
}
|
|
142
|
+
EIGEN_STRONG_INLINE void cleanup() {
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE CoeffReturnType coeff(Index index) const
|
|
146
|
+
{
|
|
147
|
+
array<Index, NumDims> coords;
|
|
148
|
+
extract_coordinates(index, coords);
|
|
149
|
+
return m_generator(coords);
|
|
150
|
+
}
|
|
151
|
+
|
|
152
|
+
template<int LoadMode>
|
|
153
|
+
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE PacketReturnType packet(Index index) const
|
|
154
|
+
{
|
|
155
|
+
const int packetSize = PacketType<CoeffReturnType, Device>::size;
|
|
156
|
+
EIGEN_STATIC_ASSERT((packetSize > 1), YOU_MADE_A_PROGRAMMING_MISTAKE)
|
|
157
|
+
eigen_assert(index+packetSize-1 < dimensions().TotalSize());
|
|
158
|
+
|
|
159
|
+
EIGEN_ALIGN_MAX typename internal::remove_const<CoeffReturnType>::type values[packetSize];
|
|
160
|
+
for (int i = 0; i < packetSize; ++i) {
|
|
161
|
+
values[i] = coeff(index+i);
|
|
162
|
+
}
|
|
163
|
+
PacketReturnType rslt = internal::pload<PacketReturnType>(values);
|
|
164
|
+
return rslt;
|
|
165
|
+
}
|
|
166
|
+
|
|
167
|
+
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE
|
|
168
|
+
internal::TensorBlockResourceRequirements getResourceRequirements() const {
|
|
169
|
+
const size_t target_size = m_device.firstLevelCacheSize();
|
|
170
|
+
// TODO(ezhulenev): Generator should have a cost.
|
|
171
|
+
return internal::TensorBlockResourceRequirements::skewed<Scalar>(
|
|
172
|
+
target_size);
|
|
173
|
+
}
|
|
174
|
+
|
|
175
|
+
struct BlockIteratorState {
|
|
176
|
+
Index stride;
|
|
177
|
+
Index span;
|
|
178
|
+
Index size;
|
|
179
|
+
Index count;
|
|
180
|
+
};
|
|
181
|
+
|
|
182
|
+
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE TensorBlock
|
|
183
|
+
block(TensorBlockDesc& desc, TensorBlockScratch& scratch,
|
|
184
|
+
bool /*root_of_expr_ast*/ = false) const {
|
|
185
|
+
static const bool is_col_major =
|
|
186
|
+
static_cast<int>(Layout) == static_cast<int>(ColMajor);
|
|
187
|
+
|
|
188
|
+
// Compute spatial coordinates for the first block element.
|
|
189
|
+
array<Index, NumDims> coords;
|
|
190
|
+
extract_coordinates(desc.offset(), coords);
|
|
191
|
+
array<Index, NumDims> initial_coords = coords;
|
|
192
|
+
|
|
193
|
+
// Offset in the output block buffer.
|
|
194
|
+
Index offset = 0;
|
|
195
|
+
|
|
196
|
+
// Initialize output block iterator state. Dimension in this array are
|
|
197
|
+
// always in inner_most -> outer_most order (col major layout).
|
|
198
|
+
array<BlockIteratorState, NumDims> it;
|
|
199
|
+
for (int i = 0; i < NumDims; ++i) {
|
|
200
|
+
const int dim = is_col_major ? i : NumDims - 1 - i;
|
|
201
|
+
it[i].size = desc.dimension(dim);
|
|
202
|
+
it[i].stride = i == 0 ? 1 : (it[i - 1].size * it[i - 1].stride);
|
|
203
|
+
it[i].span = it[i].stride * (it[i].size - 1);
|
|
204
|
+
it[i].count = 0;
|
|
205
|
+
}
|
|
206
|
+
eigen_assert(it[0].stride == 1);
|
|
207
|
+
|
|
208
|
+
// Prepare storage for the materialized generator result.
|
|
209
|
+
const typename TensorBlock::Storage block_storage =
|
|
210
|
+
TensorBlock::prepareStorage(desc, scratch);
|
|
211
|
+
|
|
212
|
+
CoeffReturnType* block_buffer = block_storage.data();
|
|
213
|
+
|
|
214
|
+
static const int packet_size = PacketType<CoeffReturnType, Device>::size;
|
|
215
|
+
|
|
216
|
+
static const int inner_dim = is_col_major ? 0 : NumDims - 1;
|
|
217
|
+
const Index inner_dim_size = it[0].size;
|
|
218
|
+
const Index inner_dim_vectorized = inner_dim_size - packet_size;
|
|
219
|
+
|
|
220
|
+
while (it[NumDims - 1].count < it[NumDims - 1].size) {
|
|
221
|
+
Index i = 0;
|
|
222
|
+
// Generate data for the vectorized part of the inner-most dimension.
|
|
223
|
+
for (; i <= inner_dim_vectorized; i += packet_size) {
|
|
224
|
+
for (Index j = 0; j < packet_size; ++j) {
|
|
225
|
+
array<Index, NumDims> j_coords = coords; // Break loop dependence.
|
|
226
|
+
j_coords[inner_dim] += j;
|
|
227
|
+
*(block_buffer + offset + i + j) = m_generator(j_coords);
|
|
228
|
+
}
|
|
229
|
+
coords[inner_dim] += packet_size;
|
|
230
|
+
}
|
|
231
|
+
// Finalize non-vectorized part of the inner-most dimension.
|
|
232
|
+
for (; i < inner_dim_size; ++i) {
|
|
233
|
+
*(block_buffer + offset + i) = m_generator(coords);
|
|
234
|
+
coords[inner_dim]++;
|
|
235
|
+
}
|
|
236
|
+
coords[inner_dim] = initial_coords[inner_dim];
|
|
237
|
+
|
|
238
|
+
// For the 1d tensor we need to generate only one inner-most dimension.
|
|
239
|
+
if (NumDims == 1) break;
|
|
240
|
+
|
|
241
|
+
// Update offset.
|
|
242
|
+
for (i = 1; i < NumDims; ++i) {
|
|
243
|
+
if (++it[i].count < it[i].size) {
|
|
244
|
+
offset += it[i].stride;
|
|
245
|
+
coords[is_col_major ? i : NumDims - 1 - i]++;
|
|
246
|
+
break;
|
|
247
|
+
}
|
|
248
|
+
if (i != NumDims - 1) it[i].count = 0;
|
|
249
|
+
coords[is_col_major ? i : NumDims - 1 - i] =
|
|
250
|
+
initial_coords[is_col_major ? i : NumDims - 1 - i];
|
|
251
|
+
offset -= it[i].span;
|
|
252
|
+
}
|
|
253
|
+
}
|
|
254
|
+
|
|
255
|
+
return block_storage.AsTensorMaterializedBlock();
|
|
256
|
+
}
|
|
257
|
+
|
|
258
|
+
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE TensorOpCost
|
|
259
|
+
costPerCoeff(bool) const {
|
|
260
|
+
// TODO(rmlarsen): This is just a placeholder. Define interface to make
|
|
261
|
+
// generators return their cost.
|
|
262
|
+
return TensorOpCost(0, 0, TensorOpCost::AddCost<Scalar>() +
|
|
263
|
+
TensorOpCost::MulCost<Scalar>());
|
|
264
|
+
}
|
|
265
|
+
|
|
266
|
+
EIGEN_DEVICE_FUNC EvaluatorPointerType data() const { return NULL; }
|
|
267
|
+
|
|
268
|
+
#ifdef EIGEN_USE_SYCL
|
|
269
|
+
// binding placeholder accessors to a command group handler for SYCL
|
|
270
|
+
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE void bind(cl::sycl::handler&) const {}
|
|
271
|
+
#endif
|
|
272
|
+
|
|
273
|
+
protected:
|
|
274
|
+
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE
|
|
275
|
+
void extract_coordinates(Index index, array<Index, NumDims>& coords) const {
|
|
276
|
+
if (static_cast<int>(Layout) == static_cast<int>(ColMajor)) {
|
|
277
|
+
for (int i = NumDims - 1; i > 0; --i) {
|
|
278
|
+
const Index idx = index / m_fast_strides[i];
|
|
279
|
+
index -= idx * m_strides[i];
|
|
280
|
+
coords[i] = idx;
|
|
281
|
+
}
|
|
282
|
+
coords[0] = index;
|
|
283
|
+
} else {
|
|
284
|
+
for (int i = 0; i < NumDims - 1; ++i) {
|
|
285
|
+
const Index idx = index / m_fast_strides[i];
|
|
286
|
+
index -= idx * m_strides[i];
|
|
287
|
+
coords[i] = idx;
|
|
288
|
+
}
|
|
289
|
+
coords[NumDims-1] = index;
|
|
290
|
+
}
|
|
291
|
+
}
|
|
292
|
+
|
|
293
|
+
const Device EIGEN_DEVICE_REF m_device;
|
|
294
|
+
Dimensions m_dimensions;
|
|
295
|
+
array<Index, NumDims> m_strides;
|
|
296
|
+
array<IndexDivisor, NumDims> m_fast_strides;
|
|
297
|
+
Generator m_generator;
|
|
298
|
+
};
|
|
299
|
+
|
|
300
|
+
} // end namespace Eigen
|
|
301
|
+
|
|
302
|
+
#endif // EIGEN_CXX11_TENSOR_TENSOR_GENERATOR_H
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
// This file is part of Eigen, a lightweight C++ template library
|
|
2
|
+
// for linear algebra.
|
|
3
|
+
//
|
|
4
|
+
// Copyright (C) 2016 Eugene Brevdo <ebrevdo@gmail.com>
|
|
5
|
+
//
|
|
6
|
+
// This Source Code Form is subject to the terms of the Mozilla
|
|
7
|
+
// Public License v. 2.0. If a copy of the MPL was not distributed
|
|
8
|
+
// with this file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
9
|
+
|
|
10
|
+
#ifndef EIGEN_CXX11_TENSOR_TENSOR_GLOBAL_FUNCTIONS_H
|
|
11
|
+
#define EIGEN_CXX11_TENSOR_TENSOR_GLOBAL_FUNCTIONS_H
|
|
12
|
+
|
|
13
|
+
namespace Eigen {
|
|
14
|
+
|
|
15
|
+
/** \cpp11 \returns an expression of the coefficient-wise betainc(\a x, \a a, \a b) to the given tensors.
|
|
16
|
+
*
|
|
17
|
+
* This function computes the regularized incomplete beta function (integral).
|
|
18
|
+
*
|
|
19
|
+
*/
|
|
20
|
+
template <typename ADerived, typename BDerived, typename XDerived>
|
|
21
|
+
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const
|
|
22
|
+
TensorCwiseTernaryOp<internal::scalar_betainc_op<typename XDerived::Scalar>,
|
|
23
|
+
const ADerived, const BDerived, const XDerived>
|
|
24
|
+
betainc(const ADerived& a, const BDerived& b, const XDerived& x) {
|
|
25
|
+
return TensorCwiseTernaryOp<
|
|
26
|
+
internal::scalar_betainc_op<typename XDerived::Scalar>, const ADerived,
|
|
27
|
+
const BDerived, const XDerived>(
|
|
28
|
+
a, b, x, internal::scalar_betainc_op<typename XDerived::Scalar>());
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
} // end namespace Eigen
|
|
32
|
+
|
|
33
|
+
#endif // EIGEN_CXX11_TENSOR_TENSOR_GLOBAL_FUNCTIONS_H
|
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
// This file is part of Eigen, a lightweight C++ template library
|
|
2
|
+
// for linear algebra.
|
|
3
|
+
//
|
|
4
|
+
// Copyright (C) 2014 Benoit Steiner <benoit.steiner.goog@gmail.com>
|
|
5
|
+
// Copyright (C) 2018 Deven Desai <deven.desai.amd@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
|
+
#if defined(EIGEN_USE_GPU) && !defined(EIGEN_CXX11_TENSOR_GPU_HIP_CUDA_DEFINES_H)
|
|
12
|
+
#define EIGEN_CXX11_TENSOR_GPU_HIP_CUDA_DEFINES_H
|
|
13
|
+
|
|
14
|
+
// Note that we are using EIGEN_USE_HIP here instead of EIGEN_HIPCC...this is by design
|
|
15
|
+
// There is code in the Tensorflow codebase that will define EIGEN_USE_GPU, but
|
|
16
|
+
// for some reason gets sent to the gcc/host compiler instead of the gpu/nvcc/hipcc compiler
|
|
17
|
+
// When compiling such files, gcc will end up trying to pick up the CUDA headers by
|
|
18
|
+
// default (see the code within "unsupported/Eigen/CXX11/Tensor" that is guarded by EIGEN_USE_GPU)
|
|
19
|
+
// This will obviously not work when trying to compile tensorflow on a system with no CUDA
|
|
20
|
+
// To work around this issue for HIP systems (and leave the default behaviour intact), the
|
|
21
|
+
// HIP tensorflow build defines EIGEN_USE_HIP when compiling all source files, and
|
|
22
|
+
// "unsupported/Eigen/CXX11/Tensor" has been updated to use HIP header when EIGEN_USE_HIP is
|
|
23
|
+
// defined. In continuation of that requirement, the guard here needs to be EIGEN_USE_HIP as well
|
|
24
|
+
|
|
25
|
+
#if defined(EIGEN_USE_HIP)
|
|
26
|
+
|
|
27
|
+
#define gpuStream_t hipStream_t
|
|
28
|
+
#define gpuDeviceProp_t hipDeviceProp_t
|
|
29
|
+
#define gpuError_t hipError_t
|
|
30
|
+
#define gpuSuccess hipSuccess
|
|
31
|
+
#define gpuErrorNotReady hipErrorNotReady
|
|
32
|
+
#define gpuGetDeviceCount hipGetDeviceCount
|
|
33
|
+
#define gpuGetLastError hipGetLastError
|
|
34
|
+
#define gpuPeekAtLastError hipPeekAtLastError
|
|
35
|
+
#define gpuGetErrorName hipGetErrorName
|
|
36
|
+
#define gpuGetErrorString hipGetErrorString
|
|
37
|
+
#define gpuGetDeviceProperties hipGetDeviceProperties
|
|
38
|
+
#define gpuStreamDefault hipStreamDefault
|
|
39
|
+
#define gpuGetDevice hipGetDevice
|
|
40
|
+
#define gpuSetDevice hipSetDevice
|
|
41
|
+
#define gpuMalloc hipMalloc
|
|
42
|
+
#define gpuFree hipFree
|
|
43
|
+
#define gpuMemsetAsync hipMemsetAsync
|
|
44
|
+
#define gpuMemcpyAsync hipMemcpyAsync
|
|
45
|
+
#define gpuMemcpyDeviceToDevice hipMemcpyDeviceToDevice
|
|
46
|
+
#define gpuMemcpyDeviceToHost hipMemcpyDeviceToHost
|
|
47
|
+
#define gpuMemcpyHostToDevice hipMemcpyHostToDevice
|
|
48
|
+
#define gpuStreamQuery hipStreamQuery
|
|
49
|
+
#define gpuSharedMemConfig hipSharedMemConfig
|
|
50
|
+
#define gpuDeviceSetSharedMemConfig hipDeviceSetSharedMemConfig
|
|
51
|
+
#define gpuStreamSynchronize hipStreamSynchronize
|
|
52
|
+
#define gpuDeviceSynchronize hipDeviceSynchronize
|
|
53
|
+
#define gpuMemcpy hipMemcpy
|
|
54
|
+
|
|
55
|
+
#else
|
|
56
|
+
|
|
57
|
+
#define gpuStream_t cudaStream_t
|
|
58
|
+
#define gpuDeviceProp_t cudaDeviceProp
|
|
59
|
+
#define gpuError_t cudaError_t
|
|
60
|
+
#define gpuSuccess cudaSuccess
|
|
61
|
+
#define gpuErrorNotReady cudaErrorNotReady
|
|
62
|
+
#define gpuGetDeviceCount cudaGetDeviceCount
|
|
63
|
+
#define gpuGetLastError cudaGetLastError
|
|
64
|
+
#define gpuPeekAtLastError cudaPeekAtLastError
|
|
65
|
+
#define gpuGetErrorName cudaGetErrorName
|
|
66
|
+
#define gpuGetErrorString cudaGetErrorString
|
|
67
|
+
#define gpuGetDeviceProperties cudaGetDeviceProperties
|
|
68
|
+
#define gpuStreamDefault cudaStreamDefault
|
|
69
|
+
#define gpuGetDevice cudaGetDevice
|
|
70
|
+
#define gpuSetDevice cudaSetDevice
|
|
71
|
+
#define gpuMalloc cudaMalloc
|
|
72
|
+
#define gpuFree cudaFree
|
|
73
|
+
#define gpuMemsetAsync cudaMemsetAsync
|
|
74
|
+
#define gpuMemcpyAsync cudaMemcpyAsync
|
|
75
|
+
#define gpuMemcpyDeviceToDevice cudaMemcpyDeviceToDevice
|
|
76
|
+
#define gpuMemcpyDeviceToHost cudaMemcpyDeviceToHost
|
|
77
|
+
#define gpuMemcpyHostToDevice cudaMemcpyHostToDevice
|
|
78
|
+
#define gpuStreamQuery cudaStreamQuery
|
|
79
|
+
#define gpuSharedMemConfig cudaSharedMemConfig
|
|
80
|
+
#define gpuDeviceSetSharedMemConfig cudaDeviceSetSharedMemConfig
|
|
81
|
+
#define gpuStreamSynchronize cudaStreamSynchronize
|
|
82
|
+
#define gpuDeviceSynchronize cudaDeviceSynchronize
|
|
83
|
+
#define gpuMemcpy cudaMemcpy
|
|
84
|
+
|
|
85
|
+
#endif
|
|
86
|
+
|
|
87
|
+
// gpu_assert can be overridden
|
|
88
|
+
#ifndef gpu_assert
|
|
89
|
+
|
|
90
|
+
#if defined(EIGEN_HIP_DEVICE_COMPILE)
|
|
91
|
+
// HIPCC do not support the use of assert on the GPU side.
|
|
92
|
+
#define gpu_assert(COND)
|
|
93
|
+
#else
|
|
94
|
+
#define gpu_assert(COND) assert(COND)
|
|
95
|
+
#endif
|
|
96
|
+
|
|
97
|
+
#endif // gpu_assert
|
|
98
|
+
|
|
99
|
+
#endif // EIGEN_CXX11_TENSOR_GPU_HIP_CUDA_DEFINES_H
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
// This file is part of Eigen, a lightweight C++ template library
|
|
2
|
+
// for linear algebra.
|
|
3
|
+
//
|
|
4
|
+
// Copyright (C) 2014 Benoit Steiner <benoit.steiner.goog@gmail.com>
|
|
5
|
+
// Copyright (C) 2018 Deven Desai <deven.desai.amd@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
|
+
#if defined(EIGEN_CXX11_TENSOR_GPU_HIP_CUDA_DEFINES_H)
|
|
12
|
+
|
|
13
|
+
#ifndef EIGEN_PERMANENTLY_ENABLE_GPU_HIP_CUDA_DEFINES
|
|
14
|
+
|
|
15
|
+
#undef gpuStream_t
|
|
16
|
+
#undef gpuDeviceProp_t
|
|
17
|
+
#undef gpuError_t
|
|
18
|
+
#undef gpuSuccess
|
|
19
|
+
#undef gpuErrorNotReady
|
|
20
|
+
#undef gpuGetDeviceCount
|
|
21
|
+
#undef gpuGetErrorString
|
|
22
|
+
#undef gpuGetDeviceProperties
|
|
23
|
+
#undef gpuStreamDefault
|
|
24
|
+
#undef gpuGetDevice
|
|
25
|
+
#undef gpuSetDevice
|
|
26
|
+
#undef gpuMalloc
|
|
27
|
+
#undef gpuFree
|
|
28
|
+
#undef gpuMemsetAsync
|
|
29
|
+
#undef gpuMemcpyAsync
|
|
30
|
+
#undef gpuMemcpyDeviceToDevice
|
|
31
|
+
#undef gpuMemcpyDeviceToHost
|
|
32
|
+
#undef gpuMemcpyHostToDevice
|
|
33
|
+
#undef gpuStreamQuery
|
|
34
|
+
#undef gpuSharedMemConfig
|
|
35
|
+
#undef gpuDeviceSetSharedMemConfig
|
|
36
|
+
#undef gpuStreamSynchronize
|
|
37
|
+
#undef gpuDeviceSynchronize
|
|
38
|
+
#undef gpuMemcpy
|
|
39
|
+
|
|
40
|
+
#endif // EIGEN_PERMANENTLY_ENABLE_GPU_HIP_CUDA_DEFINES
|
|
41
|
+
|
|
42
|
+
#undef EIGEN_CXX11_TENSOR_GPU_HIP_CUDA_DEFINES_H
|
|
43
|
+
|
|
44
|
+
#endif // EIGEN_CXX11_TENSOR_GPU_HIP_CUDA_DEFINES_H
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
// This file is part of Eigen, a lightweight C++ template library
|
|
2
|
+
// for linear algebra.
|
|
3
|
+
//
|
|
4
|
+
// Copyright (C) 2014 Benoit Steiner <benoit.steiner.goog@gmail.com>
|
|
5
|
+
//
|
|
6
|
+
// This Source Code Form is subject to the terms of the Mozilla
|
|
7
|
+
// Public License v. 2.0. If a copy of the MPL was not distributed
|
|
8
|
+
// with this file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
9
|
+
|
|
10
|
+
#ifndef EIGEN_CXX11_TENSOR_TENSOR_IO_H
|
|
11
|
+
#define EIGEN_CXX11_TENSOR_TENSOR_IO_H
|
|
12
|
+
|
|
13
|
+
namespace Eigen {
|
|
14
|
+
|
|
15
|
+
namespace internal {
|
|
16
|
+
|
|
17
|
+
// Print the tensor as a 2d matrix
|
|
18
|
+
template <typename Tensor, int Rank>
|
|
19
|
+
struct TensorPrinter {
|
|
20
|
+
static void run (std::ostream& os, const Tensor& tensor) {
|
|
21
|
+
typedef typename internal::remove_const<typename Tensor::Scalar>::type Scalar;
|
|
22
|
+
typedef typename Tensor::Index Index;
|
|
23
|
+
const Index total_size = internal::array_prod(tensor.dimensions());
|
|
24
|
+
if (total_size > 0) {
|
|
25
|
+
const Index first_dim = Eigen::internal::array_get<0>(tensor.dimensions());
|
|
26
|
+
static const int layout = Tensor::Layout;
|
|
27
|
+
Map<const Array<Scalar, Dynamic, Dynamic, layout> > matrix(const_cast<Scalar*>(tensor.data()), first_dim, total_size/first_dim);
|
|
28
|
+
os << matrix;
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
};
|
|
32
|
+
|
|
33
|
+
|
|
34
|
+
// Print the tensor as a vector
|
|
35
|
+
template <typename Tensor>
|
|
36
|
+
struct TensorPrinter<Tensor, 1> {
|
|
37
|
+
static void run (std::ostream& os, const Tensor& tensor) {
|
|
38
|
+
typedef typename internal::remove_const<typename Tensor::Scalar>::type Scalar;
|
|
39
|
+
typedef typename Tensor::Index Index;
|
|
40
|
+
const Index total_size = internal::array_prod(tensor.dimensions());
|
|
41
|
+
if (total_size > 0) {
|
|
42
|
+
Map<const Array<Scalar, Dynamic, 1> > array(const_cast<Scalar*>(tensor.data()), total_size);
|
|
43
|
+
os << array;
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
};
|
|
47
|
+
|
|
48
|
+
|
|
49
|
+
// Print the tensor as a scalar
|
|
50
|
+
template <typename Tensor>
|
|
51
|
+
struct TensorPrinter<Tensor, 0> {
|
|
52
|
+
static void run (std::ostream& os, const Tensor& tensor) {
|
|
53
|
+
os << tensor.coeff(0);
|
|
54
|
+
}
|
|
55
|
+
};
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
template <typename T>
|
|
59
|
+
std::ostream& operator << (std::ostream& os, const TensorBase<T, ReadOnlyAccessors>& expr) {
|
|
60
|
+
typedef TensorEvaluator<const TensorForcedEvalOp<const T>, DefaultDevice> Evaluator;
|
|
61
|
+
typedef typename Evaluator::Dimensions Dimensions;
|
|
62
|
+
|
|
63
|
+
// Evaluate the expression if needed
|
|
64
|
+
TensorForcedEvalOp<const T> eval = expr.eval();
|
|
65
|
+
Evaluator tensor(eval, DefaultDevice());
|
|
66
|
+
tensor.evalSubExprsIfNeeded(NULL);
|
|
67
|
+
|
|
68
|
+
// Print the result
|
|
69
|
+
static const int rank = internal::array_size<Dimensions>::value;
|
|
70
|
+
internal::TensorPrinter<Evaluator, rank>::run(os, tensor);
|
|
71
|
+
|
|
72
|
+
// Cleanup.
|
|
73
|
+
tensor.cleanup();
|
|
74
|
+
return os;
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
} // end namespace Eigen
|
|
78
|
+
|
|
79
|
+
#endif // EIGEN_CXX11_TENSOR_TENSOR_IO_H
|