pub struct Exponential { /* private fields */ }Expand description
§The Exponential Distribution
§Description:
Density, distribution function, quantile function and random generation for the exponential distribution with rate ‘rate’ (i.e., mean ‘1/rate’).
§Arguments:
- rate.
- scale: 1 / rate
§Details:
If ‘rate’ is not specified, it assumes the default value of ‘1’.
The exponential distribution with rate lambda has density
$ f(x) = lambda {e}^{- lambda x} $
for $x >= 0$.
§Density Plot
let exp = ExponentialBuilder::new().build();
let x = <[f64]>::sequence(-0.5, 4.0, 1000);
let y = x
.iter()
.map(|x| exp.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();§Note:
The cumulative hazard $H(t) = - \text{log}(1 - F(t))$ is ‘-pexp(t, r, lower = FALSE, log = TRUE)’.
§Source:
‘dexp’, ‘pexp’ and ‘qexp’ are all calculated from numerically stable versions of the definitions.
‘rexp’ uses
Ahrens, J. H. and Dieter, U. (1972). Computer methods for sampling from the exponential and normal distributions. Communications of the ACM, 15, 873-882.
§References:
Becker, R. A., Chambers, J. M. and Wilks, A. R. (1988) The New S Language. Wadsworth & Brooks/Cole.
Johnson, N. L., Kotz, S. and Balakrishnan, N. (1995) Continuous Univariate Distributions, volume 1, chapter 19. Wiley, New York.
§See Also:
‘exp’ for the exponential function.
Distributions for other standard distributions, including ‘dgamma’ for the gamma distribution and ‘dweibull’ for the Weibull distribution, both of which generalize the exponential.
§Examples:
println!("{}", (-1.0_f64).exp());
println!("{}", exp.density(1));A fast way to generate sorted U[0,1] random numbers
let rsunif = |n| {
let mut rng = MersenneTwister::new();
rng.set_seed(1);
let exp = ExponentialBuilder::new().build();
let ce = (0..n)
.map(|_| exp.random_sample(&mut rng).unwrap())
.collect::<Vec<_>>()
.cumsum();
let ce_max = ce[n - 1];
ce.into_iter().map(|ce| ce / ce_max).collect::<Vec<_>>()
};
let x = (0..1000).map(|x| x as f64).collect::<Vec<_>>();
let y = rsunif(1000);
let root = SVGBackend::new("rsunif.svg", (1024, 768)).into_drawing_area();
Plot::new()
.with_options(PlotOptions {
x_axis_label: "index".to_string(),
y_axis_label: "rsunif".to_string(),
..Default::default()
})
.with_plottable(Line {
x: vec![0.0, 1000.0],
y: vec![0.0, 1.0],
color: GREY_500,
..Default::default()
})
.with_plottable(Points {
x,
y,
color: BLACK,
..Default::default()
})
.plot(&root)
.unwrap();Trait Implementations§
Source§impl Distribution for Exponential
impl Distribution for Exponential
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 Exponential
impl RefUnwindSafe for Exponential
impl Send for Exponential
impl Sync for Exponential
impl Unpin for Exponential
impl UnwindSafe for Exponential
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.