Skip to content

Instantly share code, notes, and snippets.

@audriusrudalevicius
Forked from Pyrolistical/functions.js
Last active August 29, 2015 14:16
Show Gist options
  • Save audriusrudalevicius/b511150d080c689a2efa to your computer and use it in GitHub Desktop.
Save audriusrudalevicius/b511150d080c689a2efa to your computer and use it in GitHub Desktop.
function map() {
emit(1, {
sum: this.value, // the field you want stats for
min: this.value,
max: this.value,
count: 1,
diff: 0
});
}
function reduce(key, values) {
return values.reduce(function reduce(previous, current, index, array) {
var delta = previous.sum/previous.count - current.sum/current.count;
var weight = (previous.count * current.count)/(previous.count + current.count);
return {
sum: previous.sum + current.sum,
min: Math.min(previous.min, current.min),
max: Math.max(previous.max, current.max),
count: previous.count + current.count,
diff: previous.diff + current.diff + delta*delta*weight
};
})
}
function finalize(key, value) {
value.average = value.sum / value.count;
value.population_variance = value.diff / value.count;
value.population_standard_deviation = Math.sqrt(value.population_variance);
value.sample_variance = value.diff / (value.count - 1);
value.sample_standard_deviation = Math.sqrt(value.sample_variance);
delete value.diff;
return value;
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment