lazyrand

Crates.iolazyrand
lib.rslazyrand
version0.1.13
sourcesrc
created_at2023-03-29 07:22:03.307558
updated_at2024-07-27 14:23:46.957153
descriptionIt is a simple library for generating random numbers easily.
homepage
repositoryhttps://github.com/kujirahand/rust-lazyrand
max_upload_size
id823822
size24,136
kujirahand (kujirahand)

documentation

README

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

Commit count: 20

cargo fmt