Skip to content
This repository has been archived by the owner on Aug 22, 2024. It is now read-only.

azuqua/standard-deviation-stream

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

14 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

standard-deviation-stream Build Status

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());
console.log('Min: '+numbers.min());
console.log('Max: '+numbers.max());

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

About

A Node.js class for pulling stats from a stream.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 100.0%