Documentation ¶
Overview ¶
Package hdrhistogram provides an implementation of Gil Tene's HDR Histogram data structure. The HDR Histogram allows for fast and accurate analysis of the extreme ranges of data with non-normal distributions, like latency.
Index ¶
- type Bar
- type Bracket
- type Histogram
- func (h *Histogram) ByteSize() int
- func (h *Histogram) CumulativeDistribution() []Bracket
- func (h *Histogram) Distribution() (result []Bar)
- func (h *Histogram) Equals(other *Histogram) bool
- func (h *Histogram) Export() *Snapshot
- func (h *Histogram) HighestTrackableValue() int64
- func (h *Histogram) LowestTrackableValue() int64
- func (h *Histogram) Max() int64
- func (h *Histogram) Mean() float64
- func (h *Histogram) Merge(from *Histogram) (dropped int64)
- func (h *Histogram) Min() int64
- func (h *Histogram) RecordCorrectedValue(v, expectedInterval int64) error
- func (h *Histogram) RecordValue(v int64) error
- func (h *Histogram) RecordValueAtomic(v int64) error
- func (h *Histogram) RecordValues(v, n int64) error
- func (h *Histogram) RecordValuesAtomic(v, n int64) error
- func (h *Histogram) Reset()
- func (h *Histogram) SignificantFigures() int64
- func (h *Histogram) StdDev() float64
- func (h *Histogram) TotalCount() int64
- func (h *Histogram) ValueAtQuantile(q float64) int64
- type Snapshot
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Histogram ¶
type Histogram struct {
// contains filtered or unexported fields
}
A Histogram is a lossy data structure used to record the distribution of non-normally distributed data (like latency) with a high degree of accuracy and a bounded degree of precision.
func Import ¶
Import returns a new Histogram populated from the Snapshot data (which the caller must stop accessing).
func New ¶
New returns a new Histogram instance capable of tracking values in the given range and with the given amount of precision.
func (*Histogram) ByteSize ¶
ByteSize returns an estimate of the amount of memory allocated to the histogram in bytes.
N.B.: This does not take into account the overhead for slices, which are small, constant, and specific to the compiler version.
func (*Histogram) CumulativeDistribution ¶
CumulativeDistribution returns an ordered list of brackets of the distribution of recorded values.
func (*Histogram) Distribution ¶
Distribution returns an ordered list of bars of the distribution of recorded values, counts can be normalized to a probability
func (*Histogram) Export ¶
Export returns a snapshot view of the Histogram. This can be later passed to Import to construct a new Histogram with the same state.
func (*Histogram) HighestTrackableValue ¶
HighestTrackableValue returns the upper bound on values that will be added to the histogram
func (*Histogram) LowestTrackableValue ¶
LowestTrackableValue returns the lower bound on values that will be added to the histogram
func (*Histogram) Merge ¶
Merge merges the data stored in the given histogram with the receiver, returning the number of recorded values which had to be dropped.
func (*Histogram) RecordCorrectedValue ¶
RecordCorrectedValue records the given value, correcting for stalls in the recording process. This only works for processes which are recording values at an expected interval (e.g., doing jitter analysis). Processes which are recording ad-hoc values (e.g., latency for incoming requests) can't take advantage of this.
func (*Histogram) RecordValue ¶
RecordValue records the given value, returning an error if the value is out of range.
func (*Histogram) RecordValueAtomic ¶
RecordValueAtomic is equivalent to h.RecordValuesAtomic(v, 1).
func (*Histogram) RecordValues ¶
RecordValues records n occurrences of the given value, returning an error if the value is out of range.
func (*Histogram) RecordValuesAtomic ¶
RecordValuesAtomic records n occurrences of the given value, returning an error if the value is out of range.
The bucket count and total count are each independently updated, atomically with respect to other calls to RecordValue(s)Atomic. RecordValuesAtomic is unsafe for concurrent use with methods that read the histogram; read/write access should be synchronised using a mutex.
func (*Histogram) Reset ¶
func (h *Histogram) Reset()
Reset deletes all recorded values and restores the histogram to its original state.
func (*Histogram) SignificantFigures ¶
SignificantFigures returns the significant figures used to create the histogram
func (*Histogram) StdDev ¶
StdDev returns the approximate standard deviation of the recorded values.
func (*Histogram) TotalCount ¶
TotalCount returns total number of values recorded.
func (*Histogram) ValueAtQuantile ¶
ValueAtQuantile returns the recorded value at the given quantile (0..100).