Fork of sketches-js to fix compatibility with older versions of Node.
An implementation of DDSketch for Node.js.
DDSketch is a data structure for recording large amounts of numeric data and calculating quantiles over that data. It's designed to be fast, fully-mergeable and provide guarantees that a quantile value is within a configurable percentage threshold of the real value.
The implementation is based on the official paper: DDSketch: A Fast and Fully-Mergeable Quantile Sketch with Relative-Error Guarantees (PDF)
npm install monti-apm-sketches-js
const { DDSketch } = require('sketches-js');
const sketch = new DDSketch({
alpha: 0.005 // compute quantiles with precision of 1/2 of a percent
});
for (let i = 0; i < 1000; i++) {
sketch.add(Math.random() * 1000);
}
[0.5, 0.75, 0.9, 0.95, 0.99].forEach(function(q) {
console.log(`p${q * 100}: ${sketch.quantile(q)}`);
});
The source code is distributed under the terms of MPL 2.0 license.