pub struct Rng { /* private fields */ }Expand description
Lightweight seeded pseudo-random number generator (xoshiro256**). Used throughout procedural generation for reproducibility.
Implementations§
Source§impl Rng
impl Rng
pub fn new(seed: u64) -> Self
Sourcepub fn range_usize(&mut self, n: usize) -> usize
pub fn range_usize(&mut self, n: usize) -> usize
Next usize in [0, n).
Sourcepub fn pick<'a, T>(&mut self, slice: &'a [T]) -> Option<&'a T>
pub fn pick<'a, T>(&mut self, slice: &'a [T]) -> Option<&'a T>
Pick a random element from a slice.
Sourcepub fn pick_weighted<'a, T>(&mut self, items: &'a [(T, f32)]) -> Option<&'a T>
pub fn pick_weighted<'a, T>(&mut self, items: &'a [(T, f32)]) -> Option<&'a T>
Pick a random element from a weighted list. Weights can be any positive f32.
Sourcepub fn gaussian(&mut self, mean: f32, stddev: f32) -> f32
pub fn gaussian(&mut self, mean: f32, stddev: f32) -> f32
Gaussian sample with given mean and stddev (Box-Muller).
Trait Implementations§
Auto Trait Implementations§
impl Freeze for Rng
impl RefUnwindSafe for Rng
impl Send for Rng
impl Sync for Rng
impl Unpin for Rng
impl UnsafeUnpin for Rng
impl UnwindSafe for Rng
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more