|This article relies too much on references to primary sources. (June 2010) (Learn how and when to remove this template message)|
3.10.0 / 19 August 2015
|License||Dual (commercial, GPL)|
ALGLIB is a cross-platform open source numerical analysis and data processing library. It is written in specially designed pseudocode which is automatically translated into several target programming languages (C++, C# and other). ALGLIB is relatively young project - active development started only in 2008, while GSL, for example, has 14 years long history. However, it is actively developed with new releases every 1–2 months.
ALGLIB is used by several open source and commercial libraries/applications (e.g. TOL project, Math.NET Numerics, SpaceClaim). Multiple precision edition of ALGLIB is planned to be included into SageMath (open source computer algebra system).
Advantages and Drawbacks
Several goals were pursued while developing ALGLIB:
- support for several programming languages (as of 2010, it supports C++, C#, FreePascal, Delphi, VBA)
- identical functionality for any programming language
- ease of installation
- portability (it was tested only under x86 and x86-64 Windows and Linux, but should work under any CPU/OS which are at least 32-bit and support IEEE-compliant floating point numbers)
- support for multiple precision computations
Alternatively, the project suffers from several drawbacks:
- Only the commercial edition supports multi-threading
- it can't use SSE to speed up floating point operations
- although some linear algebra algorithms are implemented in cache oblivious manner, many subroutines (especially SVD solvers) can't efficiently work with matrices that do not fit into CPU cache.
ALGLIB provides facilities for:
- Linear algebra (direct algorithms, solvers, EVD/SVD)
- Fast Fourier transforms
- Numerical integration
- Linear and nonlinear least-squares fitting
- Ordinary differential equations
- Special functions
- Statistics (descriptive statistics, hypothesis testing)
- Data analysis (classification/regression, including neural networks)
- Multiple precision versions of linear algebra, interpolation and optimization algorithms (using MPFR for floating point computations)
- "Math.NET Numerics". Numerics.mathdotnet.com. Retrieved 2010-07-10.
- "Math.NET Numerics Contributors". GitHub.com. Retrieved 2013-05-07.
- "End User License". .spaceclaim.com. Retrieved 2010-07-10.
- "Support Vector Machine - sage-devel | Google Groups". Groups.google.com. Retrieved 2010-07-10.
- "multiprecision linear algebra - sage-devel | Google Groups". Groups.google.com. Retrieved 2010-07-10.
- "devel/SageTasks - Sage Wiki". Wiki.sagemath.org. 2010-05-09. Retrieved 2010-07-10.
- "Compatibility". ALGLIB. Archived from the original on 12 August 2010. Retrieved 2010-07-10.
- "LU decomposition". ALGLIB. Archived from the original on 6 August 2010. Retrieved 2010-07-10.
- "Cholesky decomposition". ALGLIB. Archived from the original on 30 May 2010. Retrieved 2010-07-10.