fastrand

Build License Cargo Documentation

A simple and fast random number generator.

The implementation uses Wyrand, a simple and fast generator but not cryptographically secure.

Examples

Flip a coin:

rust if fastrand::bool() { println!("heads"); } else { println!("tails"); }

Generate a random i32:

rust let num = fastrand::i32(..);

Choose a random element in an array:

rust let v = vec![1, 2, 3, 4, 5]; let i = fastrand::usize(..v.len()); let elem = v[i];

Sample values from an array with O(n) complexity (n is the length of array):

rust fastrand::choose_multiple(vec![1, 4, 5].iter(), 2); fastrand::choose_multiple(0..20, 12);

Shuffle an array:

rust let mut v = vec![1, 2, 3, 4, 5]; fastrand::shuffle(&mut v);

Generate a random Vec or String:

```rust use std::iter::repeat_with;

let v: Vec = repeatwith(|| fastrand::i32(..)).take(10).collect(); let s: String = repeatwith(fastrand::alphanumeric).take(10).collect(); ```

To get reproducible results on every run, initialize the generator with a seed:

```rust // Pick an arbitrary number as seed. fastrand::seed(7);

// Now this prints the same number on every run: println!("{}", fastrand::u32(..)); ```

To be more efficient, create a new Rng instance instead of using the thread-local generator:

```rust use std::iter::repeat_with;

let rng = fastrand::Rng::new(); let mut bytes: Vec = repeatwith(|| rng.u8(..)).take(10000).collect(); ```

Features

License

Licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.