#ndarray #lapack #matrix

ndarray-linalg

Linear algebra package for rust-ndarray using LAPACK

27 releases

✓ Uses Rust 2018 edition

new 0.11.1 Jun 11, 2019
0.10.0 Sep 1, 2018
0.9.0 Jan 12, 2018
0.8.0 Dec 20, 2017
0.1.5 Nov 28, 2016

#40 in Algorithms

Download history 190/week @ 2019-02-26 50/week @ 2019-03-05 29/week @ 2019-03-12 112/week @ 2019-03-19 380/week @ 2019-03-26 70/week @ 2019-04-02 91/week @ 2019-04-09 20/week @ 2019-04-16 47/week @ 2019-04-23 44/week @ 2019-04-30 57/week @ 2019-05-07 67/week @ 2019-05-14 150/week @ 2019-05-21 225/week @ 2019-05-28 95/week @ 2019-06-04

461 downloads per month
Used in 14 crates (11 directly)

MIT license

115KB
2.5K SLoC

ndarray-linalg

Crate docs.rs Build Status

Linear algebra package for Rust with ndarray based on external LAPACK implementations.

Examples

See examples directory.

Note: To run examples, you must specify which backend will be used (as described below). For example, you can execute the solve example with the OpenBLAS backend like this:

cargo run --example solve --features=openblas

and run all tests of ndarray-linalg with OpenBLAS

cargo test --features=openblas

BLAS/LAPACK Backend

Three BLAS/LAPACK implementations are supported:

  • OpenBLAS
    • needs gfortran (or other Fortran compiler)
  • Netlib
    • needs cmake and gfortran
  • Intel MKL (non-free license, see the linked page)

There are three features corresponding to the backend implementations (openblas / netlib / intel-mkl):

[dependencies]
ndarray = "0.12"
ndarray-linalg = { version = "0.11", features = ["openblas"] }

Tested Environments

Backend Linux Windows macOS
OpenBLAS ✔️ 🚫 🚫
Netlib ✔️ 🚫 🚫
Intel MKL ✔️ ✔️ ✔️

For librarian

If you creating a library depending on this crate, we encourage you not to link any backend:

[dependencies]
ndarray = "0.12"
ndarray-linalg = "0.11"

Link backend crate manually

For the sake of linking flexibility, you can provide LAPACKE implementation (as an extern crate) yourself. You should link a LAPACKE implementation to a final crate (like binary executable or dylib) only, not to a Rust library.

[dependencies]
ndarray = "0.12"
ndarray-linalg = "0.11"
openblas-src = "0.7" # or another backend of your choice

You must add extern crate to your code in this case:

extern crate ndarray;
extern crate ndarray_linalg;
extern crate openblas_src; // or another backend of your choice

Dependencies

~21MB
~479K SLoC