Go to file
Taiki Endo 4269d5dc45 Update actions/checkout action to v4 2023-09-10 18:27:13 +09:00
.github Update actions/checkout action to v4 2023-09-10 18:27:13 +09:00
benches Remove interior mutability from Rng (#47) 2023-02-12 19:57:40 -08:00
src Add smol-rs logo (#64) 2023-07-17 14:40:55 +09:00
tests Add choose_multple function for choosing several values (#55) 2023-03-23 10:31:42 +01:00
.gitignore Initial commit 2020-05-27 18:18:29 +02:00
CHANGELOG.md v2.0.0 2023-06-08 18:58:39 -07:00
Cargo.toml v2.0.0 2023-06-08 18:58:39 -07:00
LICENSE-APACHE Initial commit 2020-05-27 18:18:29 +02:00
LICENSE-MIT Initial commit 2020-05-27 18:18:29 +02:00
README.md Mention no_std support in the docs (#58) 2023-04-07 12:02:02 -07:00

README.md

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:

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

Generate a random i32:

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

Choose a random element in an array:

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):

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

Shuffle an array:

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

Generate a random Vec or String:

use std::iter::repeat_with;

let v: Vec<i32> = repeat_with(|| fastrand::i32(..)).take(10).collect();
let s: String = repeat_with(fastrand::alphanumeric).take(10).collect();

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

// 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:

use std::iter::repeat_with;

let rng = fastrand::Rng::new();
let mut bytes: Vec<u8> = repeat_with(|| rng.u8(..)).take(10_000).collect();

Features

  • std (enabled by default): Enables the std library. This is required for the global generator and global entropy. Without this feature, [Rng] can only be instantiated using the with_seed method.

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.