An open API service indexing awesome lists of open source software.

https://github.com/Pencilcaseman/hasty

High-performance BLAS and LAPACK within Rust
https://github.com/Pencilcaseman/hasty

accelerate atlas blas mkl openblas rust

Last synced: 30 days ago
JSON representation

High-performance BLAS and LAPACK within Rust

Awesome Lists containing this project

README

          

Hasty Logo

[![Crates.io](https://img.shields.io/crates/v/hasty)](https://crates.io/crates/hasty)
[![Documentation](https://docs.rs/hasty/badge.svg)](https://docs.rs/hasty)
[![License](https://img.shields.io/crates/l/hasty)](https://github.com/Pencilcaseman/hasty/blob/master/LICENSE)
[![Continuous Integration](https://github.com/Pencilcaseman/hasty/actions/workflows/continuous_integration.yaml/badge.svg)](https://github.com/Pencilcaseman/hasty/actions/workflows/continuous_integration.yaml)

# Hasty

Hasty provides a Rust-native interface to high-performance BLAS libraries, such as
[OpenBLAS](https://github.com/OpenMathLib/OpenBLAS),
[Intel MKL](https://www.intel.com/content/www/us/en/developer/tools/oneapi/onemkl.html),
[Apple Accelerate](https://developer.apple.com/documentation/accelerate), and more.

Unlike existing BLAS bindings, Hasty will automatically detect and link to the best available
BLAS library on your system without any configuration required. You can also specify a path to
a specific BLAS library via the `HASTY_BLAS_PATH` environment variable, if you wish.

*Note that you may need to perform a clean build of your project if you change the BLAS library
that Hasty links to.*

For more information, see the [documentation](https://docs.rs/hasty).

## Example

```rust
fn main() {
let lib = hasty::get_blas_library();
println!("Using BLAS Library: {lib}");

type Scalar = f32;

let m: u64 = 2;
let n: u64 = 1;
let k: u64 = 3;
let mut a: Vec = vec![0.0; (m * k) as usize];
let mut b: Vec = vec![0.0; (k * n) as usize];
let mut c: Vec = vec![0.0; (m * n) as usize];

for i in 0..(m * k) {
a[i as usize] = i as Scalar + 1.0;
}

for i in 0..(k * n) {
b[i as usize] = i as Scalar + 1.0;
}

hasty::level3::gemm(
hasty::StorageOrder::RowMajor,
hasty::Transpose::NoTrans,
hasty::Transpose::NoTrans,
m,
n,
k,
1.0,
&a,
k,
&b,
n,
0.0,
&mut c,
n,
);

println!("Result: {:?}", c);
}
```

## Development Plans

### More BLAS Libraries

Hasty currently supports a range of BLAS libraries, but it's difficult to test them all. We want to support
as many BLAS libraries as possible, so if you find a configuration that doesn't work, please open an issue.

### Fall-back BLAS Library

We aim to have fall-back implementations for all BLAS functions if we don't find a suitable BLAS library on
your system, but they will be much slower than the optimized implementations provided by BLAS libraries.
Ideally, we'd like to optimise these implementations as much as possible, but that's a tricky task and will
require contributions from the community.

### Missing Functions

Hasty is still a work in progress, and there are a ***lot*** of BLAS functions to implement.
If you need a function that isn't implemented yet, please open an issue or submit a pull request,
and I'll get it added as soon as possible!