#random-seed #rand #xoshiro256plusplus

bin+lib lazyrand

It is a simple library for generating random numbers easily

13 releases

0.1.13 Jul 27, 2024
0.1.12 Feb 24, 2024
0.1.9 Sep 12, 2023
0.1.5 Apr 1, 2023
0.1.4 Mar 30, 2023

#519 in Algorithms

MIT license

20KB
446 lines

lazyrand for Rust

This is a library for generating random numbers easily. The random seed is automatically initialized. This crate supports WASM.

This library can be used for various purposes such as games and dice. However, this library is not cryptographically secure.

It uses xoshiro256++ for random number generation.

Install

Run the following command in your terminal:

cargo add lazyrand

Examples

Generate random number

let num = lazyrand::randint(1, 6);
println!("random number = {}", num);

Generate random number with seed. It can be used to generate the same random number sequence.

lazyrand::set_seed(123456);
let n1 = lazyrand::rand() % 6 + 1;
let n2 = lazyrand::rand() % 6 + 1;
let n3 = lazyrand::rand() % 6 + 1;
println!("nums = [{}, {}, {}]", n1, n2, n3);

Examples - Slice

Shuffle slice

let mut a = vec![1, 2, 3, 4, 5];
lazyrand::shuffle(&mut a);
println!("shuffled = {:?}", a); // (ex) shuffled = [2, 4, 1, 5, 3]

choice one number from slice

let a = vec![1, 2, 3];
let n = lazyrand::choice(&a);
println!("choice = {:?}", n); // (ex) choice = Some(5)

choice one &str from slice

let mut a = vec!["apple", "banana", "orange"];
let s = lazyrand::choice(&a).unwrap();
println!("choice = {}", s); // (ex) choice = orange

Examples with Random struct

Generate random number with Random struct

use lazyrand::Random;
fn main() {
    // Create Random generator
    let mut random = Random::new();
    println!("random number = {}", random.randint(1, 6));

    let msg: &str = random.choice(&["hello", "hi", "bye"]).unwrap();
    println!("random message = {}", msg);
}

How to Use Lazyrand with WASM

Please see test_wasm.

methods

  • set_seed(seed) / srand(seed) / generate_seed()
  • randint(min, max)
  • shuffle(&mut slice)
  • choice(&slice)
  • rand() / rand_bool() / rand_usize() / rand_isize() / rand_f64()

Dependencies

~24–250KB