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 Bernoullipub fn new(p: f64) -> Bernoulli[src]
pub fn new(p: f64) -> BernoulliConstruct 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 Bernoullifn clone(&self) -> Bernoulli[src]
fn clone(&self) -> BernoulliReturns 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 Bernoulliimpl Debug for Bernoulli[src]
impl Debug for Bernoullifn fmt(&self, f: &mut Formatter) -> Result[src]
fn fmt(&self, f: &mut Formatter) -> ResultFormats the value using the given formatter. Read more
impl Distribution<bool> for Bernoulli[src]
impl Distribution<bool> for Bernoullifn sample<R: Rng + ?Sized>(&self, rng: &mut R) -> bool[src]
fn sample<R: Rng + ?Sized>(&self, rng: &mut R) -> boolGenerate 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