#difference #distribution #normal #find #continuous #done #benchmarking

behrens-fisher

Find the difference of the means of two Normal distributions

2 unstable releases

0.2.0 Mar 2, 2022
0.1.0 Nov 30, 2020

#11 in #done

Download history 113/week @ 2024-07-22 357/week @ 2024-07-29 58/week @ 2024-08-05 118/week @ 2024-08-12 340/week @ 2024-08-19 245/week @ 2024-08-26 361/week @ 2024-09-02 203/week @ 2024-09-09 331/week @ 2024-09-16 110/week @ 2024-09-23 271/week @ 2024-09-30 140/week @ 2024-10-07 237/week @ 2024-10-14 220/week @ 2024-10-21 110/week @ 2024-10-28 39/week @ 2024-11-04

614 downloads per month
Used in cbdr

Unlicense

32KB
677 lines

A crate for testing whether the means of two Normal distributions are the same.

This crate implements Welch's t-test, an approximate solution to the Behrens-Fisher problem. The results are presented in the form of a confidence interval.

Example

Suppose we have a population distributed as X (normal), and another distributed as Y (also normal, but possibly with different mean/variance to X). Let's take a sample from each population to estimate the difference between the population means.

use behrens_fisher::*;
let x_sample: Vec<f64> = vec![1., 2., 3., 4.];
let y_sample: Vec<f64> = vec![3., 5., 7., 9., 11.];

let x_stats: SampleStats = x_sample.into_iter().collect();
let y_stats: SampleStats = y_sample.into_iter().collect();
let ci = difference_of_means(0.95, x_stats, y_stats).unwrap();
assert_eq!(ci.to_string(), "+4.50 ± 3.89 (p=95%)");
// Looks like μ[Y] > μ[X]!

Dependencies

~83KB