Struct statrs::distribution::Pareto [−][src]
pub struct Pareto { /* fields omitted */ }
Implements the Pareto distribution
Examples
use statrs::distribution::{Pareto, Continuous}; use statrs::statistics::Mean; use statrs::prec; let p = Pareto::new(1.0, 2.0).unwrap(); assert_eq!(p.mean(), 2.0); assert!(prec::almost_eq(p.pdf(2.0), 0.25, 1e-15));
Implementations
impl Pareto
[src]
impl Pareto
[src]pub fn new(scale: f64, shape: f64) -> Result<Pareto>
[src]
Constructs a new Pareto distribution with scale scale
, and shape
shape.
Errors
Returns an error if any of scale
or shape
are NaN
.
Returns an error if scale <= 0.0
or shape <= 0.0
Examples
use statrs::distribution::Pareto; let mut result = Pareto::new(1.0, 2.0); assert!(result.is_ok()); result = Pareto::new(0.0, 0.0); assert!(result.is_err());
pub fn scale(&self) -> f64
[src]
Returns the scale of the Pareto distribution
Examples
use statrs::distribution::Pareto; let n = Pareto::new(1.0, 2.0).unwrap(); assert_eq!(n.scale(), 1.0);
pub fn shape(&self) -> f64
[src]
Returns the shape of the Pareto distribution
Examples
use statrs::distribution::Pareto; let n = Pareto::new(1.0, 2.0).unwrap(); assert_eq!(n.shape(), 2.0);
Trait Implementations
impl CheckedSkewness<f64> for Pareto
[src]
impl CheckedSkewness<f64> for Pareto
[src]impl Continuous<f64, f64> for Pareto
[src]
impl Continuous<f64, f64> for Pareto
[src]fn pdf(&self, x: f64) -> f64
[src]
Calculates the probability density function for the Pareto distribution
at x
Formula
ⓘ
if x < x_m { 0 } else { (α * x_m^α)/(x^(α + 1)) }
where x_m
is the scale and α
is the shape
fn ln_pdf(&self, x: f64) -> f64
[src]
Calculates the log probability density function for the Pareto
distribution at x
Formula
ⓘ
if x < x_m { -INF } else { ln(α) + α*ln(x_m) - (α + 1)*ln(x) }
where x_m
is the scale and α
is the shape
impl Distribution<f64> for Pareto
[src]
impl Distribution<f64> for Pareto
[src]impl Univariate<f64, f64> for Pareto
[src]
impl Univariate<f64, f64> for Pareto
[src]impl Variance<f64> for Pareto
[src]
impl Variance<f64> for Pareto
[src]fn variance(&self) -> f64
[src]
Returns the variance of the Pareto distribution
Formula
ⓘ
if α <= 2 { INF } else { (x_m/(α - 1))^2 * (α/(α - 2)) }
where x_m
is the scale and α
is the shape
fn std_dev(&self) -> f64
[src]
Returns the standard deviation of the Pareto distribution
Formula
ⓘ
let variance = if α <= 2 { INF } else { (x_m/(α - 1))^2 * (α/(α - 2)) }; sqrt(variance)
where x_m
is the scale and α
is the shape