Skip to content

hynd/lua_hdrhistogram

Repository files navigation

Lua HdrHistogram Library

Overview

HdrHistogram is an algorithm designed for recording histograms of value measurements with configurable precision. Value precision is expressed as the number of significant digits, providing control over value quantization and resolution whilst maintaining a fixed cost in both space and time. More information can be found on the HdrHistogram site (which much of the text in this README paraphrases). This library wraps the C port.

Installation

Prerequisites

  • C compiler (GCC 4.7+, Visual Studio 2013, MinGW (Lua 5.1))
  • Lua 5.1, Lua 5.2, or LuaJIT
  • CMake (2.8.7+)

CMake Build Instructions

git clone https://github.com/hynd/lua_hdrhistogram.git
cd lua_hdrhistogram
mkdir release
cd release

# UNIX
cmake -DCMAKE_BUILD_TYPE=release ..
make

Module

Example Usage

require "hdrhistogram"
local hdr = hdrhistogram.new(1,1000000,3)

for i = 10, 1000000, 10 do
  hdr:record(i)
end

local p50 = hdr:percentile(50)
-- p50 == 500223

API Functions

new

require "hdrhistogram"
local hdr = hdrhistogram.new(1,3600000000,3)

Import Lua hdrhistogram via the Lua 'require' function. The module is globally registered and returned by the require function. The new function takes 3 arguments for lowest trackable value, highest trackable value and the value precision represented as significant figures.

The example above configures a new histogram to track the counts of observed integer values between 1 and 3,600,000,000 while maintaining a value precision of 3 significant digits across that range. Value quantization within the range will thus be no larger than 1/1,000th (or 0.1%) of any value. This example Histogram could be used to track and analyze the counts of observed response times ranging between 1 microsecond and 1 hour in magnitude, while maintaining a value resolution of 1 microsecond up to 1 millisecond, a resolution of 1 millisecond (or better) up to one second, and a resolution of 1 second (or better) up to 1,000 seconds. At its maximum tracked value (1 hour), it would still maintain a resolution of 3.6 seconds (or better).

version

require "hdrhistogram"
local v = hdrhistogram.version()
-- v == "0.1.0"

Returns a string with the running version of hdrhistogram.

Arguments

  • none

Return

  • Semantic version string

API Methods

record

local success = hdr:record(value)

Adds a value to the histogram.

Arguments

  • value (number) The value to add to the histogram. Return
  • True if the value was successfully recorded.

min

local min = hdr:min()

Arguments

  • none

Return

  • Returns the minimum value stored in the histogram.

max

local max = hdr:max()

Arguments

  • none

Return

  • Returns the maximum value stored in the histogram.

mean

local mean = hdr:mean()

Arguments

  • none

Return

  • Returns the calculated mean average of all values in the histogram.

stddev

local stddev = hdr:stddev()

Arguments

  • none

Return

  • Returns the calculated standard deviation of values in the histogram.

percentile

local p999 = hdr:percentile(pct)

Get the value at a given percentile.

Arguments pct (number) Percentile to retrieve.

Return

  • Returns the value that the given percentage of the overall recorded entries are either smaller than or equivalent to.

merge

dropped = hdr:merge(old)

Merges one histogram into another.

Arguments

  • old (hdrhistogram) A hdrhistogram to merge into the current one.

Return

  • dropped (number) Number of values dropped during the merge operation.

reset

hdr:reset()

Empties the contents of the histogram.

Arguments

  • none

Return

  • none

memsize

size = hdr:memsize()

Returns the amount of memory allocated to the hdrhistogram in bytes.

Arguments

  • none

Return size (number) Size in bytes allocated to the histogram object.

count

count = hdr:count()

Arguments

  • none

Return count (number) Total count of all recorded values in the histogram.

Todo

  • Serialisation support for Mozilla's lua_sandbox
  • Add API for recording values corrected for Co-ordinated Omission.
  • Take table of numbers into :record()

About

Lua library wrapping HdrHistogram_c

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published