PaCHash: Packed and Compressed Hash Tables

Florian Kurpicz,Hans-Peter Lehmann,Peter Sanders
DOI: https://doi.org/10.48550/arXiv.2205.04745
2022-11-08
Abstract:We introduce PaCHash, a hash table that stores its objects contiguously in an array without intervening space, even if the objects have variable size. In particular, each object can be compressed using standard compression techniques. A small search data structure allows locating the objects in constant expected time. PaCHash is most naturally described as a static external hash table where it needs a constant number of bits of internal memory per block of external memory. Here, in some sense, PaCHash beats a lower bound on the space consumption of k-perfect hashing. An implementation for fast SSDs needs about 5 bits of internal memory per block of external memory, requires only one disk access (of variable length) per search operation, and has small internal search overhead compared to the disk access cost. Our experiments show that it has lower space consumption than all previous approaches even when considering objects of identical size.
Data Structures and Algorithms
What problem does this paper attempt to address?