eigen: Eigen C++ library (linear algebra: matrices, sparse matrices, vectors, numerical solvers).
NOTE: This library does not follow PVP. Instead, it follows Eigen's versioning. Version X.Y.Z.W means that the Eigen version is X.Y.Z, and the haskell release is W, where each W release is for bug fixes/API improvements.
This module provides Haskell binding for Eigen C++ library.
Eigen is versatile.
It supports all matrix sizes, from small fixed-size matrices to arbitrarily large dense matrices, and even sparse matrices.
It supports all standard numeric types, including std::complex, integers, and is easily extensible to custom numeric types.
Its ecosystem of unsupported modules provides many specialized features such as non-linear optimization, matrix functions, a polynomial solver, FFT, and much more.
Eigen is fast.
Expression templates allow to intelligently remove temporaries and enable lazy evaluation, when that is appropriate.
Explicit vectorization is performed for SSE 2/3/4, ARM NEON, and AltiVec instruction sets, with graceful fallback to non-vectorized code.
Fixed-size matrices are fully optimized: dynamic memory allocation is avoided, and the loops are unrolled when that makes sense.
For large matrices, special attention is paid to cache-friendliness.
Eigen is reliable.
Eigen is thoroughly tested through its own test suite (over 500 executables), the standard BLAS test suite, and parts of the LAPACK test suite.
Eigen is elegant.
The API is extremely clean and expressive while feeling natural to C++ programmers, thanks to expression templates.
Implementing an algorithm on top of Eigen feels like just copying pseudocode.
Eigen has good compiler support as we run our test suite against many compilers to guarantee reliability and work around any compiler bugs. Eigen also is standard C++98 and maintains very reasonable compilation times.
Eigen is licensed under the MPL2, which is a simple weak copyleft license. Common questions about the MPL2 are answered in the official MPL2 FAQ at http://www.mozilla.org/MPL/2.0/FAQ.html.
Note that currently, a few features in Eigen rely on third-party code licensed under the LGPL: SimplicialCholesky, AMD ordering, and constrained_cg. Such features are explicitly disabled by compiling Eigen with the EIGEN_MPL2_ONLY preprocessor symbol defined.
Virtually any software may use Eigen. For example, closed-source software may use Eigen without having to disclose its own source code. Many proprietary and closed-source software projects are using Eigen right now, as well as many BSD-licensed projects.
Documentation at the most extent replicates original Eigen documentation.
|Versions [RSS] [faq]||1.0.0, 1.1.1, 1.1.2, 1.2.1, 1.2.2, 1.2.3, 1.2.4, 1.2.5, 2.0.0, 2.0.1, 2.1.0, 2.1.1, 2.1.2, 2.1.3, 2.1.4, 2.1.5, 2.1.6, 2.1.7, 126.96.36.199, 188.8.131.52, 184.108.40.206, 220.127.116.11 (info)|
|Dependencies||base (>=4.10 && <5), binary (>=0.8.0.0 && <0.8.6.0), bytestring (>=0.10.4.0 && <0.11.0.0), constraints (>=0.10.0 && <0.11.0), ghc-prim, primitive (>=0.6.4.0 && <0.7), transformers (>=0.3 && <0.6), vector (>=0.5 && <0.13) [details]|
|Copyright||(c) 2013-2015, Oleg Sidorkin, (c) 2018, chessai|
|Author||Oleg Sidorkin <email@example.com>|
|Category||Data, Math, Algebra, Statistics, Algorithms, Numeric|
|Source repo||head: git clone git://github.com/chessai/eigen.git|
|Uploaded||by chessai at 2018-12-11T20:02:00Z|
|Downloads||14435 total (47 in the last 30 days)|
|Rating||(no votes yet) [estimated by Bayesian average]|
Docs uploaded by user [build log]
All reported builds failed as of 2018-12-11 [all 1 reports]