metrics_util

Struct Summary

Source
pub struct Summary { /* private fields */ }
Expand description

A quantile sketch with relative-error guarantees.

Based on DDSketch, Summary provides quantiles over an arbitrary distribution of floating-point numbers, including for negative numbers, using a space-efficient sketch that provides relative-error guarantees, regardless of the absolute range between the smallest and larger values.

Summary is similiar to HDRHistogram in practice, but supports an arbitrary range of values, and supports floating-point numbers.

Numbers with an absolute value smaller than given min_value will be recognized as zeroes.

Memory usage for Summary should be nearly identical to DDSketch. Summary::estimated_size provides a rough estimate of summary size based on the current values that have been added to it.

As mentioned above, this sketch provides relative-error guarantees across quantiles falling within 0 <= q <= 1, but trades some accuracy at the lowest quantiles as part of the collapsing scheme that allows for automatically handling arbitrary ranges of values, even when the maximum number of bins has been allocated. Typically, q=0.05 and below is where this error will be noticed, if present.

For cases when all values are positive, you can simply use Summary::min in lieu of checking these quantiles, as the minimum value will be closer to the true value. For cases when values range from negative to positive, the aforementioned collapsing will perturb the estimated true value for quantiles that conceptually fall within this collapsed band.

For example, for a distribution that spans from -25 to 75, we would intuitively expect q=0 to be -25, q=0.25 to be 0, q=0.5 to be 25, and so on. Internally, negative numbers and positive numbers are handled in two separate containers. Based on this example, one container would handle -25 to 0, and another would handle the 0 to 75 range. As the containers are mapped “back to back”, q=0.25 for this hypothetical summary would actually be q=0 within the negative container, which may return an estimated true value that exceeds the relative error guarantees.

Of course, as these problems are related to the estimation aspect of this data structure, users can allow the summary to allocate more bins to compensate for these edge cases, if desired.

Implementations§

Source§

impl Summary

Source

pub fn new(alpha: f64, max_buckets: u32, min_value: f64) -> Summary

Creates a new Summary.

alpha represents the desired relative error for this summary. If alpha was 0.0001, that would represent a desired relative error of 0.01%. For example, if the true value at quantile q0 was 1, the estimated value at that quantile would be a value within 0.01% of the true value, or a value between 0.9999 and 1.0001.

max_buckets controls how many subbuckets are created, which directly influences memory usage. Each bucket “costs” eight bytes, so a summary with 2048 buckets would consume a maximum of around 16 KiB. Depending on how many samples have been added to the summary, the number of subbuckets allocated may be far below max_buckets, and the summary will allocate more as needed to fulfill the relative error guarantee.

min_value controls the smallest value that will be recognized distinctly from zero. Said another way, any value between -min_value and min_value will be counted as zero.

Source

pub fn with_defaults() -> Summary

Creates a new Summary with default values.

alpha is 0.0001, max_buckets is 32,768, and min_value is 1.0e-9.

This will yield a summary that is roughly equivalent in memory usage to an HDRHistogram with 3 significant digits, and will support values down to a single nanosecond.

In practice, when using only positive values, maximum memory usage can be expected to hover around 200KiB, while usage of negative values can lead to an average maximum size of around 400KiB.

Source

pub fn add(&mut self, value: f64)

Adds a sample to the summary.

If the absolute value of value is smaller than given min_value, it will be added as a zero.

Source

pub fn quantile(&self, q: f64) -> Option<f64>

Gets the estimated value at the given quantile.

If the sketch is empty, or if the quantile is less than 0.0 or greater than 1.0, then the result will be None.

If the 0.0 or 1.0 quantile is requested, this function will return self.min() or self.max() instead of the estimated value.

Source

pub fn merge(&mut self, other: &Summary) -> Result<(), MergeError>

Merge another Summary into this one.

§Errors

This function will return an error if the other Summary was not created with the same parameters.

Source

pub fn min(&self) -> f64

Gets the minimum value this summary has seen so far.

Source

pub fn max(&self) -> f64

Gets the maximum value this summary has seen so far.

Source

pub fn is_empty(&self) -> bool

Whether or not this summary is empty.

Source

pub fn count(&self) -> usize

Gets the number of samples in this summary.

Source

pub fn estimated_size(&self) -> usize

Gets the estimized size of this summary, in bytes.

In practice, this value should be very close to the actual size, but will not be entirely precise.

Trait Implementations§

Source§

impl Clone for Summary

Source§

fn clone(&self) -> Summary

Returns a copy of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> Pointable for T

Source§

const ALIGN: usize = _

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.