Consider the set <inline-equation> <f> <sc>H</sc> </f> </inline-equation> of all linear (or affine) transformations between two vector spaces over a finite field <italic>F</italic>. We study how good <inline-equation> <f> <sc>H</sc></f></inline-equation> is as a class of hash functions, namely we consider hashing a set <italic>S</italic> of size <italic>n</italic> into a range having the same cardinality <italic>n</italic> by a randomly chosen function from <inline-equation> <f> <sc>H</sc></f></inline-equation> and look at the expected size of the largest hash bucket. <inline-equation> <f> <sc>H</sc></f></inline-equation> is a universal class of hash functions for any finite field, but with respect to our measure different fields behave differently.
If the finite field <italic>F</italic> has <italic>n</italic> elements, then there is a bad set <italic>S</italic> <inline-equation> <f> ⊂</f></inline-equation> <italic>F</italic><supscrpt>2</supscrpt> of size <italic>n</italic> with expected maximal bucket size <inline-equation> <f> <sc>H</sc></f></inline-equation>(<italic>n</italic><supscrpt>1/3</supscrpt>). If <italic>n</italic> is a perfect square, then there is even a bad set with largest bucket size <italic>always</italic> at least <inline-equation> <f> <rad> <rcd>n</rcd></rad></f></inline-equation>. (This is worst possible, since with respect to a universal class of hash functions every set of size <italic>n</italic> has expected largest bucket size below <inline-equation> <f> <rad> <rcd>n</rcd></rad></f></inline-equation> + 1/2.)
If, however, we consider the field of two elements, then we get much better bounds. The best previously known upper bound on the expected size of the largest bucket for this class was <italic>O</italic>(2<supscrpt><inline-equation> <f> <rad> <rcd>log n</rcd></rad></f></inline-equation></supscrpt>). We reduce this upper bound to <italic>O</italic>(log <italic>n</italic> log log<italic>n</italic>). Note that this is not far from the guarantee for a random function. There, the average largest bucket would be &THgr;(log <italic>n</italic>/ log log <italic>n</italic>).
In the course of our proof we develop a tool which may be of independent interest. Suppose we have a subset <italic>S</italic> of a vector space <italic>D</italic> over <bold>Z</bold><subscrpt>2</subscrpt>, and consider a random linear mapping of <italic>D</italic> to a smaller vector space <italic>R</italic>. If the cardinality of <italic>S</italic> is larger than <italic>c</italic><subscrpt>ε</subscrpt>|<italic>R</italic>|log|<italic>R</italic>|, then with probability 1 - ε, the image of <italic>S</italic> will cover all elements in the range.
[1]
Vladimir Vapnik,et al.
Chervonenkis: On the uniform convergence of relative frequencies of events to their probabilities
,
1971
.
[2]
S. Graham,et al.
Lower Bounds for Least Quadratic Non-Residues
,
1990
.
[3]
G. H. Gonnet,et al.
Handbook of algorithms and data structures: in Pascal and C (2nd ed.)
,
1991
.
[4]
Friedhelm Meyer auf der Heide,et al.
Dynamic Hashing in Real Time
,
1992,
Informatik.
[5]
János Komlós,et al.
Storing a sparse table with O(1) worst case access time
,
1982,
23rd Annual Symposium on Foundations of Computer Science (sfcs 1982).
[6]
Noam Nisan,et al.
The computational complexity of universal hashing
,
1990,
Proceedings Fifth Annual Structure in Complexity Theory Conference.
[7]
Alan Siegel,et al.
On universal classes of fast high performance hash functions, their time-space tradeoff, and their applications
,
1989,
30th Annual Symposium on Foundations of Computer Science.
[8]
J. Pach,et al.
Combinatorial geometry
,
1995,
Wiley-Interscience series in discrete mathematics and optimization.
[9]
Noga Alon,et al.
A Fast and Simple Randomized Parallel Algorithm for the Maximal Independent Set Problem
,
1985,
J. Algorithms.
[10]
Larry Carter,et al.
Universal Classes of Hash Functions
,
1979,
J. Comput. Syst. Sci..
[11]
Yossi Matias,et al.
Polynomial Hash Functions Are Reliable (Extended Abstract)
,
1992,
ICALP.
[12]
Martti Penttonen,et al.
A Reliable Randomized Algorithm for the Closest-Pair Problem
,
1997,
J. Algorithms.
[13]
Rajeev Raman,et al.
Sorting in linear time?
,
1995,
STOC '95.
[14]
Larry Carter,et al.
Analysis of a Universal Class of Hash Functions
,
1978,
MFCS.
[15]
Friedhelm Meyer auf der Heide,et al.
Dynamic perfect hashing: upper and lower bounds
,
1988,
[Proceedings 1988] 29th Annual Symposium on Foundations of Computer Science.
[16]
R. K. Shyamasundar,et al.
Introduction to algorithms
,
1996
.
[17]
János Pach,et al.
Combinatorial Geometry
,
2012
.
[18]
Gaston H. Gonnet,et al.
Handbook Of Algorithms And Data Structures
,
1984
.