| Crates.io | simd-itertools |
| lib.rs | simd-itertools |
| version | 0.3.0 |
| created_at | 2024-07-10 23:44:00.902654+00 |
| updated_at | 2025-02-08 13:24:05.62444+00 |
| description | SIMD-accelerated alternatives for common operations like contains, max, find etc. |
| homepage | |
| repository | https://github.com/LaihoE/SIMD-itertools |
| max_upload_size | |
| id | 1298908 |
| size | 178,033 |
let needles = [42, 52, 94];
arr.iter().any_simd(|x| needles.contains(x) || x > 156);
Works by letting LLVM do the vectorization (may change in the future).
Functions are made easy to paste into Godbolt for inspection.
Currently the following are implemented:
find
filter
position
all
any
argmin/argmax
Every piece of software makes tradeoffs. The goal of this library it to provide the majority of performance gains gained from going scalar -> vectorized, while staying user-friendly. If you are looking to shave off the last few cycles this might not be what you are looking for.
The library makes one extra assumption over the stdlib: The closure may be executed any number of times:
arr.iter().simd_position(|x| {
println!("hello world");
*x == 42
})
May print a different number of times compared to the standard library. This shouldn't be an issue under normal use-cases but something to keep in mind.
It's tricky. Hopefully one day.