#simd #u8 #i32 #f32 #vector #i16 #argmin

argmm

Argmin and argmax with SIMD support for u8, u16, i16, i32 and f32

3 releases

0.1.2 Jul 29, 2020
0.1.1 Jul 28, 2020
0.1.0 Feb 8, 2020

#602 in Hardware support

Download history 7/week @ 2024-07-23 1/week @ 2024-09-17 5/week @ 2024-09-24 2/week @ 2024-10-01 139/week @ 2024-10-08 1/week @ 2024-10-15 2/week @ 2024-10-22 48/week @ 2024-10-29 181/week @ 2024-11-05

233 downloads per month

MIT/Apache

42KB
962 lines

Argmm

Argmin/max with SIMD support for u8, i16, u16, i32 and f32 arrays and vectors.

Installing

Add the following to your Cargo.toml

argmm = "0.1.2"

Getting started

You can use the extention trait which will take advantage of SIMD if available

use argmm::ArgMinMax;

fn main() {
    let v = vec![1., 3., -20., 50., -82., 9., -53., 60., 0.];
    let min_index = v.argmin();
    let max_index = v.argmax();
    assert_eq!(min_index, Some(4));
    assert_eq!(max_index, Some(7));
}

Alternatively, the generic function can be used if you require non-SIMD support for other types

use argmm::generic::{simple_argmin, simple_argmax};

fn main() {
    let v = vec![1u64, 3, 20, 50, 82, 9, 53, 60, 0];
    let min_index = simple_argmin(&v);
    let max_index = simple_argmax(&v);
    assert_eq!(min_index, 8);
    assert_eq!(max_index, 4);
}

Benchmarks

Using a MacBook Pro (Retina, 13-inch, Early 2015) Processor 2.7 GHz Dual-Core Intel Core i5 with an array size of 512.

See /benches/results.

Warning

NAN values are not supported.

License

Licensed under either of

No runtime deps