Struct rand_distr::Exp1
source · pub struct Exp1;
Expand description
Samples floating-point numbers according to the exponential distribution,
with rate parameter λ = 1
. This is equivalent to Exp::new(1.0)
or
sampling with -rng.gen::<f64>().ln()
, but faster.
See Exp
for the general exponential distribution.
Implemented via the ZIGNOR variant1 of the Ziggurat method. The exact description in the paper was adjusted to use tables for the exponential distribution rather than normal.
Example
use rand::prelude::*;
use rand_distr::Exp1;
let val: f64 = thread_rng().sample(Exp1);
println!("{}", val);
Jurgen A. Doornik (2005). An Improved Ziggurat Method to Generate Normal Random Samples. Nuffield College, Oxford ↩
Trait Implementations§
source§impl Distribution<f32> for Exp1
impl Distribution<f32> for Exp1
source§fn sample<R: Rng + ?Sized>(&self, rng: &mut R) -> f32
fn sample<R: Rng + ?Sized>(&self, rng: &mut R) -> f32
Generate a random value of
T
, using rng
as the source of randomness.source§impl Distribution<f64> for Exp1
impl Distribution<f64> for Exp1
source§fn sample<R: Rng + ?Sized>(&self, rng: &mut R) -> f64
fn sample<R: Rng + ?Sized>(&self, rng: &mut R) -> f64
Generate a random value of
T
, using rng
as the source of randomness.impl Copy for Exp1
Auto Trait Implementations§
impl RefUnwindSafe for Exp1
impl Send for Exp1
impl Sync for Exp1
impl Unpin for Exp1
impl UnwindSafe for Exp1
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