#!/usr/bin/ruby
#
## https://rosettacode.org/wiki/Standard_deviation
#
class StdDevAccumulator(n=0, sum=0, sumofsquares=0) {
method <<(num) {
n += 1;
sum += num;
sumofsquares += num**2;
self;
}
method stddev {
sqrt(sumofsquares/n - pow(sum/n, 2));
}
method to_s {
self.stddev.to_s;
}
}
var i = 0;
var sd = StdDevAccumulator.new;
[2,4,4,4,5,5,7,9].each {|n|
say "adding #{n}: stddev of #{i+=1} samples is #{sd << n}"
}