Expand description
Simba is a crate defining a set of trait for writing code that can be generic with regard to the
number of lanes of the numeric input value. Those traits are implemented by f32, u32, i16,
bool as well as SIMD types like f32x4, u32x8, i16x2, etc.
One example of use-case applied by the nalgebra crate is to define generic methods
like vector normalization that will work for Vector3<f32> as well as Vector3<f32x4>.
This makes it easier leverage the power of SIMD Array-of-Struct-of-Array (AoSoA) with less code duplication.
Cargo features
Two cargo features can be optionally enabled:
- With the packed_simdfeature enabled, thesimba::simdmodule will export several SIMD types likef32x2,f64x4,i32i8,u16i16, etc. There types are wrappers around the SIMD types from the packed_simd crate. This requires a nightly compiler.
- With the widefeature enabled, thesimba::simdmodule will export theWideF32x4andWideBoolF32x4types. They types ure wrapper around thewide::f32x4type from the wide crate. This will work with both a stable or nightly compiler.
If none of those features are enabled, simba will still define all the scalar and SIMD traits. However, the SIMD traits won’t be implemented for any SIMD types. Therefore it is recommended to:
- Use the packed_simdfeature if you want more features, and can afford to use a nightly compiler.
- Use the widefeature if you only need 4-lanes 32-bits floats, and can’t afford to use a nightly compiler.