Armadillo (C++ library)
Armadillo is a linear algebra software library for the C++ programming language. It aims to provide efficient and streamlined base calculations, while at the same time having a straightforward and easy-to-use interface. Its intended target users are scientists and engineers.
Stable release | 12.4.0
/ May 25, 2023[1] |
---|---|
Written in | C++ |
Operating system | Cross-platform |
Available in | English |
Type | Software library |
License | Apache 2.0 (open source) |
Website | arma |
It supports integer, floating point (single and double precision), complex numbers, and a subset of trigonometric and statistics functions. Dense and sparse matrices are supported.[2] Various matrix decompositions are provided through optional integration with Linear Algebra PACKage (LAPACK), Automatically Tuned Linear Algebra Software (ATLAS), and ARPACK.[3] High-performance BLAS/LAPACK replacement libraries such as OpenBLAS and Intel MKL can also be used.
The library employs a delayed-evaluation approach (during compile time) to combine several operations into one and reduce (or eliminate) the need for temporaries. Where applicable, the order of operations is optimised. Delayed evaluation and optimisation are achieved through template metaprogramming.
Armadillo is related to the Boost Basic Linear Algebra Subprograms (uBLAS) library, which also uses template metaprogramming. However, Armadillo builds upon ATLAS and LAPACK libraries, thereby providing machine-dependent optimisations and functions not present in uBLAS.
It is open-source software distributed under the permissive Apache License, making it applicable for the development of both open source and proprietary software. The project is supported by the NICTA research centre in Australia.
An interface to the Python language is available through the PyArmadillo package,[4] which facilitates prototyping of algorithms in Python followed by relatively straightforward conversion to C++.
Armadillo is a core dependency of the mlpack machine learning library[5] and the ensmallen C++ library for numerical optimization.[6]
Example in C++ 11
Here is a trivial example demonstrating Armadillo functionality:
// Compile with:
// $ g++ -std=c++11 main.cpp -o file_name -O2 -larmadillo
#include <iostream>
#include <armadillo>
#include <cmath>
int main()
{
// ^
// Position of a particle // |
arma::vec Pos = {{0}, // | (0,1)
{1}}; // +---x-->
// Rotation matrix
double phi = -3.1416/2;
arma::mat RotM = {{+cos(phi), -sin(phi)},
{+sin(phi), +cos(phi)}};
Pos.print("Current position of the particle:");
std::cout << "Rotating the point " << phi*180/3.1416 << " deg" << std::endl;
Pos = RotM*Pos;
Pos.print("New position of the particle:"); // ^
// x (1,0)
// |
// +------>
return 0;
}
Example in C++ 98
Here is another trivial example in C++ 98:
#include <iostream>
#include <armadillo>
int main()
{
arma::vec b;
b << 2.0 << 5.0 << 2.0;
// arma::endr represents the end of a row in a matrix
arma::mat A;
A << 1.0 << 2.0 << arma::endr
<< 2.0 << 3.0 << arma::endr
<< 1.0 << 3.0 << arma::endr;
std::cout << "Least squares solution:\n";
std::cout << arma::solve(A,b) << '\n';
return 0;
}
See also
References
- "Armadillo C++ matrix library / News: Recent posts". Retrieved 2023-06-09 – via SourceForge.
- Conrad Sanderson and Ryan Curtin (2018). A User-Friendly Hybrid Sparse Matrix Class in C++. Lecture Notes in Computer Science (LNCS), Vol. 10931, pp. 422-430. arXiv:1805.03380. doi:10.1007/978-3-319-96418-8_50.
- Conrad Sanderson and Ryan Curtin (2016). "Armadillo: a template-based C++ library for linear algebra". Journal of Open Source Software. 1 (2): 26. Bibcode:2016JOSS....1...26S. doi:10.21105/joss.00026.
- Jason Rumengan; et al. (2021). "PyArmadillo: a streamlined linear algebra library for Python". Journal of Open Source Software. 6 (66): 3051. arXiv:2104.11120. doi:10.21105/joss.03051.
- Ryan Curtin; et al. (2023). "mlpack 4: a fast, header-only C++ machine learning library". Journal of Open Source Software. 8 (82): 5026. arXiv:2302.00820.
- Ryan Curtin; et al. (2021). "The ensmallen library for flexible numerical optimization". Journal of Machine Learning Research. 22 (166): 1–6. arXiv:2108.12981. Bibcode:2021arXiv210812981C.