NAME
Math::StdDev - Pure-perl mean and variance computation supporting running/online calculation (Welford's algorithm)
SYNOPSIS
#!/usr/bin/perl -w
use Math::StdDev;
my $d = new Math::StdDev();
$d->Update(2);
$d->Update(3);
print $d->mean() . "\t" . $d->sampleVariance(); # or $d->variance()
or
perl -MMath::StdDev -e '$d=new Math::StdDev; $d->Update(10**8+4, 10**8 + 7, 10**8 + 13, 10**8 + 16); print $d->mean() . "\n" . $d->sampleVariance() . "\n"'
DESCRIPTION
This module impliments Welford's online algorithm (see https://en.wikipedia.org/wiki/Algorithms_for_calculating_variance ) Maybe one day in future the two-pass algo could be included, along with Kahan compensated summation... so much math, so little time...
EXPORT
None by default.
Notes
new
Usage is
my $d = new Math::StdDev();
or
my $d = new Math::StdDev(1,2,3,4); # Add one or more samples, or a population, right from the start
Update
Usage is
my $d->Update(123);
or
my $d->Update(@list_of_scalars);
mean()
Usage is
print $d->mean();
variance
Usage is
print $d->variance();
sampleVariance
(same as variance, but uses n-1 divisor.) Usage is:
print $d->sampleVariance();
AUTHOR
This module was written by Chris Drake cdrake@cpan.org.
COPYRIGHT AND LICENSE
Copyright (c) 2019 Chris Drake. All rights reserved.
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself, either Perl version 5.18.2 or, at your option, any later version of Perl 5 you may have available.