ruby-eigen 0.0.9 → 0.0.10.pre1
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.
- checksums.yaml +4 -4
- data/LICENSE +22 -0
- data/README.md +21 -0
- data/ext/eigen/eigen3/COPYING.BSD +26 -0
- data/ext/eigen/eigen3/COPYING.MPL2 +373 -0
- data/ext/eigen/eigen3/COPYING.README +18 -0
- data/ext/eigen/eigen3/Eigen/Array +11 -0
- data/ext/eigen/eigen3/Eigen/Cholesky +32 -0
- data/ext/eigen/eigen3/Eigen/CholmodSupport +45 -0
- data/ext/eigen/eigen3/Eigen/Core +376 -0
- data/ext/eigen/eigen3/Eigen/Dense +7 -0
- data/ext/eigen/eigen3/Eigen/Eigen +2 -0
- data/ext/eigen/eigen3/Eigen/Eigen2Support +95 -0
- data/ext/eigen/eigen3/Eigen/Eigenvalues +48 -0
- data/ext/eigen/eigen3/Eigen/Geometry +63 -0
- data/ext/eigen/eigen3/Eigen/Householder +23 -0
- data/ext/eigen/eigen3/Eigen/IterativeLinearSolvers +40 -0
- data/ext/eigen/eigen3/Eigen/Jacobi +26 -0
- data/ext/eigen/eigen3/Eigen/LU +41 -0
- data/ext/eigen/eigen3/Eigen/LeastSquares +32 -0
- data/ext/eigen/eigen3/Eigen/MetisSupport +28 -0
- data/ext/eigen/eigen3/Eigen/PaStiXSupport +46 -0
- data/ext/eigen/eigen3/Eigen/PardisoSupport +30 -0
- data/ext/eigen/eigen3/Eigen/QR +45 -0
- data/ext/eigen/eigen3/Eigen/QtAlignedMalloc +34 -0
- data/ext/eigen/eigen3/Eigen/SPQRSupport +29 -0
- data/ext/eigen/eigen3/Eigen/SVD +37 -0
- data/ext/eigen/eigen3/Eigen/Sparse +27 -0
- data/ext/eigen/eigen3/Eigen/SparseCore +64 -0
- data/ext/eigen/eigen3/Eigen/SparseLU +49 -0
- data/ext/eigen/eigen3/Eigen/SparseQR +33 -0
- data/ext/eigen/eigen3/Eigen/StdDeque +27 -0
- data/ext/eigen/eigen3/Eigen/StdList +26 -0
- data/ext/eigen/eigen3/Eigen/StdVector +27 -0
- data/ext/eigen/eigen3/Eigen/SuperLUSupport +59 -0
- data/ext/eigen/eigen3/Eigen/UmfPackSupport +36 -0
- data/ext/eigen/eigen3/Eigen/src/Cholesky/LDLT.h +611 -0
- data/ext/eigen/eigen3/Eigen/src/Cholesky/LLT.h +498 -0
- data/ext/eigen/eigen3/Eigen/src/Cholesky/LLT_MKL.h +102 -0
- data/ext/eigen/eigen3/Eigen/src/CholmodSupport/CholmodSupport.h +607 -0
- data/ext/eigen/eigen3/Eigen/src/Core/Array.h +323 -0
- data/ext/eigen/eigen3/Eigen/src/Core/ArrayBase.h +226 -0
- data/ext/eigen/eigen3/Eigen/src/Core/ArrayWrapper.h +264 -0
- data/ext/eigen/eigen3/Eigen/src/Core/Assign.h +590 -0
- data/ext/eigen/eigen3/Eigen/src/Core/Assign_MKL.h +224 -0
- data/ext/eigen/eigen3/Eigen/src/Core/BandMatrix.h +334 -0
- data/ext/eigen/eigen3/Eigen/src/Core/Block.h +406 -0
- data/ext/eigen/eigen3/Eigen/src/Core/BooleanRedux.h +154 -0
- data/ext/eigen/eigen3/Eigen/src/Core/CommaInitializer.h +154 -0
- data/ext/eigen/eigen3/Eigen/src/Core/CoreIterators.h +61 -0
- data/ext/eigen/eigen3/Eigen/src/Core/CwiseBinaryOp.h +230 -0
- data/ext/eigen/eigen3/Eigen/src/Core/CwiseNullaryOp.h +864 -0
- data/ext/eigen/eigen3/Eigen/src/Core/CwiseUnaryOp.h +126 -0
- data/ext/eigen/eigen3/Eigen/src/Core/CwiseUnaryView.h +139 -0
- data/ext/eigen/eigen3/Eigen/src/Core/DenseBase.h +521 -0
- data/ext/eigen/eigen3/Eigen/src/Core/DenseCoeffsBase.h +754 -0
- data/ext/eigen/eigen3/Eigen/src/Core/DenseStorage.h +434 -0
- data/ext/eigen/eigen3/Eigen/src/Core/Diagonal.h +237 -0
- data/ext/eigen/eigen3/Eigen/src/Core/DiagonalMatrix.h +313 -0
- data/ext/eigen/eigen3/Eigen/src/Core/DiagonalProduct.h +131 -0
- data/ext/eigen/eigen3/Eigen/src/Core/Dot.h +263 -0
- data/ext/eigen/eigen3/Eigen/src/Core/EigenBase.h +131 -0
- data/ext/eigen/eigen3/Eigen/src/Core/Flagged.h +140 -0
- data/ext/eigen/eigen3/Eigen/src/Core/ForceAlignedAccess.h +146 -0
- data/ext/eigen/eigen3/Eigen/src/Core/Functors.h +1026 -0
- data/ext/eigen/eigen3/Eigen/src/Core/Fuzzy.h +150 -0
- data/ext/eigen/eigen3/Eigen/src/Core/GeneralProduct.h +635 -0
- data/ext/eigen/eigen3/Eigen/src/Core/GenericPacketMath.h +350 -0
- data/ext/eigen/eigen3/Eigen/src/Core/GlobalFunctions.h +92 -0
- data/ext/eigen/eigen3/Eigen/src/Core/IO.h +250 -0
- data/ext/eigen/eigen3/Eigen/src/Core/Map.h +192 -0
- data/ext/eigen/eigen3/Eigen/src/Core/MapBase.h +247 -0
- data/ext/eigen/eigen3/Eigen/src/Core/MathFunctions.h +768 -0
- data/ext/eigen/eigen3/Eigen/src/Core/Matrix.h +420 -0
- data/ext/eigen/eigen3/Eigen/src/Core/MatrixBase.h +563 -0
- data/ext/eigen/eigen3/Eigen/src/Core/NestByValue.h +111 -0
- data/ext/eigen/eigen3/Eigen/src/Core/NoAlias.h +134 -0
- data/ext/eigen/eigen3/Eigen/src/Core/NumTraits.h +150 -0
- data/ext/eigen/eigen3/Eigen/src/Core/PermutationMatrix.h +721 -0
- data/ext/eigen/eigen3/Eigen/src/Core/PlainObjectBase.h +822 -0
- data/ext/eigen/eigen3/Eigen/src/Core/ProductBase.h +290 -0
- data/ext/eigen/eigen3/Eigen/src/Core/Random.h +152 -0
- data/ext/eigen/eigen3/Eigen/src/Core/Redux.h +409 -0
- data/ext/eigen/eigen3/Eigen/src/Core/Ref.h +278 -0
- data/ext/eigen/eigen3/Eigen/src/Core/Replicate.h +177 -0
- data/ext/eigen/eigen3/Eigen/src/Core/ReturnByValue.h +99 -0
- data/ext/eigen/eigen3/Eigen/src/Core/Reverse.h +224 -0
- data/ext/eigen/eigen3/Eigen/src/Core/Select.h +162 -0
- data/ext/eigen/eigen3/Eigen/src/Core/SelfAdjointView.h +314 -0
- data/ext/eigen/eigen3/Eigen/src/Core/SelfCwiseBinaryOp.h +191 -0
- data/ext/eigen/eigen3/Eigen/src/Core/SolveTriangular.h +260 -0
- data/ext/eigen/eigen3/Eigen/src/Core/StableNorm.h +203 -0
- data/ext/eigen/eigen3/Eigen/src/Core/Stride.h +108 -0
- data/ext/eigen/eigen3/Eigen/src/Core/Swap.h +126 -0
- data/ext/eigen/eigen3/Eigen/src/Core/Transpose.h +419 -0
- data/ext/eigen/eigen3/Eigen/src/Core/Transpositions.h +436 -0
- data/ext/eigen/eigen3/Eigen/src/Core/TriangularMatrix.h +839 -0
- data/ext/eigen/eigen3/Eigen/src/Core/VectorBlock.h +95 -0
- data/ext/eigen/eigen3/Eigen/src/Core/VectorwiseOp.h +642 -0
- data/ext/eigen/eigen3/Eigen/src/Core/Visitor.h +237 -0
- data/ext/eigen/eigen3/Eigen/src/Core/arch/AltiVec/Complex.h +217 -0
- data/ext/eigen/eigen3/Eigen/src/Core/arch/AltiVec/PacketMath.h +501 -0
- data/ext/eigen/eigen3/Eigen/src/Core/arch/Default/Settings.h +49 -0
- data/ext/eigen/eigen3/Eigen/src/Core/arch/NEON/Complex.h +253 -0
- data/ext/eigen/eigen3/Eigen/src/Core/arch/NEON/PacketMath.h +420 -0
- data/ext/eigen/eigen3/Eigen/src/Core/arch/SSE/Complex.h +442 -0
- data/ext/eigen/eigen3/Eigen/src/Core/arch/SSE/MathFunctions.h +475 -0
- data/ext/eigen/eigen3/Eigen/src/Core/arch/SSE/PacketMath.h +649 -0
- data/ext/eigen/eigen3/Eigen/src/Core/products/CoeffBasedProduct.h +476 -0
- data/ext/eigen/eigen3/Eigen/src/Core/products/GeneralBlockPanelKernel.h +1341 -0
- data/ext/eigen/eigen3/Eigen/src/Core/products/GeneralMatrixMatrix.h +427 -0
- data/ext/eigen/eigen3/Eigen/src/Core/products/GeneralMatrixMatrixTriangular.h +278 -0
- data/ext/eigen/eigen3/Eigen/src/Core/products/GeneralMatrixMatrixTriangular_MKL.h +146 -0
- data/ext/eigen/eigen3/Eigen/src/Core/products/GeneralMatrixMatrix_MKL.h +118 -0
- data/ext/eigen/eigen3/Eigen/src/Core/products/GeneralMatrixVector.h +566 -0
- data/ext/eigen/eigen3/Eigen/src/Core/products/GeneralMatrixVector_MKL.h +131 -0
- data/ext/eigen/eigen3/Eigen/src/Core/products/Parallelizer.h +162 -0
- data/ext/eigen/eigen3/Eigen/src/Core/products/SelfadjointMatrixMatrix.h +436 -0
- data/ext/eigen/eigen3/Eigen/src/Core/products/SelfadjointMatrixMatrix_MKL.h +295 -0
- data/ext/eigen/eigen3/Eigen/src/Core/products/SelfadjointMatrixVector.h +281 -0
- data/ext/eigen/eigen3/Eigen/src/Core/products/SelfadjointMatrixVector_MKL.h +114 -0
- data/ext/eigen/eigen3/Eigen/src/Core/products/SelfadjointProduct.h +123 -0
- data/ext/eigen/eigen3/Eigen/src/Core/products/SelfadjointRank2Update.h +93 -0
- data/ext/eigen/eigen3/Eigen/src/Core/products/TriangularMatrixMatrix.h +427 -0
- data/ext/eigen/eigen3/Eigen/src/Core/products/TriangularMatrixMatrix_MKL.h +309 -0
- data/ext/eigen/eigen3/Eigen/src/Core/products/TriangularMatrixVector.h +348 -0
- data/ext/eigen/eigen3/Eigen/src/Core/products/TriangularMatrixVector_MKL.h +247 -0
- data/ext/eigen/eigen3/Eigen/src/Core/products/TriangularSolverMatrix.h +332 -0
- data/ext/eigen/eigen3/Eigen/src/Core/products/TriangularSolverMatrix_MKL.h +155 -0
- data/ext/eigen/eigen3/Eigen/src/Core/products/TriangularSolverVector.h +139 -0
- data/ext/eigen/eigen3/Eigen/src/Core/util/BlasUtil.h +264 -0
- data/ext/eigen/eigen3/Eigen/src/Core/util/Constants.h +451 -0
- data/ext/eigen/eigen3/Eigen/src/Core/util/DisableStupidWarnings.h +40 -0
- data/ext/eigen/eigen3/Eigen/src/Core/util/ForwardDeclarations.h +302 -0
- data/ext/eigen/eigen3/Eigen/src/Core/util/MKL_support.h +158 -0
- data/ext/eigen/eigen3/Eigen/src/Core/util/Macros.h +451 -0
- data/ext/eigen/eigen3/Eigen/src/Core/util/Memory.h +977 -0
- data/ext/eigen/eigen3/Eigen/src/Core/util/Meta.h +243 -0
- data/ext/eigen/eigen3/Eigen/src/Core/util/NonMPL2.h +3 -0
- data/ext/eigen/eigen3/Eigen/src/Core/util/ReenableStupidWarnings.h +14 -0
- data/ext/eigen/eigen3/Eigen/src/Core/util/StaticAssert.h +208 -0
- data/ext/eigen/eigen3/Eigen/src/Core/util/XprHelper.h +469 -0
- data/ext/eigen/eigen3/Eigen/src/Eigen2Support/Block.h +126 -0
- data/ext/eigen/eigen3/Eigen/src/Eigen2Support/Cwise.h +192 -0
- data/ext/eigen/eigen3/Eigen/src/Eigen2Support/CwiseOperators.h +298 -0
- data/ext/eigen/eigen3/Eigen/src/Eigen2Support/Geometry/AlignedBox.h +159 -0
- data/ext/eigen/eigen3/Eigen/src/Eigen2Support/Geometry/All.h +115 -0
- data/ext/eigen/eigen3/Eigen/src/Eigen2Support/Geometry/AngleAxis.h +214 -0
- data/ext/eigen/eigen3/Eigen/src/Eigen2Support/Geometry/Hyperplane.h +254 -0
- data/ext/eigen/eigen3/Eigen/src/Eigen2Support/Geometry/ParametrizedLine.h +141 -0
- data/ext/eigen/eigen3/Eigen/src/Eigen2Support/Geometry/Quaternion.h +495 -0
- data/ext/eigen/eigen3/Eigen/src/Eigen2Support/Geometry/Rotation2D.h +145 -0
- data/ext/eigen/eigen3/Eigen/src/Eigen2Support/Geometry/RotationBase.h +123 -0
- data/ext/eigen/eigen3/Eigen/src/Eigen2Support/Geometry/Scaling.h +167 -0
- data/ext/eigen/eigen3/Eigen/src/Eigen2Support/Geometry/Transform.h +786 -0
- data/ext/eigen/eigen3/Eigen/src/Eigen2Support/Geometry/Translation.h +184 -0
- data/ext/eigen/eigen3/Eigen/src/Eigen2Support/LU.h +120 -0
- data/ext/eigen/eigen3/Eigen/src/Eigen2Support/Lazy.h +71 -0
- data/ext/eigen/eigen3/Eigen/src/Eigen2Support/LeastSquares.h +169 -0
- data/ext/eigen/eigen3/Eigen/src/Eigen2Support/Macros.h +20 -0
- data/ext/eigen/eigen3/Eigen/src/Eigen2Support/MathFunctions.h +57 -0
- data/ext/eigen/eigen3/Eigen/src/Eigen2Support/Memory.h +45 -0
- data/ext/eigen/eigen3/Eigen/src/Eigen2Support/Meta.h +75 -0
- data/ext/eigen/eigen3/Eigen/src/Eigen2Support/Minor.h +117 -0
- data/ext/eigen/eigen3/Eigen/src/Eigen2Support/QR.h +67 -0
- data/ext/eigen/eigen3/Eigen/src/Eigen2Support/SVD.h +637 -0
- data/ext/eigen/eigen3/Eigen/src/Eigen2Support/TriangularSolver.h +42 -0
- data/ext/eigen/eigen3/Eigen/src/Eigen2Support/VectorBlock.h +94 -0
- data/ext/eigen/eigen3/Eigen/src/Eigenvalues/ComplexEigenSolver.h +341 -0
- data/ext/eigen/eigen3/Eigen/src/Eigenvalues/ComplexSchur.h +456 -0
- data/ext/eigen/eigen3/Eigen/src/Eigenvalues/ComplexSchur_MKL.h +94 -0
- data/ext/eigen/eigen3/Eigen/src/Eigenvalues/EigenSolver.h +607 -0
- data/ext/eigen/eigen3/Eigen/src/Eigenvalues/GeneralizedEigenSolver.h +350 -0
- data/ext/eigen/eigen3/Eigen/src/Eigenvalues/GeneralizedSelfAdjointEigenSolver.h +227 -0
- data/ext/eigen/eigen3/Eigen/src/Eigenvalues/HessenbergDecomposition.h +373 -0
- data/ext/eigen/eigen3/Eigen/src/Eigenvalues/MatrixBaseEigenvalues.h +160 -0
- data/ext/eigen/eigen3/Eigen/src/Eigenvalues/RealQZ.h +624 -0
- data/ext/eigen/eigen3/Eigen/src/Eigenvalues/RealSchur.h +525 -0
- data/ext/eigen/eigen3/Eigen/src/Eigenvalues/RealSchur_MKL.h +83 -0
- data/ext/eigen/eigen3/Eigen/src/Eigenvalues/SelfAdjointEigenSolver.h +801 -0
- data/ext/eigen/eigen3/Eigen/src/Eigenvalues/SelfAdjointEigenSolver_MKL.h +92 -0
- data/ext/eigen/eigen3/Eigen/src/Eigenvalues/Tridiagonalization.h +557 -0
- data/ext/eigen/eigen3/Eigen/src/Geometry/AlignedBox.h +392 -0
- data/ext/eigen/eigen3/Eigen/src/Geometry/AngleAxis.h +233 -0
- data/ext/eigen/eigen3/Eigen/src/Geometry/EulerAngles.h +104 -0
- data/ext/eigen/eigen3/Eigen/src/Geometry/Homogeneous.h +307 -0
- data/ext/eigen/eigen3/Eigen/src/Geometry/Hyperplane.h +280 -0
- data/ext/eigen/eigen3/Eigen/src/Geometry/OrthoMethods.h +218 -0
- data/ext/eigen/eigen3/Eigen/src/Geometry/ParametrizedLine.h +195 -0
- data/ext/eigen/eigen3/Eigen/src/Geometry/Quaternion.h +776 -0
- data/ext/eigen/eigen3/Eigen/src/Geometry/Rotation2D.h +160 -0
- data/ext/eigen/eigen3/Eigen/src/Geometry/RotationBase.h +206 -0
- data/ext/eigen/eigen3/Eigen/src/Geometry/Scaling.h +166 -0
- data/ext/eigen/eigen3/Eigen/src/Geometry/Transform.h +1455 -0
- data/ext/eigen/eigen3/Eigen/src/Geometry/Translation.h +206 -0
- data/ext/eigen/eigen3/Eigen/src/Geometry/Umeyama.h +177 -0
- data/ext/eigen/eigen3/Eigen/src/Geometry/arch/Geometry_SSE.h +115 -0
- data/ext/eigen/eigen3/Eigen/src/Householder/BlockHouseholder.h +68 -0
- data/ext/eigen/eigen3/Eigen/src/Householder/Householder.h +171 -0
- data/ext/eigen/eigen3/Eigen/src/Householder/HouseholderSequence.h +441 -0
- data/ext/eigen/eigen3/Eigen/src/IterativeLinearSolvers/BasicPreconditioners.h +149 -0
- data/ext/eigen/eigen3/Eigen/src/IterativeLinearSolvers/BiCGSTAB.h +263 -0
- data/ext/eigen/eigen3/Eigen/src/IterativeLinearSolvers/ConjugateGradient.h +256 -0
- data/ext/eigen/eigen3/Eigen/src/IterativeLinearSolvers/IterativeSolverBase.h +282 -0
- data/ext/eigen/eigen3/Eigen/src/Jacobi/Jacobi.h +433 -0
- data/ext/eigen/eigen3/Eigen/src/LU/Determinant.h +101 -0
- data/ext/eigen/eigen3/Eigen/src/LU/FullPivLU.h +751 -0
- data/ext/eigen/eigen3/Eigen/src/LU/Inverse.h +400 -0
- data/ext/eigen/eigen3/Eigen/src/LU/PartialPivLU.h +509 -0
- data/ext/eigen/eigen3/Eigen/src/LU/PartialPivLU_MKL.h +85 -0
- data/ext/eigen/eigen3/Eigen/src/LU/arch/Inverse_SSE.h +329 -0
- data/ext/eigen/eigen3/Eigen/src/MetisSupport/MetisSupport.h +137 -0
- data/ext/eigen/eigen3/Eigen/src/OrderingMethods/Amd.h +444 -0
- data/ext/eigen/eigen3/Eigen/src/OrderingMethods/Eigen_Colamd.h +1850 -0
- data/ext/eigen/eigen3/Eigen/src/PaStiXSupport/PaStiXSupport.h +721 -0
- data/ext/eigen/eigen3/Eigen/src/PardisoSupport/PardisoSupport.h +592 -0
- data/ext/eigen/eigen3/Eigen/src/QR/ColPivHouseholderQR.h +580 -0
- data/ext/eigen/eigen3/Eigen/src/QR/ColPivHouseholderQR_MKL.h +99 -0
- data/ext/eigen/eigen3/Eigen/src/QR/FullPivHouseholderQR.h +622 -0
- data/ext/eigen/eigen3/Eigen/src/QR/HouseholderQR.h +388 -0
- data/ext/eigen/eigen3/Eigen/src/QR/HouseholderQR_MKL.h +71 -0
- data/ext/eigen/eigen3/Eigen/src/SPQRSupport/SuiteSparseQRSupport.h +338 -0
- data/ext/eigen/eigen3/Eigen/src/SVD/JacobiSVD.h +976 -0
- data/ext/eigen/eigen3/Eigen/src/SVD/JacobiSVD_MKL.h +92 -0
- data/ext/eigen/eigen3/Eigen/src/SVD/UpperBidiagonalization.h +148 -0
- data/ext/eigen/eigen3/Eigen/src/SparseCholesky/SimplicialCholesky.h +671 -0
- data/ext/eigen/eigen3/Eigen/src/SparseCholesky/SimplicialCholesky_impl.h +199 -0
- data/ext/eigen/eigen3/Eigen/src/SparseCore/AmbiVector.h +373 -0
- data/ext/eigen/eigen3/Eigen/src/SparseCore/CompressedStorage.h +233 -0
- data/ext/eigen/eigen3/Eigen/src/SparseCore/ConservativeSparseSparseProduct.h +245 -0
- data/ext/eigen/eigen3/Eigen/src/SparseCore/MappedSparseMatrix.h +181 -0
- data/ext/eigen/eigen3/Eigen/src/SparseCore/SparseBlock.h +537 -0
- data/ext/eigen/eigen3/Eigen/src/SparseCore/SparseColEtree.h +206 -0
- data/ext/eigen/eigen3/Eigen/src/SparseCore/SparseCwiseBinaryOp.h +325 -0
- data/ext/eigen/eigen3/Eigen/src/SparseCore/SparseCwiseUnaryOp.h +163 -0
- data/ext/eigen/eigen3/Eigen/src/SparseCore/SparseDenseProduct.h +311 -0
- data/ext/eigen/eigen3/Eigen/src/SparseCore/SparseDiagonalProduct.h +196 -0
- data/ext/eigen/eigen3/Eigen/src/SparseCore/SparseDot.h +101 -0
- data/ext/eigen/eigen3/Eigen/src/SparseCore/SparseFuzzy.h +26 -0
- data/ext/eigen/eigen3/Eigen/src/SparseCore/SparseMatrix.h +1262 -0
- data/ext/eigen/eigen3/Eigen/src/SparseCore/SparseMatrixBase.h +461 -0
- data/ext/eigen/eigen3/Eigen/src/SparseCore/SparsePermutation.h +148 -0
- data/ext/eigen/eigen3/Eigen/src/SparseCore/SparseProduct.h +188 -0
- data/ext/eigen/eigen3/Eigen/src/SparseCore/SparseRedux.h +45 -0
- data/ext/eigen/eigen3/Eigen/src/SparseCore/SparseSelfAdjointView.h +507 -0
- data/ext/eigen/eigen3/Eigen/src/SparseCore/SparseSparseProductWithPruning.h +150 -0
- data/ext/eigen/eigen3/Eigen/src/SparseCore/SparseTranspose.h +63 -0
- data/ext/eigen/eigen3/Eigen/src/SparseCore/SparseTriangularView.h +179 -0
- data/ext/eigen/eigen3/Eigen/src/SparseCore/SparseUtil.h +172 -0
- data/ext/eigen/eigen3/Eigen/src/SparseCore/SparseVector.h +448 -0
- data/ext/eigen/eigen3/Eigen/src/SparseCore/SparseView.h +99 -0
- data/ext/eigen/eigen3/Eigen/src/SparseCore/TriangularSolver.h +334 -0
- data/ext/eigen/eigen3/Eigen/src/SparseLU/SparseLU.h +806 -0
- data/ext/eigen/eigen3/Eigen/src/SparseLU/SparseLUImpl.h +66 -0
- data/ext/eigen/eigen3/Eigen/src/SparseLU/SparseLU_Memory.h +227 -0
- data/ext/eigen/eigen3/Eigen/src/SparseLU/SparseLU_Structs.h +111 -0
- data/ext/eigen/eigen3/Eigen/src/SparseLU/SparseLU_SupernodalMatrix.h +298 -0
- data/ext/eigen/eigen3/Eigen/src/SparseLU/SparseLU_Utils.h +80 -0
- data/ext/eigen/eigen3/Eigen/src/SparseLU/SparseLU_column_bmod.h +180 -0
- data/ext/eigen/eigen3/Eigen/src/SparseLU/SparseLU_column_dfs.h +177 -0
- data/ext/eigen/eigen3/Eigen/src/SparseLU/SparseLU_copy_to_ucol.h +106 -0
- data/ext/eigen/eigen3/Eigen/src/SparseLU/SparseLU_gemm_kernel.h +279 -0
- data/ext/eigen/eigen3/Eigen/src/SparseLU/SparseLU_heap_relax_snode.h +127 -0
- data/ext/eigen/eigen3/Eigen/src/SparseLU/SparseLU_kernel_bmod.h +130 -0
- data/ext/eigen/eigen3/Eigen/src/SparseLU/SparseLU_panel_bmod.h +223 -0
- data/ext/eigen/eigen3/Eigen/src/SparseLU/SparseLU_panel_dfs.h +258 -0
- data/ext/eigen/eigen3/Eigen/src/SparseLU/SparseLU_pivotL.h +137 -0
- data/ext/eigen/eigen3/Eigen/src/SparseLU/SparseLU_pruneL.h +135 -0
- data/ext/eigen/eigen3/Eigen/src/SparseLU/SparseLU_relax_snode.h +83 -0
- data/ext/eigen/eigen3/Eigen/src/SparseQR/SparseQR.h +714 -0
- data/ext/eigen/eigen3/Eigen/src/StlSupport/StdDeque.h +134 -0
- data/ext/eigen/eigen3/Eigen/src/StlSupport/StdList.h +114 -0
- data/ext/eigen/eigen3/Eigen/src/StlSupport/StdVector.h +126 -0
- data/ext/eigen/eigen3/Eigen/src/StlSupport/details.h +84 -0
- data/ext/eigen/eigen3/Eigen/src/SuperLUSupport/SuperLUSupport.h +1026 -0
- data/ext/eigen/eigen3/Eigen/src/UmfPackSupport/UmfPackSupport.h +474 -0
- data/ext/eigen/eigen3/Eigen/src/misc/Image.h +84 -0
- data/ext/eigen/eigen3/Eigen/src/misc/Kernel.h +81 -0
- data/ext/eigen/eigen3/Eigen/src/misc/Solve.h +76 -0
- data/ext/eigen/eigen3/Eigen/src/misc/SparseSolve.h +128 -0
- data/ext/eigen/eigen3/Eigen/src/misc/blas.h +658 -0
- data/ext/eigen/eigen3/Eigen/src/plugins/ArrayCwiseBinaryOps.h +253 -0
- data/ext/eigen/eigen3/Eigen/src/plugins/ArrayCwiseUnaryOps.h +187 -0
- data/ext/eigen/eigen3/Eigen/src/plugins/BlockMethods.h +935 -0
- data/ext/eigen/eigen3/Eigen/src/plugins/CommonCwiseBinaryOps.h +46 -0
- data/ext/eigen/eigen3/Eigen/src/plugins/CommonCwiseUnaryOps.h +172 -0
- data/ext/eigen/eigen3/Eigen/src/plugins/MatrixCwiseBinaryOps.h +143 -0
- data/ext/eigen/eigen3/Eigen/src/plugins/MatrixCwiseUnaryOps.h +52 -0
- data/ext/eigen/eigen3/signature_of_eigen3_matrix_library +1 -0
- data/ext/eigen/eigen_wrap.cxx +19420 -10396
- data/ext/eigen/extconf.rb +37 -2
- data/lib/eigen.rb +146 -3
- metadata +294 -7
|
@@ -0,0 +1,302 @@
|
|
|
1
|
+
// This file is part of Eigen, a lightweight C++ template library
|
|
2
|
+
// for linear algebra.
|
|
3
|
+
//
|
|
4
|
+
// Copyright (C) 2007-2010 Benoit Jacob <jacob.benoit.1@gmail.com>
|
|
5
|
+
// Copyright (C) 2008-2009 Gael Guennebaud <gael.guennebaud@inria.fr>
|
|
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
|
+
#ifndef EIGEN_FORWARDDECLARATIONS_H
|
|
12
|
+
#define EIGEN_FORWARDDECLARATIONS_H
|
|
13
|
+
|
|
14
|
+
namespace Eigen {
|
|
15
|
+
namespace internal {
|
|
16
|
+
|
|
17
|
+
template<typename T> struct traits;
|
|
18
|
+
|
|
19
|
+
// here we say once and for all that traits<const T> == traits<T>
|
|
20
|
+
// When constness must affect traits, it has to be constness on template parameters on which T itself depends.
|
|
21
|
+
// For example, traits<Map<const T> > != traits<Map<T> >, but
|
|
22
|
+
// traits<const Map<T> > == traits<Map<T> >
|
|
23
|
+
template<typename T> struct traits<const T> : traits<T> {};
|
|
24
|
+
|
|
25
|
+
template<typename Derived> struct has_direct_access
|
|
26
|
+
{
|
|
27
|
+
enum { ret = (traits<Derived>::Flags & DirectAccessBit) ? 1 : 0 };
|
|
28
|
+
};
|
|
29
|
+
|
|
30
|
+
template<typename Derived> struct accessors_level
|
|
31
|
+
{
|
|
32
|
+
enum { has_direct_access = (traits<Derived>::Flags & DirectAccessBit) ? 1 : 0,
|
|
33
|
+
has_write_access = (traits<Derived>::Flags & LvalueBit) ? 1 : 0,
|
|
34
|
+
value = has_direct_access ? (has_write_access ? DirectWriteAccessors : DirectAccessors)
|
|
35
|
+
: (has_write_access ? WriteAccessors : ReadOnlyAccessors)
|
|
36
|
+
};
|
|
37
|
+
};
|
|
38
|
+
|
|
39
|
+
} // end namespace internal
|
|
40
|
+
|
|
41
|
+
template<typename T> struct NumTraits;
|
|
42
|
+
|
|
43
|
+
template<typename Derived> struct EigenBase;
|
|
44
|
+
template<typename Derived> class DenseBase;
|
|
45
|
+
template<typename Derived> class PlainObjectBase;
|
|
46
|
+
|
|
47
|
+
|
|
48
|
+
template<typename Derived,
|
|
49
|
+
int Level = internal::accessors_level<Derived>::value >
|
|
50
|
+
class DenseCoeffsBase;
|
|
51
|
+
|
|
52
|
+
template<typename _Scalar, int _Rows, int _Cols,
|
|
53
|
+
int _Options = AutoAlign |
|
|
54
|
+
#if defined(__GNUC__) && __GNUC__==3 && __GNUC_MINOR__==4
|
|
55
|
+
// workaround a bug in at least gcc 3.4.6
|
|
56
|
+
// the innermost ?: ternary operator is misparsed. We write it slightly
|
|
57
|
+
// differently and this makes gcc 3.4.6 happy, but it's ugly.
|
|
58
|
+
// The error would only show up with EIGEN_DEFAULT_TO_ROW_MAJOR is defined
|
|
59
|
+
// (when EIGEN_DEFAULT_MATRIX_STORAGE_ORDER_OPTION is RowMajor)
|
|
60
|
+
( (_Rows==1 && _Cols!=1) ? RowMajor
|
|
61
|
+
: !(_Cols==1 && _Rows!=1) ? EIGEN_DEFAULT_MATRIX_STORAGE_ORDER_OPTION
|
|
62
|
+
: ColMajor ),
|
|
63
|
+
#else
|
|
64
|
+
( (_Rows==1 && _Cols!=1) ? RowMajor
|
|
65
|
+
: (_Cols==1 && _Rows!=1) ? ColMajor
|
|
66
|
+
: EIGEN_DEFAULT_MATRIX_STORAGE_ORDER_OPTION ),
|
|
67
|
+
#endif
|
|
68
|
+
int _MaxRows = _Rows,
|
|
69
|
+
int _MaxCols = _Cols
|
|
70
|
+
> class Matrix;
|
|
71
|
+
|
|
72
|
+
template<typename Derived> class MatrixBase;
|
|
73
|
+
template<typename Derived> class ArrayBase;
|
|
74
|
+
|
|
75
|
+
template<typename ExpressionType, unsigned int Added, unsigned int Removed> class Flagged;
|
|
76
|
+
template<typename ExpressionType, template <typename> class StorageBase > class NoAlias;
|
|
77
|
+
template<typename ExpressionType> class NestByValue;
|
|
78
|
+
template<typename ExpressionType> class ForceAlignedAccess;
|
|
79
|
+
template<typename ExpressionType> class SwapWrapper;
|
|
80
|
+
|
|
81
|
+
template<typename XprType, int BlockRows=Dynamic, int BlockCols=Dynamic, bool InnerPanel = false> class Block;
|
|
82
|
+
|
|
83
|
+
template<typename MatrixType, int Size=Dynamic> class VectorBlock;
|
|
84
|
+
template<typename MatrixType> class Transpose;
|
|
85
|
+
template<typename MatrixType> class Conjugate;
|
|
86
|
+
template<typename NullaryOp, typename MatrixType> class CwiseNullaryOp;
|
|
87
|
+
template<typename UnaryOp, typename MatrixType> class CwiseUnaryOp;
|
|
88
|
+
template<typename ViewOp, typename MatrixType> class CwiseUnaryView;
|
|
89
|
+
template<typename BinaryOp, typename Lhs, typename Rhs> class CwiseBinaryOp;
|
|
90
|
+
template<typename BinOp, typename Lhs, typename Rhs> class SelfCwiseBinaryOp;
|
|
91
|
+
template<typename Derived, typename Lhs, typename Rhs> class ProductBase;
|
|
92
|
+
template<typename Lhs, typename Rhs, int Mode> class GeneralProduct;
|
|
93
|
+
template<typename Lhs, typename Rhs, int NestingFlags> class CoeffBasedProduct;
|
|
94
|
+
|
|
95
|
+
template<typename Derived> class DiagonalBase;
|
|
96
|
+
template<typename _DiagonalVectorType> class DiagonalWrapper;
|
|
97
|
+
template<typename _Scalar, int SizeAtCompileTime, int MaxSizeAtCompileTime=SizeAtCompileTime> class DiagonalMatrix;
|
|
98
|
+
template<typename MatrixType, typename DiagonalType, int ProductOrder> class DiagonalProduct;
|
|
99
|
+
template<typename MatrixType, int Index = 0> class Diagonal;
|
|
100
|
+
template<int SizeAtCompileTime, int MaxSizeAtCompileTime = SizeAtCompileTime, typename IndexType=int> class PermutationMatrix;
|
|
101
|
+
template<int SizeAtCompileTime, int MaxSizeAtCompileTime = SizeAtCompileTime, typename IndexType=int> class Transpositions;
|
|
102
|
+
template<typename Derived> class PermutationBase;
|
|
103
|
+
template<typename Derived> class TranspositionsBase;
|
|
104
|
+
template<typename _IndicesType> class PermutationWrapper;
|
|
105
|
+
template<typename _IndicesType> class TranspositionsWrapper;
|
|
106
|
+
|
|
107
|
+
template<typename Derived,
|
|
108
|
+
int Level = internal::accessors_level<Derived>::has_write_access ? WriteAccessors : ReadOnlyAccessors
|
|
109
|
+
> class MapBase;
|
|
110
|
+
template<int InnerStrideAtCompileTime, int OuterStrideAtCompileTime> class Stride;
|
|
111
|
+
template<typename MatrixType, int MapOptions=Unaligned, typename StrideType = Stride<0,0> > class Map;
|
|
112
|
+
|
|
113
|
+
template<typename Derived> class TriangularBase;
|
|
114
|
+
template<typename MatrixType, unsigned int Mode> class TriangularView;
|
|
115
|
+
template<typename MatrixType, unsigned int Mode> class SelfAdjointView;
|
|
116
|
+
template<typename MatrixType> class SparseView;
|
|
117
|
+
template<typename ExpressionType> class WithFormat;
|
|
118
|
+
template<typename MatrixType> struct CommaInitializer;
|
|
119
|
+
template<typename Derived> class ReturnByValue;
|
|
120
|
+
template<typename ExpressionType> class ArrayWrapper;
|
|
121
|
+
template<typename ExpressionType> class MatrixWrapper;
|
|
122
|
+
|
|
123
|
+
namespace internal {
|
|
124
|
+
template<typename DecompositionType, typename Rhs> struct solve_retval_base;
|
|
125
|
+
template<typename DecompositionType, typename Rhs> struct solve_retval;
|
|
126
|
+
template<typename DecompositionType> struct kernel_retval_base;
|
|
127
|
+
template<typename DecompositionType> struct kernel_retval;
|
|
128
|
+
template<typename DecompositionType> struct image_retval_base;
|
|
129
|
+
template<typename DecompositionType> struct image_retval;
|
|
130
|
+
} // end namespace internal
|
|
131
|
+
|
|
132
|
+
namespace internal {
|
|
133
|
+
template<typename _Scalar, int Rows=Dynamic, int Cols=Dynamic, int Supers=Dynamic, int Subs=Dynamic, int Options=0> class BandMatrix;
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
namespace internal {
|
|
137
|
+
template<typename Lhs, typename Rhs> struct product_type;
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
template<typename Lhs, typename Rhs,
|
|
141
|
+
int ProductType = internal::product_type<Lhs,Rhs>::value>
|
|
142
|
+
struct ProductReturnType;
|
|
143
|
+
|
|
144
|
+
// this is a workaround for sun CC
|
|
145
|
+
template<typename Lhs, typename Rhs> struct LazyProductReturnType;
|
|
146
|
+
|
|
147
|
+
namespace internal {
|
|
148
|
+
|
|
149
|
+
// Provides scalar/packet-wise product and product with accumulation
|
|
150
|
+
// with optional conjugation of the arguments.
|
|
151
|
+
template<typename LhsScalar, typename RhsScalar, bool ConjLhs=false, bool ConjRhs=false> struct conj_helper;
|
|
152
|
+
|
|
153
|
+
template<typename Scalar> struct scalar_sum_op;
|
|
154
|
+
template<typename Scalar> struct scalar_difference_op;
|
|
155
|
+
template<typename LhsScalar,typename RhsScalar> struct scalar_conj_product_op;
|
|
156
|
+
template<typename Scalar> struct scalar_opposite_op;
|
|
157
|
+
template<typename Scalar> struct scalar_conjugate_op;
|
|
158
|
+
template<typename Scalar> struct scalar_real_op;
|
|
159
|
+
template<typename Scalar> struct scalar_imag_op;
|
|
160
|
+
template<typename Scalar> struct scalar_abs_op;
|
|
161
|
+
template<typename Scalar> struct scalar_abs2_op;
|
|
162
|
+
template<typename Scalar> struct scalar_sqrt_op;
|
|
163
|
+
template<typename Scalar> struct scalar_exp_op;
|
|
164
|
+
template<typename Scalar> struct scalar_log_op;
|
|
165
|
+
template<typename Scalar> struct scalar_cos_op;
|
|
166
|
+
template<typename Scalar> struct scalar_sin_op;
|
|
167
|
+
template<typename Scalar> struct scalar_acos_op;
|
|
168
|
+
template<typename Scalar> struct scalar_asin_op;
|
|
169
|
+
template<typename Scalar> struct scalar_tan_op;
|
|
170
|
+
template<typename Scalar> struct scalar_pow_op;
|
|
171
|
+
template<typename Scalar> struct scalar_inverse_op;
|
|
172
|
+
template<typename Scalar> struct scalar_square_op;
|
|
173
|
+
template<typename Scalar> struct scalar_cube_op;
|
|
174
|
+
template<typename Scalar, typename NewType> struct scalar_cast_op;
|
|
175
|
+
template<typename Scalar> struct scalar_multiple_op;
|
|
176
|
+
template<typename Scalar> struct scalar_quotient1_op;
|
|
177
|
+
template<typename Scalar> struct scalar_min_op;
|
|
178
|
+
template<typename Scalar> struct scalar_max_op;
|
|
179
|
+
template<typename Scalar> struct scalar_random_op;
|
|
180
|
+
template<typename Scalar> struct scalar_add_op;
|
|
181
|
+
template<typename Scalar> struct scalar_constant_op;
|
|
182
|
+
template<typename Scalar> struct scalar_identity_op;
|
|
183
|
+
|
|
184
|
+
template<typename LhsScalar,typename RhsScalar=LhsScalar> struct scalar_product_op;
|
|
185
|
+
template<typename LhsScalar,typename RhsScalar> struct scalar_multiple2_op;
|
|
186
|
+
template<typename LhsScalar,typename RhsScalar=LhsScalar> struct scalar_quotient_op;
|
|
187
|
+
|
|
188
|
+
} // end namespace internal
|
|
189
|
+
|
|
190
|
+
struct IOFormat;
|
|
191
|
+
|
|
192
|
+
// Array module
|
|
193
|
+
template<typename _Scalar, int _Rows, int _Cols,
|
|
194
|
+
int _Options = AutoAlign |
|
|
195
|
+
#if defined(__GNUC__) && __GNUC__==3 && __GNUC_MINOR__==4
|
|
196
|
+
// workaround a bug in at least gcc 3.4.6
|
|
197
|
+
// the innermost ?: ternary operator is misparsed. We write it slightly
|
|
198
|
+
// differently and this makes gcc 3.4.6 happy, but it's ugly.
|
|
199
|
+
// The error would only show up with EIGEN_DEFAULT_TO_ROW_MAJOR is defined
|
|
200
|
+
// (when EIGEN_DEFAULT_MATRIX_STORAGE_ORDER_OPTION is RowMajor)
|
|
201
|
+
( (_Rows==1 && _Cols!=1) ? RowMajor
|
|
202
|
+
: !(_Cols==1 && _Rows!=1) ? EIGEN_DEFAULT_MATRIX_STORAGE_ORDER_OPTION
|
|
203
|
+
: ColMajor ),
|
|
204
|
+
#else
|
|
205
|
+
( (_Rows==1 && _Cols!=1) ? RowMajor
|
|
206
|
+
: (_Cols==1 && _Rows!=1) ? ColMajor
|
|
207
|
+
: EIGEN_DEFAULT_MATRIX_STORAGE_ORDER_OPTION ),
|
|
208
|
+
#endif
|
|
209
|
+
int _MaxRows = _Rows, int _MaxCols = _Cols> class Array;
|
|
210
|
+
template<typename ConditionMatrixType, typename ThenMatrixType, typename ElseMatrixType> class Select;
|
|
211
|
+
template<typename MatrixType, typename BinaryOp, int Direction> class PartialReduxExpr;
|
|
212
|
+
template<typename ExpressionType, int Direction> class VectorwiseOp;
|
|
213
|
+
template<typename MatrixType,int RowFactor,int ColFactor> class Replicate;
|
|
214
|
+
template<typename MatrixType, int Direction = BothDirections> class Reverse;
|
|
215
|
+
|
|
216
|
+
template<typename MatrixType> class FullPivLU;
|
|
217
|
+
template<typename MatrixType> class PartialPivLU;
|
|
218
|
+
namespace internal {
|
|
219
|
+
template<typename MatrixType> struct inverse_impl;
|
|
220
|
+
}
|
|
221
|
+
template<typename MatrixType> class HouseholderQR;
|
|
222
|
+
template<typename MatrixType> class ColPivHouseholderQR;
|
|
223
|
+
template<typename MatrixType> class FullPivHouseholderQR;
|
|
224
|
+
template<typename MatrixType, int QRPreconditioner = ColPivHouseholderQRPreconditioner> class JacobiSVD;
|
|
225
|
+
template<typename MatrixType, int UpLo = Lower> class LLT;
|
|
226
|
+
template<typename MatrixType, int UpLo = Lower> class LDLT;
|
|
227
|
+
template<typename VectorsType, typename CoeffsType, int Side=OnTheLeft> class HouseholderSequence;
|
|
228
|
+
template<typename Scalar> class JacobiRotation;
|
|
229
|
+
|
|
230
|
+
// Geometry module:
|
|
231
|
+
template<typename Derived, int _Dim> class RotationBase;
|
|
232
|
+
template<typename Lhs, typename Rhs> class Cross;
|
|
233
|
+
template<typename Derived> class QuaternionBase;
|
|
234
|
+
template<typename Scalar> class Rotation2D;
|
|
235
|
+
template<typename Scalar> class AngleAxis;
|
|
236
|
+
template<typename Scalar,int Dim> class Translation;
|
|
237
|
+
|
|
238
|
+
// Sparse module:
|
|
239
|
+
template<typename Derived> class SparseMatrixBase;
|
|
240
|
+
|
|
241
|
+
#ifdef EIGEN2_SUPPORT
|
|
242
|
+
template<typename Derived, int _Dim> class eigen2_RotationBase;
|
|
243
|
+
template<typename Lhs, typename Rhs> class eigen2_Cross;
|
|
244
|
+
template<typename Scalar> class eigen2_Quaternion;
|
|
245
|
+
template<typename Scalar> class eigen2_Rotation2D;
|
|
246
|
+
template<typename Scalar> class eigen2_AngleAxis;
|
|
247
|
+
template<typename Scalar,int Dim> class eigen2_Transform;
|
|
248
|
+
template <typename _Scalar, int _AmbientDim> class eigen2_ParametrizedLine;
|
|
249
|
+
template <typename _Scalar, int _AmbientDim> class eigen2_Hyperplane;
|
|
250
|
+
template<typename Scalar,int Dim> class eigen2_Translation;
|
|
251
|
+
template<typename Scalar,int Dim> class eigen2_Scaling;
|
|
252
|
+
#endif
|
|
253
|
+
|
|
254
|
+
#if EIGEN2_SUPPORT_STAGE < STAGE20_RESOLVE_API_CONFLICTS
|
|
255
|
+
template<typename Scalar> class Quaternion;
|
|
256
|
+
template<typename Scalar,int Dim> class Transform;
|
|
257
|
+
template <typename _Scalar, int _AmbientDim> class ParametrizedLine;
|
|
258
|
+
template <typename _Scalar, int _AmbientDim> class Hyperplane;
|
|
259
|
+
template<typename Scalar,int Dim> class Scaling;
|
|
260
|
+
#endif
|
|
261
|
+
|
|
262
|
+
#if EIGEN2_SUPPORT_STAGE > STAGE20_RESOLVE_API_CONFLICTS
|
|
263
|
+
template<typename Scalar, int Options = AutoAlign> class Quaternion;
|
|
264
|
+
template<typename Scalar,int Dim,int Mode,int _Options=AutoAlign> class Transform;
|
|
265
|
+
template <typename _Scalar, int _AmbientDim, int Options=AutoAlign> class ParametrizedLine;
|
|
266
|
+
template <typename _Scalar, int _AmbientDim, int Options=AutoAlign> class Hyperplane;
|
|
267
|
+
template<typename Scalar> class UniformScaling;
|
|
268
|
+
template<typename MatrixType,int Direction> class Homogeneous;
|
|
269
|
+
#endif
|
|
270
|
+
|
|
271
|
+
// MatrixFunctions module
|
|
272
|
+
template<typename Derived> struct MatrixExponentialReturnValue;
|
|
273
|
+
template<typename Derived> class MatrixFunctionReturnValue;
|
|
274
|
+
template<typename Derived> class MatrixSquareRootReturnValue;
|
|
275
|
+
template<typename Derived> class MatrixLogarithmReturnValue;
|
|
276
|
+
template<typename Derived> class MatrixPowerReturnValue;
|
|
277
|
+
template<typename Derived, typename Lhs, typename Rhs> class MatrixPowerProduct;
|
|
278
|
+
|
|
279
|
+
namespace internal {
|
|
280
|
+
template <typename Scalar>
|
|
281
|
+
struct stem_function
|
|
282
|
+
{
|
|
283
|
+
typedef std::complex<typename NumTraits<Scalar>::Real> ComplexScalar;
|
|
284
|
+
typedef ComplexScalar type(ComplexScalar, int);
|
|
285
|
+
};
|
|
286
|
+
}
|
|
287
|
+
|
|
288
|
+
|
|
289
|
+
#ifdef EIGEN2_SUPPORT
|
|
290
|
+
template<typename ExpressionType> class Cwise;
|
|
291
|
+
template<typename MatrixType> class Minor;
|
|
292
|
+
template<typename MatrixType> class LU;
|
|
293
|
+
template<typename MatrixType> class QR;
|
|
294
|
+
template<typename MatrixType> class SVD;
|
|
295
|
+
namespace internal {
|
|
296
|
+
template<typename MatrixType, unsigned int Mode> struct eigen2_part_return_type;
|
|
297
|
+
}
|
|
298
|
+
#endif
|
|
299
|
+
|
|
300
|
+
} // end namespace Eigen
|
|
301
|
+
|
|
302
|
+
#endif // EIGEN_FORWARDDECLARATIONS_H
|
|
@@ -0,0 +1,158 @@
|
|
|
1
|
+
/*
|
|
2
|
+
Copyright (c) 2011, Intel Corporation. All rights reserved.
|
|
3
|
+
|
|
4
|
+
Redistribution and use in source and binary forms, with or without modification,
|
|
5
|
+
are permitted provided that the following conditions are met:
|
|
6
|
+
|
|
7
|
+
* Redistributions of source code must retain the above copyright notice, this
|
|
8
|
+
list of conditions and the following disclaimer.
|
|
9
|
+
* Redistributions in binary form must reproduce the above copyright notice,
|
|
10
|
+
this list of conditions and the following disclaimer in the documentation
|
|
11
|
+
and/or other materials provided with the distribution.
|
|
12
|
+
* Neither the name of Intel Corporation nor the names of its contributors may
|
|
13
|
+
be used to endorse or promote products derived from this software without
|
|
14
|
+
specific prior written permission.
|
|
15
|
+
|
|
16
|
+
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
|
17
|
+
ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
|
18
|
+
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|
19
|
+
DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
|
|
20
|
+
ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
|
21
|
+
(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
|
22
|
+
LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
|
23
|
+
ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
24
|
+
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
|
25
|
+
SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
26
|
+
|
|
27
|
+
********************************************************************************
|
|
28
|
+
* Content : Eigen bindings to Intel(R) MKL
|
|
29
|
+
* Include file with common MKL declarations
|
|
30
|
+
********************************************************************************
|
|
31
|
+
*/
|
|
32
|
+
|
|
33
|
+
#ifndef EIGEN_MKL_SUPPORT_H
|
|
34
|
+
#define EIGEN_MKL_SUPPORT_H
|
|
35
|
+
|
|
36
|
+
#ifdef EIGEN_USE_MKL_ALL
|
|
37
|
+
#ifndef EIGEN_USE_BLAS
|
|
38
|
+
#define EIGEN_USE_BLAS
|
|
39
|
+
#endif
|
|
40
|
+
#ifndef EIGEN_USE_LAPACKE
|
|
41
|
+
#define EIGEN_USE_LAPACKE
|
|
42
|
+
#endif
|
|
43
|
+
#ifndef EIGEN_USE_MKL_VML
|
|
44
|
+
#define EIGEN_USE_MKL_VML
|
|
45
|
+
#endif
|
|
46
|
+
#endif
|
|
47
|
+
|
|
48
|
+
#ifdef EIGEN_USE_LAPACKE_STRICT
|
|
49
|
+
#define EIGEN_USE_LAPACKE
|
|
50
|
+
#endif
|
|
51
|
+
|
|
52
|
+
#if defined(EIGEN_USE_BLAS) || defined(EIGEN_USE_LAPACKE) || defined(EIGEN_USE_MKL_VML)
|
|
53
|
+
#define EIGEN_USE_MKL
|
|
54
|
+
#endif
|
|
55
|
+
|
|
56
|
+
#if defined EIGEN_USE_MKL
|
|
57
|
+
# include <mkl.h>
|
|
58
|
+
/*Check IMKL version for compatibility: < 10.3 is not usable with Eigen*/
|
|
59
|
+
# ifndef INTEL_MKL_VERSION
|
|
60
|
+
# undef EIGEN_USE_MKL /* INTEL_MKL_VERSION is not even defined on older versions */
|
|
61
|
+
# elif INTEL_MKL_VERSION < 100305 /* the intel-mkl-103-release-notes say this was when the lapacke.h interface was added*/
|
|
62
|
+
# undef EIGEN_USE_MKL
|
|
63
|
+
# endif
|
|
64
|
+
# ifndef EIGEN_USE_MKL
|
|
65
|
+
/*If the MKL version is too old, undef everything*/
|
|
66
|
+
# undef EIGEN_USE_MKL_ALL
|
|
67
|
+
# undef EIGEN_USE_BLAS
|
|
68
|
+
# undef EIGEN_USE_LAPACKE
|
|
69
|
+
# undef EIGEN_USE_MKL_VML
|
|
70
|
+
# undef EIGEN_USE_LAPACKE_STRICT
|
|
71
|
+
# undef EIGEN_USE_LAPACKE
|
|
72
|
+
# endif
|
|
73
|
+
#endif
|
|
74
|
+
|
|
75
|
+
#if defined EIGEN_USE_MKL
|
|
76
|
+
#include <mkl_lapacke.h>
|
|
77
|
+
#define EIGEN_MKL_VML_THRESHOLD 128
|
|
78
|
+
|
|
79
|
+
/* MKL_DOMAIN_BLAS, etc are defined only in 10.3 update 7 */
|
|
80
|
+
/* MKL_BLAS, etc are not defined in 11.2 */
|
|
81
|
+
#ifdef MKL_DOMAIN_ALL
|
|
82
|
+
#define EIGEN_MKL_DOMAIN_ALL MKL_DOMAIN_ALL
|
|
83
|
+
#else
|
|
84
|
+
#define EIGEN_MKL_DOMAIN_ALL MKL_ALL
|
|
85
|
+
#endif
|
|
86
|
+
|
|
87
|
+
#ifdef MKL_DOMAIN_BLAS
|
|
88
|
+
#define EIGEN_MKL_DOMAIN_BLAS MKL_DOMAIN_BLAS
|
|
89
|
+
#else
|
|
90
|
+
#define EIGEN_MKL_DOMAIN_BLAS MKL_BLAS
|
|
91
|
+
#endif
|
|
92
|
+
|
|
93
|
+
#ifdef MKL_DOMAIN_FFT
|
|
94
|
+
#define EIGEN_MKL_DOMAIN_FFT MKL_DOMAIN_FFT
|
|
95
|
+
#else
|
|
96
|
+
#define EIGEN_MKL_DOMAIN_FFT MKL_FFT
|
|
97
|
+
#endif
|
|
98
|
+
|
|
99
|
+
#ifdef MKL_DOMAIN_VML
|
|
100
|
+
#define EIGEN_MKL_DOMAIN_VML MKL_DOMAIN_VML
|
|
101
|
+
#else
|
|
102
|
+
#define EIGEN_MKL_DOMAIN_VML MKL_VML
|
|
103
|
+
#endif
|
|
104
|
+
|
|
105
|
+
#ifdef MKL_DOMAIN_PARDISO
|
|
106
|
+
#define EIGEN_MKL_DOMAIN_PARDISO MKL_DOMAIN_PARDISO
|
|
107
|
+
#else
|
|
108
|
+
#define EIGEN_MKL_DOMAIN_PARDISO MKL_PARDISO
|
|
109
|
+
#endif
|
|
110
|
+
|
|
111
|
+
namespace Eigen {
|
|
112
|
+
|
|
113
|
+
typedef std::complex<double> dcomplex;
|
|
114
|
+
typedef std::complex<float> scomplex;
|
|
115
|
+
|
|
116
|
+
namespace internal {
|
|
117
|
+
|
|
118
|
+
template<typename MKLType, typename EigenType>
|
|
119
|
+
static inline void assign_scalar_eig2mkl(MKLType& mklScalar, const EigenType& eigenScalar) {
|
|
120
|
+
mklScalar=eigenScalar;
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
template<typename MKLType, typename EigenType>
|
|
124
|
+
static inline void assign_conj_scalar_eig2mkl(MKLType& mklScalar, const EigenType& eigenScalar) {
|
|
125
|
+
mklScalar=eigenScalar;
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
template <>
|
|
129
|
+
inline void assign_scalar_eig2mkl<MKL_Complex16,dcomplex>(MKL_Complex16& mklScalar, const dcomplex& eigenScalar) {
|
|
130
|
+
mklScalar.real=eigenScalar.real();
|
|
131
|
+
mklScalar.imag=eigenScalar.imag();
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
template <>
|
|
135
|
+
inline void assign_scalar_eig2mkl<MKL_Complex8,scomplex>(MKL_Complex8& mklScalar, const scomplex& eigenScalar) {
|
|
136
|
+
mklScalar.real=eigenScalar.real();
|
|
137
|
+
mklScalar.imag=eigenScalar.imag();
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
template <>
|
|
141
|
+
inline void assign_conj_scalar_eig2mkl<MKL_Complex16,dcomplex>(MKL_Complex16& mklScalar, const dcomplex& eigenScalar) {
|
|
142
|
+
mklScalar.real=eigenScalar.real();
|
|
143
|
+
mklScalar.imag=-eigenScalar.imag();
|
|
144
|
+
}
|
|
145
|
+
|
|
146
|
+
template <>
|
|
147
|
+
inline void assign_conj_scalar_eig2mkl<MKL_Complex8,scomplex>(MKL_Complex8& mklScalar, const scomplex& eigenScalar) {
|
|
148
|
+
mklScalar.real=eigenScalar.real();
|
|
149
|
+
mklScalar.imag=-eigenScalar.imag();
|
|
150
|
+
}
|
|
151
|
+
|
|
152
|
+
} // end namespace internal
|
|
153
|
+
|
|
154
|
+
} // end namespace Eigen
|
|
155
|
+
|
|
156
|
+
#endif
|
|
157
|
+
|
|
158
|
+
#endif // EIGEN_MKL_SUPPORT_H
|