HyperLogLogLog: Cardinality Estimation With One Log More

05/23/2022
by   Matti Karppa, et al.
0

We present HyperLogLogLog, a practical compression of the HyperLogLog sketch that compresses the sketch from O(mloglog n) bits down to m log_2log_2log_2 m + O(m+loglog n) bits for estimating the number of distinct elements n using m registers. The algorithm works as a drop-in replacement that preserves all estimation properties of the HyperLogLog sketch, it is possible to convert back and forth between the compressed and uncompressed representations, and the compressed sketch maintains mergeability in the compressed domain. The compressed sketch can be updated in amortized constant time, assuming n is sufficiently larger than m. We provide a C++ implementation of the sketch, and show by experimental evaluation against well-known implementations by Google and Apache that our implementation provides small sketches while maintaining competitive update and merge times. Concretely, we observed approximately a 40 Furthermore, we obtain as a corollary a theoretical algorithm that compresses the sketch down to mlog_2log_2log_2log_2 m+O(mlogloglog m/loglog m+loglog n) bits.

READ FULL TEXT

Please sign up or login with your details

Forgot password? Click here to reset