standard-deviation-stream

0.0.3 • Public • Published

standard-deviation-stream

A Node.js method for finding the standard deviation of numbers arriving in a stream. Based on Donald Knuth's solution in Art of Computer Programming as described by John D. Cook.

Basic Example

Just get the standard deviation on some numbers.

var DeviationStream = require('standard-deviation-stream');
 
var numbers = new DeviationStream();
 
numbers.push(10);
numbers.push(15);
numbers.push(20);
numbers.push(25);
 
console.log('Count: '+numbers.count());
console.log('Mean: '+numbers.mean());
console.log('Variance: '+numbers.variance());
console.log('Standard Deviation: '+numbers.standardDeviation());
 
numbers.clear();

Redis Enhanced Example

If you are fetching a stream of numbers in batches it can be useful to save the state of the standard deviation stream between batches.

For example lets say you have a web endpoint that returns results from a database collection in pages of 100 at a time, and needs to calculate standard deviation on the results. With the redis enhanced style you can fetch 100 items, calculate standard deviation on that page of 100 results, and cache the stream data.

Now the next time the web endpoint is called to fetch the next page of 100 results you can restore from cache and continue calculating the standard deviation on the next 100 items, taking into account the mean and variance of the first 100 items that you fetched in the previous request.

var async = require('async');
var DeviationStream = require('standard-deviation-stream');
 
var numbers = new DeviationStream('someResults', redisConnection);
 
async.series(
    [
        function (done) {
            numbers.restore(done);
        },
 
        function (done) {
            numbers.push(10);
            numbers.push(15);
            numbers.push(20);
            numbers.push(25);
            numbers.save(done);
        }
    ],
    function () {
        console.log('Done');
    }
);
 

By default the save function stores the standard deviation stream data in a Redis key with an expiration of one hour. This allows you to continue adding more items to a stream based on that key at any time within an hour.

Installation & Testing

npm install standard-deviation-stream
npm test

To run the tests on the Redis enhanced capability you'll need to be running Redis locally on port 6379

Package Sidebar

Install

npm i standard-deviation-stream

Weekly Downloads

5

Version

0.0.3

License

MIT

Last publish

Collaborators

  • nathanpeck