Struct rand::distributions::Bernoulli [−][src]
pub struct Bernoulli { /* fields omitted */ }
The Bernoulli distribution.
This is a special case of the Binomial distribution where n = 1
.
Example
use rand::distributions::{Bernoulli, Distribution}; let d = Bernoulli::new(0.3); let v = d.sample(&mut rand::thread_rng()); println!("{} is from a Bernoulli distribution", v);
Precision
This Bernoulli
distribution uses 64 bits from the RNG (a u64
),
so only probabilities that are multiples of 2-64 can be
represented.
Methods
impl Bernoulli
[src]
impl Bernoulli
pub fn new(p: f64) -> Bernoulli
[src]
pub fn new(p: f64) -> Bernoulli
Construct a new Bernoulli
with the given probability of success p
.
Panics
If p < 0
or p > 1
.
Precision
For p = 1.0
, the resulting distribution will always generate true.
For p = 0.0
, the resulting distribution will always generate false.
This method is accurate for any input p
in the range [0, 1]
which is
a multiple of 2-64. (Note that not all multiples of
2-64 in [0, 1]
can be represented as a f64
.)
Trait Implementations
impl Clone for Bernoulli
[src]
impl Clone for Bernoulli
fn clone(&self) -> Bernoulli
[src]
fn clone(&self) -> Bernoulli
Returns a copy of the value. Read more
fn clone_from(&mut self, source: &Self)
1.0.0[src]
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from source
. Read more
impl Copy for Bernoulli
[src]
impl Copy for Bernoulli
impl Debug for Bernoulli
[src]
impl Debug for Bernoulli
fn fmt(&self, f: &mut Formatter) -> Result
[src]
fn fmt(&self, f: &mut Formatter) -> Result
Formats the value using the given formatter. Read more
impl Distribution<bool> for Bernoulli
[src]
impl Distribution<bool> for Bernoulli
fn sample<R: Rng + ?Sized>(&self, rng: &mut R) -> bool
[src]
fn sample<R: Rng + ?Sized>(&self, rng: &mut R) -> bool
Generate a random value of T
, using rng
as the source of randomness.
ⓘImportant traits for DistIter<'a, D, R, T>fn sample_iter<'a, R>(&'a self, rng: &'a mut R) -> DistIter<'a, Self, R, T> where
Self: Sized,
R: Rng,
[src]
fn sample_iter<'a, R>(&'a self, rng: &'a mut R) -> DistIter<'a, Self, R, T> where
Self: Sized,
R: Rng,
Create an iterator that generates random values of T
, using rng
as the source of randomness. Read more