pub struct Gev { /* private fields */ }
Expand description
Generalized Extreme Value Distribution Gev(μ, σ, ξ) where the parameters are μ is location σ is the scale ξ is the shape
f(x|μ, σ, ξ) = \frac{1}{σ} t(x)^{ξ + 1} e^{-t(x)}
t(x) = ⎰ (1 + ξ ((x - μ) / σ))^(-1/ξ) if ξ ≠ 0
⎱ e^{(μ - x) / σ} if ξ = 0
Implementations§
source§impl Gev
impl Gev
sourcepub fn new(loc: f64, scale: f64, shape: f64) -> Result<Self, GevError>
pub fn new(loc: f64, scale: f64, shape: f64) -> Result<Self, GevError>
Create a new Gev
distribution with location, scale, and shape.
sourcepub fn new_unchecked(loc: f64, scale: f64, shape: f64) -> Self
pub fn new_unchecked(loc: f64, scale: f64, shape: f64) -> Self
Creates a new Gev without checking whether the parameters are valid.
sourcepub fn loc(&self) -> f64
pub fn loc(&self) -> f64
Get the location parameter
§Example
let gev = Gev::new(1.2, 2.3, 3.4).unwrap();
assert_eq!(gev.loc(), 1.2);
sourcepub fn set_loc(&mut self, loc: f64) -> Result<(), GevError>
pub fn set_loc(&mut self, loc: f64) -> Result<(), GevError>
Set the loc parameter without input validation
§Example
let mut gev = Gev::new(1.2, 2.3, 3.4).unwrap();
assert_eq!(gev.loc(), 1.2);
gev.set_loc(2.8).unwrap();
assert_eq!(gev.loc(), 2.8);
Will error for invalid values
assert!(gev.set_loc(2.8).is_ok());
assert!(gev.set_loc(std::f64::INFINITY).is_err());
assert!(gev.set_loc(std::f64::NEG_INFINITY).is_err());
assert!(gev.set_loc(std::f64::NAN).is_err());
sourcepub fn set_loc_unchecked(&mut self, loc: f64)
pub fn set_loc_unchecked(&mut self, loc: f64)
Set the loc parameter without input validation
sourcepub fn shape(&self) -> f64
pub fn shape(&self) -> f64
Get the shape parameter
§Example
let gev = Gev::new(1.2, 2.3, 3.4).unwrap();
assert_eq!(gev.shape(), 3.4);
sourcepub fn set_shape(&mut self, shape: f64) -> Result<(), GevError>
pub fn set_shape(&mut self, shape: f64) -> Result<(), GevError>
Set the shape parameter without input validation
§Example
let mut gev = Gev::new(1.2, 2.3, 3.4).unwrap();
assert_eq!(gev.shape(), 3.4);
gev.set_shape(2.8).unwrap();
assert_eq!(gev.shape(), 2.8);
Will error for invalid values
assert!(gev.set_shape(2.8).is_ok());
assert!(gev.set_shape(std::f64::INFINITY).is_err());
assert!(gev.set_shape(std::f64::NEG_INFINITY).is_err());
assert!(gev.set_shape(std::f64::NAN).is_err());
sourcepub fn set_shape_unchecked(&mut self, shape: f64)
pub fn set_shape_unchecked(&mut self, shape: f64)
Set the shape parameter without input validation
sourcepub fn scale(&self) -> f64
pub fn scale(&self) -> f64
Get the scale parameter
§Example
let gev = Gev::new(1.2, 2.3, 3.4).unwrap();
assert_eq!(gev.scale(), 2.3);
sourcepub fn set_scale(&mut self, scale: f64) -> Result<(), GevError>
pub fn set_scale(&mut self, scale: f64) -> Result<(), GevError>
Set the scale parameter without input validation
§Example
let mut gev = Gev::new(1.2, 2.3, 3.4).unwrap();
assert_eq!(gev.scale(), 2.3);
gev.set_scale(2.8).unwrap();
assert_eq!(gev.scale(), 2.8);
Will error for invalid values
assert!(gev.set_scale(2.8).is_ok());
assert!(gev.set_scale(0.0).is_err());
assert!(gev.set_scale(-1.0).is_err());
assert!(gev.set_scale(std::f64::INFINITY).is_err());
assert!(gev.set_scale(std::f64::NEG_INFINITY).is_err());
assert!(gev.set_scale(std::f64::NAN).is_err());
sourcepub fn set_scale_unchecked(&mut self, scale: f64)
pub fn set_scale_unchecked(&mut self, scale: f64)
Set the scale parameter without input validation
Trait Implementations§
source§impl ContinuousDistr<f32> for Gev
impl ContinuousDistr<f32> for Gev
source§impl ContinuousDistr<f64> for Gev
impl ContinuousDistr<f64> for Gev
source§impl<'de> Deserialize<'de> for Gev
impl<'de> Deserialize<'de> for Gev
source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
impl StructuralPartialEq for Gev
Auto Trait Implementations§
impl Freeze for Gev
impl RefUnwindSafe for Gev
impl Send for Gev
impl Sync for Gev
impl Unpin for Gev
impl UnwindSafe for Gev
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
Mutably borrows from an owned value. Read more
source§impl<Fx> Rv<Datum> for Fxwhere
Fx: RvDatum,
impl<Fx> Rv<Datum> for Fxwhere
Fx: RvDatum,
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>
The inverse inclusion map: attempts to construct
self
from the equivalent element of its
superset. Read moresource§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
Checks if
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
Use with care! Same as
self.to_subset
but without any property checks. Always succeeds.source§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
The inclusion map: converts
self
to the equivalent element of its superset.