Struct average::Covariance

source ·
pub struct Covariance { /* private fields */ }
Expand description

Estimate the arithmetic means and the covariance of a sequence of number pairs (“population”).

Because the variances are calculated as well, this can be used to calculate the Pearson correlation coefficient.

§Example

use average::Covariance;

let a: Covariance = [(1., 5.), (2., 4.), (3., 3.), (4., 2.), (5., 1.)].iter().cloned().collect();
assert_eq!(a.mean_x(), 3.);
assert_eq!(a.mean_y(), 3.);
assert_eq!(a.population_covariance(), -2.0);
assert_eq!(a.sample_covariance(), -2.5);

Implementations§

source§

impl Covariance

source

pub fn new() -> Covariance

Create a new covariance estimator.

source

pub fn add(&mut self, x: f64, y: f64)

Add an observation sampled from the population.

source

pub fn population_covariance(&self) -> f64

Calculate the population covariance of the sample.

This is a biased estimator of the covariance of the population.

Returns NaN for an empty sample.

source

pub fn sample_covariance(&self) -> f64

Calculate the sample covariance.

This is an unbiased estimator of the covariance of the population.

Returns NaN for samples of size 1 or less.

source

pub fn pearson(&self) -> f64

Available on crate features std or libm only.

Calculate the population Pearson correlation coefficient.

Returns NaN for an empty sample.

source

pub fn len(&self) -> u64

Return the sample size.

source

pub fn is_empty(&self) -> bool

Determine whether the sample is empty.

source

pub fn mean_x(&self) -> f64

Estimate the mean of the x population.

Returns NaN for an empty sample.

source

pub fn mean_y(&self) -> f64

Estimate the mean of the y population.

Returns NaN for an empty sample.

source

pub fn sample_variance_x(&self) -> f64

Calculate the sample variance of x.

This is an unbiased estimator of the variance of the population.

Returns NaN for samples of size 1 or less.

source

pub fn population_variance_x(&self) -> f64

Calculate the population variance of the sample for x.

This is a biased estimator of the variance of the population.

Returns NaN for an empty sample.

source

pub fn sample_variance_y(&self) -> f64

Calculate the sample variance of y.

This is an unbiased estimator of the variance of the population.

Returns NaN for samples of size 1 or less.

source

pub fn population_variance_y(&self) -> f64

Calculate the population variance of the sample for y.

This is a biased estimator of the variance of the population.

Returns NaN for an empty sample.

Trait Implementations§

source§

impl Clone for Covariance

source§

fn clone(&self) -> Covariance

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for Covariance

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Default for Covariance

source§

fn default() -> Covariance

Returns the “default value” for a type. Read more
source§

impl<'de> Deserialize<'de> for Covariance

source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
source§

impl<'a> Extend<&'a (f64, f64)> for Covariance

source§

fn extend<T: IntoIterator<Item = &'a (f64, f64)>>(&mut self, iter: T)

Extends a collection with the contents of an iterator. Read more
source§

fn extend_one(&mut self, item: A)

🔬This is a nightly-only experimental API. (extend_one)
Extends a collection with exactly one element.
source§

fn extend_reserve(&mut self, additional: usize)

🔬This is a nightly-only experimental API. (extend_one)
Reserves capacity in a collection for the given number of additional elements. Read more
source§

impl Extend<(f64, f64)> for Covariance

source§

fn extend<T: IntoIterator<Item = (f64, f64)>>(&mut self, iter: T)

Extends a collection with the contents of an iterator. Read more
source§

fn extend_one(&mut self, item: A)

🔬This is a nightly-only experimental API. (extend_one)
Extends a collection with exactly one element.
source§

fn extend_reserve(&mut self, additional: usize)

🔬This is a nightly-only experimental API. (extend_one)
Reserves capacity in a collection for the given number of additional elements. Read more
source§

impl<'a> FromIterator<&'a (f64, f64)> for Covariance

source§

fn from_iter<T>(iter: T) -> Covariance
where T: IntoIterator<Item = &'a (f64, f64)>,

Creates a value from an iterator. Read more
source§

impl FromIterator<(f64, f64)> for Covariance

source§

fn from_iter<T>(iter: T) -> Covariance
where T: IntoIterator<Item = (f64, f64)>,

Creates a value from an iterator. Read more
source§

impl Merge for Covariance

source§

fn merge(&mut self, other: &Covariance)

Merge another sample into this one.

§Example
use average::{Covariance, Merge};

let sequence: &[(f64, f64)] = &[(1., 2.), (3., 4.), (5., 6.), (7., 8.), (9., 10.)];
let (left, right) = sequence.split_at(3);
let cov_total: Covariance = sequence.iter().collect();
let mut cov_left: Covariance = left.iter().collect();
let cov_right: Covariance = right.iter().collect();
cov_left.merge(&cov_right);
assert_eq!(cov_total.population_covariance(), cov_left.population_covariance());
source§

impl Serialize for Covariance

source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<S, T> Cast<T> for S
where T: Conv<S>,

source§

fn cast(self) -> T

Cast from Self to T Read more
source§

fn try_cast(self) -> Result<T, Error>

Try converting from Self to T Read more
source§

impl<S, T> CastApprox<T> for S
where T: ConvApprox<S>,

source§

fn try_cast_approx(self) -> Result<T, Error>

Try approximate conversion from Self to T Read more
source§

fn cast_approx(self) -> T

Cast approximately from Self to T Read more
source§

impl<S, T> CastFloat<T> for S
where T: ConvFloat<S>,

source§

fn cast_trunc(self) -> T

Cast to integer, truncating Read more
source§

fn cast_nearest(self) -> T

Cast to the nearest integer Read more
source§

fn cast_floor(self) -> T

Cast the floor to an integer Read more
source§

fn cast_ceil(self) -> T

Cast the ceiling to an integer Read more
source§

fn try_cast_trunc(self) -> Result<T, Error>

Try converting to integer with truncation Read more
source§

fn try_cast_nearest(self) -> Result<T, Error>

Try converting to the nearest integer Read more
source§

fn try_cast_floor(self) -> Result<T, Error>

Try converting the floor to an integer Read more
source§

fn try_cast_ceil(self) -> Result<T, Error>

Try convert the ceiling to an integer Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> Pointable for T

source§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,