pub struct Geometric { /* private fields */ }Expand description
§The Geometric Distribution
§Description
Density, distribution function, quantile function and random generation for the geometric distribution with parameter prob.
§Arguments
- x, q: quantiles representing the number of failures in a sequence of Bernoulli trials before success occurs.
- prob: probability of success in each trial. 0 < prob <= 1.
§Details
The geometric distribution with prob = p has density
$ p(x) = p (1-p)^x $
for x = 0, 1, 2, …, 0 < p ≤ 1.
If an element of x is not integer, the result of dgeom is zero, with a warning.
The quantile is defined as the smallest value x such that $ F(x) ≥ p $, where F is the distribution function.
§Density Plot
let geom = GeometricBuilder::new().build();
let x = <[f64]>::sequence_by(-1.0, 1.0, 0.001);
let y = x
.iter()
.map(|x| geom.density(x).unwrap())
.collect::<Vec<_>>();
let root = SVGBackend::new("density.svg", (1024, 768)).into_drawing_area();
Plot::new()
.with_options(PlotOptions {
x_axis_label: "x".to_string(),
y_axis_label: "density".to_string(),
..Default::default()
})
.with_plottable(Line {
x,
y,
color: BLACK,
..Default::default()
})
.plot(&root)
.unwrap();§Source
dgeom computes via dbinom, using code contributed by Catherine Loader (see dbinom).
pgeom and qgeom are based on the closed-form formulae.
rgeom uses the derivation as an exponential mixture of Poissons, see
Devroye, L. (1986) Non-Uniform Random Variate Generation. Springer-Verlag, New York. Page 480.
§See Also
Distributions for other standard distributions, including dnbinom for the negative binomial which generalizes the geometric distribution.
§Examples
let x = (1..=9).map(|i| i as f64 / 10.0).collect::<Vec<_>>();
let geom = GeometricBuilder::new()
.with_success_probability(0.2)
.build();
let r = x
.iter()
.map(|x| geom.quantile(x, true).unwrap())
.collect::<Vec<_>>();
println!("{r:?}");let mut rng = MersenneTwister::new();
rng.set_seed(1);
let geom = GeometricBuilder::new()
.with_success_probability(0.25)
.build();
let mut r = (0..20)
.map(|_| geom.random_sample(&mut rng).unwrap() as usize)
.fold(HashMap::new(), |mut acc, r| {
*acc.entry(r).or_insert(0) += 1;
acc
})
.into_iter()
.collect::<Vec<_>>();
r.sort_by(|(i1, _), (i2, _)| i1.cmp(i2));
for (key, index) in &r {
println!("{key:2}: {index}");
}Trait Implementations§
Source§impl Distribution for Geometric
impl Distribution for Geometric
Source§fn log_density<R: Into<Real64>>(&self, x: R) -> Real64
fn log_density<R: Into<Real64>>(&self, x: R) -> Real64
Source§fn probability<R: Into<Real64>>(&self, q: R, lower_tail: bool) -> Probability64
fn probability<R: Into<Real64>>(&self, q: R, lower_tail: bool) -> Probability64
Source§fn log_probability<R: Into<Real64>>(
&self,
q: R,
lower_tail: bool,
) -> LogProbability64
fn log_probability<R: Into<Real64>>( &self, q: R, lower_tail: bool, ) -> LogProbability64
Source§fn quantile<P: Into<Probability64>>(&self, p: P, lower_tail: bool) -> Real64
fn quantile<P: Into<Probability64>>(&self, p: P, lower_tail: bool) -> Real64
Source§fn log_quantile<LP: Into<LogProbability64>>(
&self,
p: LP,
lower_tail: bool,
) -> Real64
fn log_quantile<LP: Into<LogProbability64>>( &self, p: LP, lower_tail: bool, ) -> Real64
Auto Trait Implementations§
impl Freeze for Geometric
impl RefUnwindSafe for Geometric
impl Send for Geometric
impl Sync for Geometric
impl Unpin for Geometric
impl UnwindSafe for Geometric
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
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
Source§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
self from the equivalent element of its
superset. Read moreSource§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
self is actually part of its subset T (and can be converted to it).Source§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
self.to_subset but without any property checks. Always succeeds.Source§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
self to the equivalent element of its superset.