Struct rand_distr::Zipf
source · [−]pub struct Zipf<F> where
F: Float,
Standard: Distribution<F>, { /* private fields */ }
Expand description
Samples integers according to the Zipf distribution.
The samples follow Zipf’s law: The frequency of each sample from a finite
set of size n
is inversely proportional to a power of its frequency rank
(with exponent s
).
For large n
, this converges to the Zeta
distribution.
For s = 0
, this becomes a uniform distribution.
Example
use rand::prelude::*;
use rand_distr::Zipf;
let val: f64 = thread_rng().sample(Zipf::new(10, 1.5).unwrap());
println!("{}", val);
Implementation details
Implemented via rejection sampling, due to Jason Crease1.
Implementations
Trait Implementations
Generate a random value of T
, using rng
as the source of randomness.
fn sample_iter<R>(self, rng: R) -> DistIter<Self, R, T>ⓘ where
R: Rng,
fn sample_iter<R>(self, rng: R) -> DistIter<Self, R, T>ⓘ where
R: Rng,
Create an iterator that generates random values of T
, using rng
as
the source of randomness. Read more
Auto Trait Implementations
impl<F> RefUnwindSafe for Zipf<F> where
F: RefUnwindSafe,
impl<F> UnwindSafe for Zipf<F> where
F: UnwindSafe,
Blanket Implementations
Mutably borrows from an owned value. Read more