#difference #distribution #find #normal #benchmarking #right #continuous

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

#20 in #normal

Download history 35/week @ 2024-11-15 18/week @ 2024-11-22 151/week @ 2024-11-29 350/week @ 2024-12-06 153/week @ 2024-12-13 51/week @ 2024-12-20 49/week @ 2024-12-27 213/week @ 2025-01-03 253/week @ 2025-01-10 707/week @ 2025-01-17 268/week @ 2025-01-24 252/week @ 2025-01-31 199/week @ 2025-02-07 231/week @ 2025-02-14 176/week @ 2025-02-21 225/week @ 2025-02-28

894 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

~82KB