hyperloglog

HyperLogLog and HyperLogLog++ implementation in Go/Golang.

Github stars Tracking Chart

Build Status Coverage Status GoDoc

HyperLogLog and HyperLogLog++

Implements the HyperLogLog and HyperLogLog++ algorithms.

HyperLogLog paper: http://algo.inria.fr/flajolet/Publications/FlFuGaMe07.pdf

HyperLogLog++ paper: http://research.google.com/pubs/pub40671.html

Documentation

Documentation can be found here.

Comparison of Algorithms

The HyperLogLog++ algorithm has much lower error for small cardinalities. This
is because it uses a different representation of data for small sets of data.
Data generated using this library shows the difference for N < 10000:

N < 10000

HyperLogLog++ also has bias correction which helps offset estimation errors in
the original HyperLogLog algorithm. This correction can be seen here, again
using data generated using this library:

N < 80000

Future Improvements

  • Right now HLL++ uses 8 bits per register. It could use 6 bits and take less
    memory.
  • The list compression algorithm could be improved, allowing the sparse
    representation to be used longer.

Main metrics

Overview
Name With Ownerclarkduvall/hyperloglog
Primary LanguageGo
Program languageGo (Language Count: 1)
Platform
License:MIT License
所有者活动
Created At2014-10-07 13:55:30
Pushed At2019-10-16 23:34:10
Last Commit At2017-11-27 09:45:14
Release Count0
用户参与
Stargazers Count461
Watchers Count10
Fork Count47
Commits Count44
Has Issues Enabled
Issues Count7
Issue Open Count2
Pull Requests Count12
Pull Requests Open Count4
Pull Requests Close Count5
项目设置
Has Wiki Enabled
Is Archived
Is Fork
Is Locked
Is Mirror
Is Private