pub struct Choose<'a, T> { /* private fields */ }Expand description
A distribution to uniformly sample elements of a slice
Like IndexedRandom::choose, this uniformly samples elements of a slice
without modification of the slice (so called “sampling with replacement”).
This distribution object may be a little faster for repeated sampling (but
slower for small numbers of samples).
§Examples
Since this is a distribution, Rng::sample_iter and
Distribution::sample_iter may be used, for example:
use rand::distr::{Distribution, slice::Choose};
let vowels = ['a', 'e', 'i', 'o', 'u'];
let vowels_dist = Choose::new(&vowels).unwrap();
// build a string of 10 vowels
let vowel_string: String = vowels_dist
    .sample_iter(&mut rand::rng())
    .take(10)
    .collect();
println!("{}", vowel_string);
assert_eq!(vowel_string.len(), 10);
assert!(vowel_string.chars().all(|c| vowels.contains(&c)));For a single sample, IndexedRandom::choose may be preferred:
use rand::seq::IndexedRandom;
let vowels = ['a', 'e', 'i', 'o', 'u'];
let mut rng = rand::rng();
println!("{}", vowels.choose(&mut rng).unwrap());Implementations§
Trait Implementations§
Source§impl<'a, T> Distribution<&'a T> for Choose<'a, T>
 
impl<'a, T> Distribution<&'a T> for Choose<'a, T>
Source§impl SampleString for Choose<'_, char>
 
impl SampleString for Choose<'_, char>
impl<'a, T: Copy> Copy for Choose<'a, T>
Auto Trait Implementations§
impl<'a, T> Freeze for Choose<'a, T>
impl<'a, T> RefUnwindSafe for Choose<'a, T>where
    T: RefUnwindSafe,
impl<'a, T> Send for Choose<'a, T>where
    T: Sync,
impl<'a, T> Sync for Choose<'a, T>where
    T: Sync,
impl<'a, T> Unpin for Choose<'a, T>
impl<'a, T> UnwindSafe for Choose<'a, T>where
    T: RefUnwindSafe,
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