Modern Minimal Perfect Hashing: A Survey
Hans-Peter Lehmann, Thomas Mueller, Rasmus Pagh, Giulio Ermanno Pibiri, Peter Sanders, Sebastiano Vigna, Stefan Walzer
TL;DR
This survey addresses the problem of constructing minimal perfect hash functions (MPHFs) that map a known set of n keys to exactly [n] with no collisions, while using space near the information-theoretic lower bound $n\log_2 e$. It systematically categorizes modern MPHFs into retrieval-based, brute-force, and fingerprinting approaches, analyzes their space, construction time, and query performance, and provides a comprehensive experimental comparison across billions of keys. Key contributions include a detailed taxonomy, clarified relationship to graph-theoretic notions like peelability and orientability, and extensive benchmarks that guide practitioners in selecting the right MPHF for their needs. The work demonstrates that state-of-the-art MPHFs can be extremely space-efficient (near $1.444$ bits/key) and fast to query, with construction times that scale via partitioning and parallelism, including GPU acceleration, making MPHFs practical for large-scale databases, bioinformatics, and text processing tasks.
Abstract
Given a set $S$ of $n$ keys, a perfect hash function for $S$ maps the keys in $S$ to the first $m \geq n$ integers without collisions. It may return an arbitrary result for any key not in $S$ and is called minimal if $m = n$. The most important parameters are its space consumption, construction time, and query time. Years of research now enable modern perfect hash functions to be extremely fast to query, very space-efficient, and scale to billions of keys. Different approaches give different trade-offs between these aspects. For example, the smallest constructions get within 0.1% of the space lower bound of $\log_2(e)$ bits per key. Others are particularly fast to query, requiring only one memory access. Perfect hashing has many applications, for example to avoid collision resolution in static hash tables, and is used in databases, bioinformatics, and stringology. Since the last comprehensive survey in 1997, significant progress has been made. This survey covers the latest developments and provides a starting point for getting familiar with the topic. Additionally, our extensive experimental evaluation can serve as a guide to select a perfect hash function for use in applications.
