rust/README.md

59 lines
2.7 KiB
Markdown
Raw Normal View History

# The Rust standard library's portable SIMD API
2021-11-15 18:36:21 +05:30
![Build Status](https://github.com/rust-lang/portable-simd/actions/workflows/ci.yml/badge.svg?branch=master)
2020-09-21 20:03:54 -06:00
Code repository for the [Portable SIMD Project Group](https://github.com/rust-lang/project-portable-simd).
2020-10-12 14:31:55 -07:00
Please refer to [CONTRIBUTING.md](./CONTRIBUTING.md) for our contributing guidelines.
2021-02-09 12:52:27 +10:00
The docs for this crate are published from the main branch.
You can [read them here][docs].
2020-10-12 14:31:55 -07:00
If you have questions about SIMD, we have begun writing a [guide][simd-guide].
We can also be found on [Zulip][zulip-project-portable-simd].
If you are interested in support for a specific architecture, you may want [stdarch] instead.
2020-09-21 20:03:54 -06:00
## Hello World
Now we're gonna dip our toes into this world with a small SIMD "Hello, World!" example. Make sure your compiler is up to date and using `nightly`. We can do that by running
```bash
rustup update -- nightly
```
2021-06-26 17:08:40 +00:00
or by setting up `rustup default nightly` or else with `cargo +nightly {build,test,run}`. After updating, run
```bash
cargo new hellosimd
```
2022-10-16 13:52:08 -04:00
to create a new crate. Finally write this in `src/main.rs`:
```rust
#![feature(portable_simd)]
2022-10-16 13:52:08 -04:00
use std::simd::f32x4;
fn main() {
let a = f32x4::splat(10.0);
let b = f32x4::from_array([1.0, 2.0, 3.0, 4.0]);
println!("{:?}", a + b);
}
```
2022-10-16 13:52:08 -04:00
Explanation: We construct our SIMD vectors with methods like `splat` or `from_array`. Next, we can use operators like `+` on them, and the appropriate SIMD instructions will be carried out. When we run `cargo run` you should get `[11.0, 12.0, 13.0, 14.0]`.
2020-09-26 20:57:32 -06:00
2022-10-16 13:52:08 -04:00
## Supported vectors
2020-09-26 20:57:32 -06:00
2022-10-16 13:52:08 -04:00
Currently, vectors may have up to 64 elements, but aliases are provided only up to 512-bit vectors.
2020-09-26 20:57:32 -06:00
Depending on the size of the primitive type, the number of lanes the vector will have varies. For example, 128-bit vectors have four `f32` lanes and two `f64` lanes.
The supported element types are as follows:
* **Floating Point:** `f32`, `f64`
2022-10-16 13:52:08 -04:00
* **Signed Integers:** `i8`, `i16`, `i32`, `i64`, `isize` (`i128` excluded)
* **Unsigned Integers:** `u8`, `u16`, `u32`, `u64`, `usize` (`u128` excluded)
* **Masks:** 8-bit, 16-bit, 32-bit, 64-bit, and `usize`-sized masks
2020-09-26 20:57:32 -06:00
Floating point, signed integers, and unsigned integers are the [primitive types](https://doc.rust-lang.org/core/primitive/index.html) you're already used to.
The mask types have elements that are "truthy" values, like `bool`, but have an unspecified layout because different architectures prefer different layouts for mask types.
2020-10-12 14:31:55 -07:00
[simd-guide]: ./beginners-guide.md
[zulip-project-portable-simd]: https://rust-lang.zulipchat.com/#narrow/stream/257879-project-portable-simd
[stdarch]: https://github.com/rust-lang/stdarch
[docs]: https://rust-lang.github.io/portable-simd/core_simd