#sketch #quantile #port #golang #direct #merge #dd-sketch

sketches-ddsketch

A direct port of the Golang DDSketch implementation

8 releases

0.3.0 Jun 1, 2024
0.2.2 Feb 4, 2024
0.2.1 Apr 10, 2023
0.2.0 Jun 27, 2022
0.1.1 Sep 21, 2019

#44 in Algorithms

Download history 157489/week @ 2024-05-20 169748/week @ 2024-05-27 236522/week @ 2024-06-03 214339/week @ 2024-06-10 221863/week @ 2024-06-17 257155/week @ 2024-06-24 214940/week @ 2024-07-01 210219/week @ 2024-07-08 204362/week @ 2024-07-15 219580/week @ 2024-07-22 215328/week @ 2024-07-29 198267/week @ 2024-08-05 182805/week @ 2024-08-12 190605/week @ 2024-08-19 199871/week @ 2024-08-26 179346/week @ 2024-09-02

759,431 downloads per month
Used in 146 crates (7 directly)

Apache-2.0

24KB
557 lines

sketches-ddsketch

This is a direct port of the Golang DDSketch quantile sketch implementation to Rust. DDSketch is a fully-mergeable quantile sketch with relative-error guarantees and is extremely fast.

DDSketch

  • Sketch size automatically grows as needed, starting with 128 bins.
  • Extremely fast sample insertion and sketch merges.

Usage

use sketches_ddsketch::{Config, DDSketch};

let config = Config::defaults();
let mut sketch = DDSketch::new(c);

sketch.add(1.0);
sketch.add(1.0);
sketch.add(1.0);

// Get p=50%
let quantile = sketch.quantile(0.5).unwrap();
assert_eq!(quantile, Some(1.0));

Performance

No performance tuning has been done with this implementation of the port, so we would expect similar profiles to the original implementation.

Out of the box we see can achieve over 70M sample inserts/sec and 350K sketch merges/sec. All tests run on a single core Intel i7 processor with 4.2Ghz max clock.

Dependencies

~165KB