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.
Files changed (293) hide show
  1. checksums.yaml +4 -4
  2. data/LICENSE +22 -0
  3. data/README.md +21 -0
  4. data/ext/eigen/eigen3/COPYING.BSD +26 -0
  5. data/ext/eigen/eigen3/COPYING.MPL2 +373 -0
  6. data/ext/eigen/eigen3/COPYING.README +18 -0
  7. data/ext/eigen/eigen3/Eigen/Array +11 -0
  8. data/ext/eigen/eigen3/Eigen/Cholesky +32 -0
  9. data/ext/eigen/eigen3/Eigen/CholmodSupport +45 -0
  10. data/ext/eigen/eigen3/Eigen/Core +376 -0
  11. data/ext/eigen/eigen3/Eigen/Dense +7 -0
  12. data/ext/eigen/eigen3/Eigen/Eigen +2 -0
  13. data/ext/eigen/eigen3/Eigen/Eigen2Support +95 -0
  14. data/ext/eigen/eigen3/Eigen/Eigenvalues +48 -0
  15. data/ext/eigen/eigen3/Eigen/Geometry +63 -0
  16. data/ext/eigen/eigen3/Eigen/Householder +23 -0
  17. data/ext/eigen/eigen3/Eigen/IterativeLinearSolvers +40 -0
  18. data/ext/eigen/eigen3/Eigen/Jacobi +26 -0
  19. data/ext/eigen/eigen3/Eigen/LU +41 -0
  20. data/ext/eigen/eigen3/Eigen/LeastSquares +32 -0
  21. data/ext/eigen/eigen3/Eigen/MetisSupport +28 -0
  22. data/ext/eigen/eigen3/Eigen/PaStiXSupport +46 -0
  23. data/ext/eigen/eigen3/Eigen/PardisoSupport +30 -0
  24. data/ext/eigen/eigen3/Eigen/QR +45 -0
  25. data/ext/eigen/eigen3/Eigen/QtAlignedMalloc +34 -0
  26. data/ext/eigen/eigen3/Eigen/SPQRSupport +29 -0
  27. data/ext/eigen/eigen3/Eigen/SVD +37 -0
  28. data/ext/eigen/eigen3/Eigen/Sparse +27 -0
  29. data/ext/eigen/eigen3/Eigen/SparseCore +64 -0
  30. data/ext/eigen/eigen3/Eigen/SparseLU +49 -0
  31. data/ext/eigen/eigen3/Eigen/SparseQR +33 -0
  32. data/ext/eigen/eigen3/Eigen/StdDeque +27 -0
  33. data/ext/eigen/eigen3/Eigen/StdList +26 -0
  34. data/ext/eigen/eigen3/Eigen/StdVector +27 -0
  35. data/ext/eigen/eigen3/Eigen/SuperLUSupport +59 -0
  36. data/ext/eigen/eigen3/Eigen/UmfPackSupport +36 -0
  37. data/ext/eigen/eigen3/Eigen/src/Cholesky/LDLT.h +611 -0
  38. data/ext/eigen/eigen3/Eigen/src/Cholesky/LLT.h +498 -0
  39. data/ext/eigen/eigen3/Eigen/src/Cholesky/LLT_MKL.h +102 -0
  40. data/ext/eigen/eigen3/Eigen/src/CholmodSupport/CholmodSupport.h +607 -0
  41. data/ext/eigen/eigen3/Eigen/src/Core/Array.h +323 -0
  42. data/ext/eigen/eigen3/Eigen/src/Core/ArrayBase.h +226 -0
  43. data/ext/eigen/eigen3/Eigen/src/Core/ArrayWrapper.h +264 -0
  44. data/ext/eigen/eigen3/Eigen/src/Core/Assign.h +590 -0
  45. data/ext/eigen/eigen3/Eigen/src/Core/Assign_MKL.h +224 -0
  46. data/ext/eigen/eigen3/Eigen/src/Core/BandMatrix.h +334 -0
  47. data/ext/eigen/eigen3/Eigen/src/Core/Block.h +406 -0
  48. data/ext/eigen/eigen3/Eigen/src/Core/BooleanRedux.h +154 -0
  49. data/ext/eigen/eigen3/Eigen/src/Core/CommaInitializer.h +154 -0
  50. data/ext/eigen/eigen3/Eigen/src/Core/CoreIterators.h +61 -0
  51. data/ext/eigen/eigen3/Eigen/src/Core/CwiseBinaryOp.h +230 -0
  52. data/ext/eigen/eigen3/Eigen/src/Core/CwiseNullaryOp.h +864 -0
  53. data/ext/eigen/eigen3/Eigen/src/Core/CwiseUnaryOp.h +126 -0
  54. data/ext/eigen/eigen3/Eigen/src/Core/CwiseUnaryView.h +139 -0
  55. data/ext/eigen/eigen3/Eigen/src/Core/DenseBase.h +521 -0
  56. data/ext/eigen/eigen3/Eigen/src/Core/DenseCoeffsBase.h +754 -0
  57. data/ext/eigen/eigen3/Eigen/src/Core/DenseStorage.h +434 -0
  58. data/ext/eigen/eigen3/Eigen/src/Core/Diagonal.h +237 -0
  59. data/ext/eigen/eigen3/Eigen/src/Core/DiagonalMatrix.h +313 -0
  60. data/ext/eigen/eigen3/Eigen/src/Core/DiagonalProduct.h +131 -0
  61. data/ext/eigen/eigen3/Eigen/src/Core/Dot.h +263 -0
  62. data/ext/eigen/eigen3/Eigen/src/Core/EigenBase.h +131 -0
  63. data/ext/eigen/eigen3/Eigen/src/Core/Flagged.h +140 -0
  64. data/ext/eigen/eigen3/Eigen/src/Core/ForceAlignedAccess.h +146 -0
  65. data/ext/eigen/eigen3/Eigen/src/Core/Functors.h +1026 -0
  66. data/ext/eigen/eigen3/Eigen/src/Core/Fuzzy.h +150 -0
  67. data/ext/eigen/eigen3/Eigen/src/Core/GeneralProduct.h +635 -0
  68. data/ext/eigen/eigen3/Eigen/src/Core/GenericPacketMath.h +350 -0
  69. data/ext/eigen/eigen3/Eigen/src/Core/GlobalFunctions.h +92 -0
  70. data/ext/eigen/eigen3/Eigen/src/Core/IO.h +250 -0
  71. data/ext/eigen/eigen3/Eigen/src/Core/Map.h +192 -0
  72. data/ext/eigen/eigen3/Eigen/src/Core/MapBase.h +247 -0
  73. data/ext/eigen/eigen3/Eigen/src/Core/MathFunctions.h +768 -0
  74. data/ext/eigen/eigen3/Eigen/src/Core/Matrix.h +420 -0
  75. data/ext/eigen/eigen3/Eigen/src/Core/MatrixBase.h +563 -0
  76. data/ext/eigen/eigen3/Eigen/src/Core/NestByValue.h +111 -0
  77. data/ext/eigen/eigen3/Eigen/src/Core/NoAlias.h +134 -0
  78. data/ext/eigen/eigen3/Eigen/src/Core/NumTraits.h +150 -0
  79. data/ext/eigen/eigen3/Eigen/src/Core/PermutationMatrix.h +721 -0
  80. data/ext/eigen/eigen3/Eigen/src/Core/PlainObjectBase.h +822 -0
  81. data/ext/eigen/eigen3/Eigen/src/Core/ProductBase.h +290 -0
  82. data/ext/eigen/eigen3/Eigen/src/Core/Random.h +152 -0
  83. data/ext/eigen/eigen3/Eigen/src/Core/Redux.h +409 -0
  84. data/ext/eigen/eigen3/Eigen/src/Core/Ref.h +278 -0
  85. data/ext/eigen/eigen3/Eigen/src/Core/Replicate.h +177 -0
  86. data/ext/eigen/eigen3/Eigen/src/Core/ReturnByValue.h +99 -0
  87. data/ext/eigen/eigen3/Eigen/src/Core/Reverse.h +224 -0
  88. data/ext/eigen/eigen3/Eigen/src/Core/Select.h +162 -0
  89. data/ext/eigen/eigen3/Eigen/src/Core/SelfAdjointView.h +314 -0
  90. data/ext/eigen/eigen3/Eigen/src/Core/SelfCwiseBinaryOp.h +191 -0
  91. data/ext/eigen/eigen3/Eigen/src/Core/SolveTriangular.h +260 -0
  92. data/ext/eigen/eigen3/Eigen/src/Core/StableNorm.h +203 -0
  93. data/ext/eigen/eigen3/Eigen/src/Core/Stride.h +108 -0
  94. data/ext/eigen/eigen3/Eigen/src/Core/Swap.h +126 -0
  95. data/ext/eigen/eigen3/Eigen/src/Core/Transpose.h +419 -0
  96. data/ext/eigen/eigen3/Eigen/src/Core/Transpositions.h +436 -0
  97. data/ext/eigen/eigen3/Eigen/src/Core/TriangularMatrix.h +839 -0
  98. data/ext/eigen/eigen3/Eigen/src/Core/VectorBlock.h +95 -0
  99. data/ext/eigen/eigen3/Eigen/src/Core/VectorwiseOp.h +642 -0
  100. data/ext/eigen/eigen3/Eigen/src/Core/Visitor.h +237 -0
  101. data/ext/eigen/eigen3/Eigen/src/Core/arch/AltiVec/Complex.h +217 -0
  102. data/ext/eigen/eigen3/Eigen/src/Core/arch/AltiVec/PacketMath.h +501 -0
  103. data/ext/eigen/eigen3/Eigen/src/Core/arch/Default/Settings.h +49 -0
  104. data/ext/eigen/eigen3/Eigen/src/Core/arch/NEON/Complex.h +253 -0
  105. data/ext/eigen/eigen3/Eigen/src/Core/arch/NEON/PacketMath.h +420 -0
  106. data/ext/eigen/eigen3/Eigen/src/Core/arch/SSE/Complex.h +442 -0
  107. data/ext/eigen/eigen3/Eigen/src/Core/arch/SSE/MathFunctions.h +475 -0
  108. data/ext/eigen/eigen3/Eigen/src/Core/arch/SSE/PacketMath.h +649 -0
  109. data/ext/eigen/eigen3/Eigen/src/Core/products/CoeffBasedProduct.h +476 -0
  110. data/ext/eigen/eigen3/Eigen/src/Core/products/GeneralBlockPanelKernel.h +1341 -0
  111. data/ext/eigen/eigen3/Eigen/src/Core/products/GeneralMatrixMatrix.h +427 -0
  112. data/ext/eigen/eigen3/Eigen/src/Core/products/GeneralMatrixMatrixTriangular.h +278 -0
  113. data/ext/eigen/eigen3/Eigen/src/Core/products/GeneralMatrixMatrixTriangular_MKL.h +146 -0
  114. data/ext/eigen/eigen3/Eigen/src/Core/products/GeneralMatrixMatrix_MKL.h +118 -0
  115. data/ext/eigen/eigen3/Eigen/src/Core/products/GeneralMatrixVector.h +566 -0
  116. data/ext/eigen/eigen3/Eigen/src/Core/products/GeneralMatrixVector_MKL.h +131 -0
  117. data/ext/eigen/eigen3/Eigen/src/Core/products/Parallelizer.h +162 -0
  118. data/ext/eigen/eigen3/Eigen/src/Core/products/SelfadjointMatrixMatrix.h +436 -0
  119. data/ext/eigen/eigen3/Eigen/src/Core/products/SelfadjointMatrixMatrix_MKL.h +295 -0
  120. data/ext/eigen/eigen3/Eigen/src/Core/products/SelfadjointMatrixVector.h +281 -0
  121. data/ext/eigen/eigen3/Eigen/src/Core/products/SelfadjointMatrixVector_MKL.h +114 -0
  122. data/ext/eigen/eigen3/Eigen/src/Core/products/SelfadjointProduct.h +123 -0
  123. data/ext/eigen/eigen3/Eigen/src/Core/products/SelfadjointRank2Update.h +93 -0
  124. data/ext/eigen/eigen3/Eigen/src/Core/products/TriangularMatrixMatrix.h +427 -0
  125. data/ext/eigen/eigen3/Eigen/src/Core/products/TriangularMatrixMatrix_MKL.h +309 -0
  126. data/ext/eigen/eigen3/Eigen/src/Core/products/TriangularMatrixVector.h +348 -0
  127. data/ext/eigen/eigen3/Eigen/src/Core/products/TriangularMatrixVector_MKL.h +247 -0
  128. data/ext/eigen/eigen3/Eigen/src/Core/products/TriangularSolverMatrix.h +332 -0
  129. data/ext/eigen/eigen3/Eigen/src/Core/products/TriangularSolverMatrix_MKL.h +155 -0
  130. data/ext/eigen/eigen3/Eigen/src/Core/products/TriangularSolverVector.h +139 -0
  131. data/ext/eigen/eigen3/Eigen/src/Core/util/BlasUtil.h +264 -0
  132. data/ext/eigen/eigen3/Eigen/src/Core/util/Constants.h +451 -0
  133. data/ext/eigen/eigen3/Eigen/src/Core/util/DisableStupidWarnings.h +40 -0
  134. data/ext/eigen/eigen3/Eigen/src/Core/util/ForwardDeclarations.h +302 -0
  135. data/ext/eigen/eigen3/Eigen/src/Core/util/MKL_support.h +158 -0
  136. data/ext/eigen/eigen3/Eigen/src/Core/util/Macros.h +451 -0
  137. data/ext/eigen/eigen3/Eigen/src/Core/util/Memory.h +977 -0
  138. data/ext/eigen/eigen3/Eigen/src/Core/util/Meta.h +243 -0
  139. data/ext/eigen/eigen3/Eigen/src/Core/util/NonMPL2.h +3 -0
  140. data/ext/eigen/eigen3/Eigen/src/Core/util/ReenableStupidWarnings.h +14 -0
  141. data/ext/eigen/eigen3/Eigen/src/Core/util/StaticAssert.h +208 -0
  142. data/ext/eigen/eigen3/Eigen/src/Core/util/XprHelper.h +469 -0
  143. data/ext/eigen/eigen3/Eigen/src/Eigen2Support/Block.h +126 -0
  144. data/ext/eigen/eigen3/Eigen/src/Eigen2Support/Cwise.h +192 -0
  145. data/ext/eigen/eigen3/Eigen/src/Eigen2Support/CwiseOperators.h +298 -0
  146. data/ext/eigen/eigen3/Eigen/src/Eigen2Support/Geometry/AlignedBox.h +159 -0
  147. data/ext/eigen/eigen3/Eigen/src/Eigen2Support/Geometry/All.h +115 -0
  148. data/ext/eigen/eigen3/Eigen/src/Eigen2Support/Geometry/AngleAxis.h +214 -0
  149. data/ext/eigen/eigen3/Eigen/src/Eigen2Support/Geometry/Hyperplane.h +254 -0
  150. data/ext/eigen/eigen3/Eigen/src/Eigen2Support/Geometry/ParametrizedLine.h +141 -0
  151. data/ext/eigen/eigen3/Eigen/src/Eigen2Support/Geometry/Quaternion.h +495 -0
  152. data/ext/eigen/eigen3/Eigen/src/Eigen2Support/Geometry/Rotation2D.h +145 -0
  153. data/ext/eigen/eigen3/Eigen/src/Eigen2Support/Geometry/RotationBase.h +123 -0
  154. data/ext/eigen/eigen3/Eigen/src/Eigen2Support/Geometry/Scaling.h +167 -0
  155. data/ext/eigen/eigen3/Eigen/src/Eigen2Support/Geometry/Transform.h +786 -0
  156. data/ext/eigen/eigen3/Eigen/src/Eigen2Support/Geometry/Translation.h +184 -0
  157. data/ext/eigen/eigen3/Eigen/src/Eigen2Support/LU.h +120 -0
  158. data/ext/eigen/eigen3/Eigen/src/Eigen2Support/Lazy.h +71 -0
  159. data/ext/eigen/eigen3/Eigen/src/Eigen2Support/LeastSquares.h +169 -0
  160. data/ext/eigen/eigen3/Eigen/src/Eigen2Support/Macros.h +20 -0
  161. data/ext/eigen/eigen3/Eigen/src/Eigen2Support/MathFunctions.h +57 -0
  162. data/ext/eigen/eigen3/Eigen/src/Eigen2Support/Memory.h +45 -0
  163. data/ext/eigen/eigen3/Eigen/src/Eigen2Support/Meta.h +75 -0
  164. data/ext/eigen/eigen3/Eigen/src/Eigen2Support/Minor.h +117 -0
  165. data/ext/eigen/eigen3/Eigen/src/Eigen2Support/QR.h +67 -0
  166. data/ext/eigen/eigen3/Eigen/src/Eigen2Support/SVD.h +637 -0
  167. data/ext/eigen/eigen3/Eigen/src/Eigen2Support/TriangularSolver.h +42 -0
  168. data/ext/eigen/eigen3/Eigen/src/Eigen2Support/VectorBlock.h +94 -0
  169. data/ext/eigen/eigen3/Eigen/src/Eigenvalues/ComplexEigenSolver.h +341 -0
  170. data/ext/eigen/eigen3/Eigen/src/Eigenvalues/ComplexSchur.h +456 -0
  171. data/ext/eigen/eigen3/Eigen/src/Eigenvalues/ComplexSchur_MKL.h +94 -0
  172. data/ext/eigen/eigen3/Eigen/src/Eigenvalues/EigenSolver.h +607 -0
  173. data/ext/eigen/eigen3/Eigen/src/Eigenvalues/GeneralizedEigenSolver.h +350 -0
  174. data/ext/eigen/eigen3/Eigen/src/Eigenvalues/GeneralizedSelfAdjointEigenSolver.h +227 -0
  175. data/ext/eigen/eigen3/Eigen/src/Eigenvalues/HessenbergDecomposition.h +373 -0
  176. data/ext/eigen/eigen3/Eigen/src/Eigenvalues/MatrixBaseEigenvalues.h +160 -0
  177. data/ext/eigen/eigen3/Eigen/src/Eigenvalues/RealQZ.h +624 -0
  178. data/ext/eigen/eigen3/Eigen/src/Eigenvalues/RealSchur.h +525 -0
  179. data/ext/eigen/eigen3/Eigen/src/Eigenvalues/RealSchur_MKL.h +83 -0
  180. data/ext/eigen/eigen3/Eigen/src/Eigenvalues/SelfAdjointEigenSolver.h +801 -0
  181. data/ext/eigen/eigen3/Eigen/src/Eigenvalues/SelfAdjointEigenSolver_MKL.h +92 -0
  182. data/ext/eigen/eigen3/Eigen/src/Eigenvalues/Tridiagonalization.h +557 -0
  183. data/ext/eigen/eigen3/Eigen/src/Geometry/AlignedBox.h +392 -0
  184. data/ext/eigen/eigen3/Eigen/src/Geometry/AngleAxis.h +233 -0
  185. data/ext/eigen/eigen3/Eigen/src/Geometry/EulerAngles.h +104 -0
  186. data/ext/eigen/eigen3/Eigen/src/Geometry/Homogeneous.h +307 -0
  187. data/ext/eigen/eigen3/Eigen/src/Geometry/Hyperplane.h +280 -0
  188. data/ext/eigen/eigen3/Eigen/src/Geometry/OrthoMethods.h +218 -0
  189. data/ext/eigen/eigen3/Eigen/src/Geometry/ParametrizedLine.h +195 -0
  190. data/ext/eigen/eigen3/Eigen/src/Geometry/Quaternion.h +776 -0
  191. data/ext/eigen/eigen3/Eigen/src/Geometry/Rotation2D.h +160 -0
  192. data/ext/eigen/eigen3/Eigen/src/Geometry/RotationBase.h +206 -0
  193. data/ext/eigen/eigen3/Eigen/src/Geometry/Scaling.h +166 -0
  194. data/ext/eigen/eigen3/Eigen/src/Geometry/Transform.h +1455 -0
  195. data/ext/eigen/eigen3/Eigen/src/Geometry/Translation.h +206 -0
  196. data/ext/eigen/eigen3/Eigen/src/Geometry/Umeyama.h +177 -0
  197. data/ext/eigen/eigen3/Eigen/src/Geometry/arch/Geometry_SSE.h +115 -0
  198. data/ext/eigen/eigen3/Eigen/src/Householder/BlockHouseholder.h +68 -0
  199. data/ext/eigen/eigen3/Eigen/src/Householder/Householder.h +171 -0
  200. data/ext/eigen/eigen3/Eigen/src/Householder/HouseholderSequence.h +441 -0
  201. data/ext/eigen/eigen3/Eigen/src/IterativeLinearSolvers/BasicPreconditioners.h +149 -0
  202. data/ext/eigen/eigen3/Eigen/src/IterativeLinearSolvers/BiCGSTAB.h +263 -0
  203. data/ext/eigen/eigen3/Eigen/src/IterativeLinearSolvers/ConjugateGradient.h +256 -0
  204. data/ext/eigen/eigen3/Eigen/src/IterativeLinearSolvers/IterativeSolverBase.h +282 -0
  205. data/ext/eigen/eigen3/Eigen/src/Jacobi/Jacobi.h +433 -0
  206. data/ext/eigen/eigen3/Eigen/src/LU/Determinant.h +101 -0
  207. data/ext/eigen/eigen3/Eigen/src/LU/FullPivLU.h +751 -0
  208. data/ext/eigen/eigen3/Eigen/src/LU/Inverse.h +400 -0
  209. data/ext/eigen/eigen3/Eigen/src/LU/PartialPivLU.h +509 -0
  210. data/ext/eigen/eigen3/Eigen/src/LU/PartialPivLU_MKL.h +85 -0
  211. data/ext/eigen/eigen3/Eigen/src/LU/arch/Inverse_SSE.h +329 -0
  212. data/ext/eigen/eigen3/Eigen/src/MetisSupport/MetisSupport.h +137 -0
  213. data/ext/eigen/eigen3/Eigen/src/OrderingMethods/Amd.h +444 -0
  214. data/ext/eigen/eigen3/Eigen/src/OrderingMethods/Eigen_Colamd.h +1850 -0
  215. data/ext/eigen/eigen3/Eigen/src/PaStiXSupport/PaStiXSupport.h +721 -0
  216. data/ext/eigen/eigen3/Eigen/src/PardisoSupport/PardisoSupport.h +592 -0
  217. data/ext/eigen/eigen3/Eigen/src/QR/ColPivHouseholderQR.h +580 -0
  218. data/ext/eigen/eigen3/Eigen/src/QR/ColPivHouseholderQR_MKL.h +99 -0
  219. data/ext/eigen/eigen3/Eigen/src/QR/FullPivHouseholderQR.h +622 -0
  220. data/ext/eigen/eigen3/Eigen/src/QR/HouseholderQR.h +388 -0
  221. data/ext/eigen/eigen3/Eigen/src/QR/HouseholderQR_MKL.h +71 -0
  222. data/ext/eigen/eigen3/Eigen/src/SPQRSupport/SuiteSparseQRSupport.h +338 -0
  223. data/ext/eigen/eigen3/Eigen/src/SVD/JacobiSVD.h +976 -0
  224. data/ext/eigen/eigen3/Eigen/src/SVD/JacobiSVD_MKL.h +92 -0
  225. data/ext/eigen/eigen3/Eigen/src/SVD/UpperBidiagonalization.h +148 -0
  226. data/ext/eigen/eigen3/Eigen/src/SparseCholesky/SimplicialCholesky.h +671 -0
  227. data/ext/eigen/eigen3/Eigen/src/SparseCholesky/SimplicialCholesky_impl.h +199 -0
  228. data/ext/eigen/eigen3/Eigen/src/SparseCore/AmbiVector.h +373 -0
  229. data/ext/eigen/eigen3/Eigen/src/SparseCore/CompressedStorage.h +233 -0
  230. data/ext/eigen/eigen3/Eigen/src/SparseCore/ConservativeSparseSparseProduct.h +245 -0
  231. data/ext/eigen/eigen3/Eigen/src/SparseCore/MappedSparseMatrix.h +181 -0
  232. data/ext/eigen/eigen3/Eigen/src/SparseCore/SparseBlock.h +537 -0
  233. data/ext/eigen/eigen3/Eigen/src/SparseCore/SparseColEtree.h +206 -0
  234. data/ext/eigen/eigen3/Eigen/src/SparseCore/SparseCwiseBinaryOp.h +325 -0
  235. data/ext/eigen/eigen3/Eigen/src/SparseCore/SparseCwiseUnaryOp.h +163 -0
  236. data/ext/eigen/eigen3/Eigen/src/SparseCore/SparseDenseProduct.h +311 -0
  237. data/ext/eigen/eigen3/Eigen/src/SparseCore/SparseDiagonalProduct.h +196 -0
  238. data/ext/eigen/eigen3/Eigen/src/SparseCore/SparseDot.h +101 -0
  239. data/ext/eigen/eigen3/Eigen/src/SparseCore/SparseFuzzy.h +26 -0
  240. data/ext/eigen/eigen3/Eigen/src/SparseCore/SparseMatrix.h +1262 -0
  241. data/ext/eigen/eigen3/Eigen/src/SparseCore/SparseMatrixBase.h +461 -0
  242. data/ext/eigen/eigen3/Eigen/src/SparseCore/SparsePermutation.h +148 -0
  243. data/ext/eigen/eigen3/Eigen/src/SparseCore/SparseProduct.h +188 -0
  244. data/ext/eigen/eigen3/Eigen/src/SparseCore/SparseRedux.h +45 -0
  245. data/ext/eigen/eigen3/Eigen/src/SparseCore/SparseSelfAdjointView.h +507 -0
  246. data/ext/eigen/eigen3/Eigen/src/SparseCore/SparseSparseProductWithPruning.h +150 -0
  247. data/ext/eigen/eigen3/Eigen/src/SparseCore/SparseTranspose.h +63 -0
  248. data/ext/eigen/eigen3/Eigen/src/SparseCore/SparseTriangularView.h +179 -0
  249. data/ext/eigen/eigen3/Eigen/src/SparseCore/SparseUtil.h +172 -0
  250. data/ext/eigen/eigen3/Eigen/src/SparseCore/SparseVector.h +448 -0
  251. data/ext/eigen/eigen3/Eigen/src/SparseCore/SparseView.h +99 -0
  252. data/ext/eigen/eigen3/Eigen/src/SparseCore/TriangularSolver.h +334 -0
  253. data/ext/eigen/eigen3/Eigen/src/SparseLU/SparseLU.h +806 -0
  254. data/ext/eigen/eigen3/Eigen/src/SparseLU/SparseLUImpl.h +66 -0
  255. data/ext/eigen/eigen3/Eigen/src/SparseLU/SparseLU_Memory.h +227 -0
  256. data/ext/eigen/eigen3/Eigen/src/SparseLU/SparseLU_Structs.h +111 -0
  257. data/ext/eigen/eigen3/Eigen/src/SparseLU/SparseLU_SupernodalMatrix.h +298 -0
  258. data/ext/eigen/eigen3/Eigen/src/SparseLU/SparseLU_Utils.h +80 -0
  259. data/ext/eigen/eigen3/Eigen/src/SparseLU/SparseLU_column_bmod.h +180 -0
  260. data/ext/eigen/eigen3/Eigen/src/SparseLU/SparseLU_column_dfs.h +177 -0
  261. data/ext/eigen/eigen3/Eigen/src/SparseLU/SparseLU_copy_to_ucol.h +106 -0
  262. data/ext/eigen/eigen3/Eigen/src/SparseLU/SparseLU_gemm_kernel.h +279 -0
  263. data/ext/eigen/eigen3/Eigen/src/SparseLU/SparseLU_heap_relax_snode.h +127 -0
  264. data/ext/eigen/eigen3/Eigen/src/SparseLU/SparseLU_kernel_bmod.h +130 -0
  265. data/ext/eigen/eigen3/Eigen/src/SparseLU/SparseLU_panel_bmod.h +223 -0
  266. data/ext/eigen/eigen3/Eigen/src/SparseLU/SparseLU_panel_dfs.h +258 -0
  267. data/ext/eigen/eigen3/Eigen/src/SparseLU/SparseLU_pivotL.h +137 -0
  268. data/ext/eigen/eigen3/Eigen/src/SparseLU/SparseLU_pruneL.h +135 -0
  269. data/ext/eigen/eigen3/Eigen/src/SparseLU/SparseLU_relax_snode.h +83 -0
  270. data/ext/eigen/eigen3/Eigen/src/SparseQR/SparseQR.h +714 -0
  271. data/ext/eigen/eigen3/Eigen/src/StlSupport/StdDeque.h +134 -0
  272. data/ext/eigen/eigen3/Eigen/src/StlSupport/StdList.h +114 -0
  273. data/ext/eigen/eigen3/Eigen/src/StlSupport/StdVector.h +126 -0
  274. data/ext/eigen/eigen3/Eigen/src/StlSupport/details.h +84 -0
  275. data/ext/eigen/eigen3/Eigen/src/SuperLUSupport/SuperLUSupport.h +1026 -0
  276. data/ext/eigen/eigen3/Eigen/src/UmfPackSupport/UmfPackSupport.h +474 -0
  277. data/ext/eigen/eigen3/Eigen/src/misc/Image.h +84 -0
  278. data/ext/eigen/eigen3/Eigen/src/misc/Kernel.h +81 -0
  279. data/ext/eigen/eigen3/Eigen/src/misc/Solve.h +76 -0
  280. data/ext/eigen/eigen3/Eigen/src/misc/SparseSolve.h +128 -0
  281. data/ext/eigen/eigen3/Eigen/src/misc/blas.h +658 -0
  282. data/ext/eigen/eigen3/Eigen/src/plugins/ArrayCwiseBinaryOps.h +253 -0
  283. data/ext/eigen/eigen3/Eigen/src/plugins/ArrayCwiseUnaryOps.h +187 -0
  284. data/ext/eigen/eigen3/Eigen/src/plugins/BlockMethods.h +935 -0
  285. data/ext/eigen/eigen3/Eigen/src/plugins/CommonCwiseBinaryOps.h +46 -0
  286. data/ext/eigen/eigen3/Eigen/src/plugins/CommonCwiseUnaryOps.h +172 -0
  287. data/ext/eigen/eigen3/Eigen/src/plugins/MatrixCwiseBinaryOps.h +143 -0
  288. data/ext/eigen/eigen3/Eigen/src/plugins/MatrixCwiseUnaryOps.h +52 -0
  289. data/ext/eigen/eigen3/signature_of_eigen3_matrix_library +1 -0
  290. data/ext/eigen/eigen_wrap.cxx +19420 -10396
  291. data/ext/eigen/extconf.rb +37 -2
  292. data/lib/eigen.rb +146 -3
  293. 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