Matrix exponentiation in Rust

This crate contains expm, an implementation of Algorithm 6.1 by [Al-Mohy, Higham] in the Rust programming language. It calculates the exponential of a matrix. See the linked paper for more information.

It uses the excellent [rust-ndarray] crate for matrix storage.

Example usage

The example below calculates the exponential of the unit matrix.

Important: You need to explicitly link to a BLAS + LAPACK provider such as openblas_src. See the explanations given at the [blas-lapack-rs organization].

```rust extern crate openblassrc; use approx::assertulps_eq;

[test]

fn expofunit() { let n = 5; let a = ndarray::Array2::eye(n); let mut b = unsafe { ndarray::Array2::::uninitialized((n, n)) };

crate::expm(&a, &mut b);

for &elem in &b.diag() {
    assert_ulps_eq!(elem, 1f64.exp(), max_ulps=1);
}

} ```

TODO

Care was taken to implement the algorithm with performance in mind. As such, no extra allocations after the initial setup of the Expm struct are done, and Expm can be reused to repeatedly calculate the exponential of matrices with the same dimension.

However, profiling the code might reveal ways to improve it.