8 stable releases

1.5.1 Dec 20, 2024
1.5.0 Dec 18, 2024
1.3.0 Mar 18, 2021
1.2.0 Jun 20, 2020
0.0.1 Jun 14, 2020

#94 in Algorithms

Download history 1409/week @ 2024-10-05 1577/week @ 2024-10-12 2053/week @ 2024-10-19 1672/week @ 2024-10-26 2031/week @ 2024-11-02 1291/week @ 2024-11-09 1771/week @ 2024-11-16 1209/week @ 2024-11-23 892/week @ 2024-11-30 1572/week @ 2024-12-07 1370/week @ 2024-12-14 967/week @ 2024-12-21 715/week @ 2024-12-28 1509/week @ 2025-01-04 2178/week @ 2025-01-11 1900/week @ 2025-01-18

6,491 downloads per month
Used in 11 crates (3 directly)

MIT license

40KB
1K SLoC

simplerand

Latest Version Minimum rustc version

Simple and fast random number generator

Motivation

I've worked on a fake data generator, which strongly relies on random number generation. The package, which serves this purpose in the world of Rust was the rand package. That's a cool package, if you want to have enterprise-level random generation. But for a simple fake data generator it's huge. Whatsoever, it takes 400+ microsec to generate a random number. (struggle)

So I`ve created a much simpler pseudo-random generator based on a very simple seeding mechanism. That won't serve cryptographic random generations! So it's only useful for projects like a fake data generator where a simple and fast solution is needed. Thid way I can generate random numbers in ~200 nanosec.

The random number generation is strongly based on the linear congruential generators, so if you are familiar with the algorithm you can imagine how simple it is.

Usage

extern crate simplerand;

use simplerand::{randn, rand_range};

fn main() {
    let data = randn(10000);
    println!("data: {}", data); // output: something between 0 and 10000

    let data = rand_range(3000, 10000);
    println!("data: {}", data); // output: something between 3000 and 10000

    let generic_data = rand_range::<f32>(1000.123, 30000.123)
    println!("data: {}", generic_data);
}
Use Randomable
extern crate simplerand;

use simplerand::{Randomable, rand_range};

fn main() {
    let generic_data = get_random_in_range::<u32>(10, 33);
    println!("data: {}", generic_data);
}

fn get_random_in_range<T: Randomable>(min: T, max: T) -> T {
    rand_range::<T>(min, max)
}
Singleton implementation
#[macro_use]
extern crate lazy_static;
extern crate simplerand;

use std::sync::Mutex;

lazy_static! {
    static ref rand: Mutex<simplerand::Rng> = Mutex::new(simplerand::Rng::new());
}

fn main() {
    let number = RNG.lock().unwrap().rand_range(0, 10000); // output: something between 0 and 10000
}

rand package

Since it took 400 microsec to generate a random number I thought it's because of the seeding mechanism. I wanted to setup the rand's ThreadRng as a static singleton variable on top of my declaration. I also used lazy_static to achive it, but it's not designed for that purpose, so I couldn't make it happen. (If someone has a solution for that I'm curious to see.)

Dependencies

~10KB