data:image/s3,"s3://crabby-images/ca364/ca36463f9b82c90b6f3e27c6326cdcdc31617e4c" alt=""
Locality sensitive hashing
Encyclopedia
Locality-sensitive hashing (LSH) is a method of performing probabilistic dimension reduction of high-dimensional data. The basic idea is to hash
the input items so that similar items are mapped to the same buckets with high probability (the number of buckets being much smaller than the universe of possible input items).
is defined for
a metric space
, a threshold
and an approximation factor
.
An LSH family
is a family of functions
satisfying the following conditions for any two points
, and a function
chosen uniformly at random from
:
A family is interesting when
. Such a family
is called
-sensitive.
An alternative definition is defined with respect to a universe of items
that have a similarity
function
. An LSH scheme is a family of hash function
s
coupled with a probability distribution
over the functions such that a function
chosen according to
satisfies the property that
for any
.
This approach works for the Hamming distance
over d-dimensional vectors
. Here, the family
of hash functions is simply the family of all the projections of points on
one of the
coordinates, i.e.,
,
where
is the
th coordinate of
. A random function
from
simply selects a random bit from the input point. This family has the following parameters:
,
.
is composed of subsets of some ground set of enumerable items
and the similarity function of interest is the Jaccard index
. If
is a permutation on the indices of
, for
let
. Each possible choice of
defines a single hash function
mapping input sets to integers.
Define the function family
to be the set of all such functions and let
be the uniform distribution. Given two sets
the event that
corresponds exactly to the event that the minimizer of
lies inside
. As
was chosen uniformly at random,
and
define an LSH scheme for the Jaccard index.
Because the symmetric group on n elements has size n!, choosing a truly random permutation from the full symmetric group is infeasible for even moderately sized n. Because of this fact, there has been significant work on finding a family of permutations that is "min-wise independent" - a permutation family for which each element of the domain has equal probability of being the minimum under a randomly chosen
. It has been established that a min-wise independent family of permutations is at least of size
. and that this boundary is tight
Because min-wise independent families are too big for practical applications, two variant notions of min-wise independence are introduced: restricted min-wise independent permutations families, and approximate min-wise independent families.
Restricted min-wise independence is the min-wise independence property restricted to certain sets of cardinality at most k .
Approximate min-wise independence differs from the property by at most a fixed
.
(defined by a normal unit vector
) at the outset and use the hyperplane to hash input vectors.
Given an input vector
and a hyperplane defined by
, we let
. That is,
depending on which side of the hyperplane
lies.
Each possible choice of
defines a single function. Let
be the set of all such functions and let
be the uniform distribution once again. It is not difficult to prove that, for two vectors
,
, where
is the angle between
and
.
is closely related to
.
In this instance hashing produces only a single bit. Two vectors' bits match with probability proportional to the cosine of the angle between them.
maps a d dimensional vector
onto a set of integers. Each hash function
in the family is indexed by a choice of random
and
where
is a d dimensional
vector with
entries chosen independently from a stable distribution and
is
a real number chosen uniformly from the range [0,r]. For a fixed
the hash function
is
given by
.
Other construction methods for hash functions have been proposed to better fit the data.
In particular k-means hash functions are better in practice than projection-based hash functions, but without any theoretical guarantee.
algorithms.
Consider any LSH family
. The
algorithm has two main parameters: the width parameter
and the
number of hash tables
.
In the first step, we define a new family
of hash
functions
, where each function
is
obtained by concatenating
functions
from
, i.e.,
.
In other words, a random hash function
is obtained by
concatenating
randomly chosen hash functions from
.
The algorithm then constructs
hash tables, each
corresponding to
a different randomly chosen hash function
.
In the preprocessing step we hash all
points from the data set
into each of
the
hash tables.
Given that the resulting hash tables have only
non-zero
entries,
one can reduce the amount of memory used per each hash table to
using standard hash functions.
Given a query point
, the algorithm iterates over the
hash functions
.
For each
considered, it retrieves the data points that
are hashed
into the same bucket as
.
The process is stopped as soon as a point within distance
from
is found.
Given the parameters
and
, the algorithm has
the following performance guarantees:
For a fixed approximation ratio
and probabilities
and
, one can set
and
, where
.
Then one obtains the following performance guarantees:
Hash function
A hash function is any algorithm or subroutine that maps large data sets to smaller data sets, called keys. For example, a single integer can serve as an index to an array...
the input items so that similar items are mapped to the same buckets with high probability (the number of buckets being much smaller than the universe of possible input items).
Definition
An LSH familydata:image/s3,"s3://crabby-images/4a962/4a96261305254ee14263bff5889bda90c5169a4e" alt=""
a metric space
Metric space
In mathematics, a metric space is a set where a notion of distance between elements of the set is defined.The metric space which most closely corresponds to our intuitive understanding of space is the 3-dimensional Euclidean space...
data:image/s3,"s3://crabby-images/cc816/cc8162f1499e647c54a7876130827b68cb7bc75a" alt=""
data:image/s3,"s3://crabby-images/d5fed/d5fedb0a0862b1d4066526665f7f6744175b3fe0" alt=""
data:image/s3,"s3://crabby-images/c6945/c6945d796f6f9f98ddaf0d77b1e64845fe72df28" alt=""
An LSH family
data:image/s3,"s3://crabby-images/ef4a2/ef4a2b9f825fa8ccaeac760492fc46b18cf86967" alt=""
data:image/s3,"s3://crabby-images/19881/19881799a0d32ed7521824a05a0f275c2cea58ce" alt=""
data:image/s3,"s3://crabby-images/50922/50922b17adb915f1aa5d8bc1779bc7ba95051c6e" alt=""
data:image/s3,"s3://crabby-images/c198f/c198fc9dc246100c325cadd350aeb406dcb9a5dd" alt=""
data:image/s3,"s3://crabby-images/e453a/e453ab79c04d1a9e0b94cc9fbe1a72b888b89492" alt=""
- if
, then
(i.e.,
and
collide) with probability at least
,
- if
, then
with probability at most
.
A family is interesting when
data:image/s3,"s3://crabby-images/24b01/24b016e8d54aa97c6d97614f6cae1a2ddcd58479" alt=""
data:image/s3,"s3://crabby-images/40370/403700e06930a1de41ebd280dbd748d1965a160c" alt=""
data:image/s3,"s3://crabby-images/cf791/cf79169b3bfa828345790f28d861390303ae31fe" alt=""
An alternative definition is defined with respect to a universe of items
data:image/s3,"s3://crabby-images/99f66/99f668714f64d489a335a7b6bdd06038f0a42c43" alt=""
Similarity
-Specific definitions:Different fields provide differing definitions of similarity:-In computer science:* string metric, aka string similarity* semantic similarity in computational linguistics-In other fields:...
function
data:image/s3,"s3://crabby-images/a4445/a4445b796ef72470bdbab7f0f287e6403d7df164" alt=""
Hash function
A hash function is any algorithm or subroutine that maps large data sets to smaller data sets, called keys. For example, a single integer can serve as an index to an array...
s
data:image/s3,"s3://crabby-images/c917a/c917a88acc4af9ab30b4834d1c169286e5e3ab0e" alt=""
data:image/s3,"s3://crabby-images/eec75/eec75086d89c117b6c69514996f821fe93ecd296" alt=""
data:image/s3,"s3://crabby-images/82141/821413b67880dc244f8a50fe18c90f4288f83113" alt=""
data:image/s3,"s3://crabby-images/8e9d2/8e9d24568f43d969d139a4cd2317b3206ed3aa4a" alt=""
data:image/s3,"s3://crabby-images/b011e/b011e5f3bb3385506bd42b806d58a302fc1a486f" alt=""
data:image/s3,"s3://crabby-images/e99df/e99df67cb7765de606bdc7c555b0bb794e43f9a9" alt=""
Applications
LSH has been applied to several problem domains including- Near-duplicate detection
- Image similarity identification
- Gene expression similarity identification
- Audio similarity identification
Bit sampling for Hamming distance
One of the easiest ways to construct an LSH family is by bit sampling .This approach works for the Hamming distance
Hamming distance
In information theory, the Hamming distance between two strings of equal length is the number of positions at which the corresponding symbols are different...
over d-dimensional vectors
data:image/s3,"s3://crabby-images/a6575/a65755f13455acd379a350c2058f245cf4eb5a33" alt=""
data:image/s3,"s3://crabby-images/8517f/8517f4696b82a0ede454bf4b7304cfb37958d06d" alt=""
one of the
data:image/s3,"s3://crabby-images/0db7c/0db7c57d95361f824d627a608439f4e1aa310b13" alt=""
data:image/s3,"s3://crabby-images/8effe/8effe769f3b65b385caf8933d551c09771532ba6" alt=""
where
data:image/s3,"s3://crabby-images/af0ec/af0ecda77f76eb07c3bf709c014498b38114305a" alt=""
data:image/s3,"s3://crabby-images/fa913/fa91368ddae02a8580227e1cf1684245e71a75fb" alt=""
data:image/s3,"s3://crabby-images/63e66/63e66f58310251dd6fbf4410695b7f39ac49e173" alt=""
data:image/s3,"s3://crabby-images/95194/95194a814251a66c1ce5b9c5ebf175e273e459e5" alt=""
data:image/s3,"s3://crabby-images/25d2b/25d2b1455ef1d070ca9cca996f25d3b80590fce6" alt=""
data:image/s3,"s3://crabby-images/980db/980dbb04ca32d1616d6248d1e2b55b66e00a24fa" alt=""
data:image/s3,"s3://crabby-images/fcd88/fcd88586885ae962bb170e063d81a9a6106d6bff" alt=""
Min-wise independent permutations
Supposedata:image/s3,"s3://crabby-images/3f432/3f4320174fc4e41c151748061f681c35cda6ff79" alt=""
data:image/s3,"s3://crabby-images/23e0d/23e0d2c4d6fccb6d90c8831256dfba3423f71ce8" alt=""
Jaccard index
The Jaccard index, also known as the Jaccard similarity coefficient , is a statistic used for comparing the similarity and diversity of sample sets....
data:image/s3,"s3://crabby-images/329bc/329bcea3eeaccc21784d94901b06a744a65b5c7b" alt=""
data:image/s3,"s3://crabby-images/ffab9/ffab94df5533b8afefdb92e16084ed1e26f6aff8" alt=""
data:image/s3,"s3://crabby-images/88d89/88d89eb6cbf9489f504451a01069a21a39c8dacc" alt=""
data:image/s3,"s3://crabby-images/7ec02/7ec02b2a3e3e0d3bf6454d0a4ce09b268cfc6d30" alt=""
data:image/s3,"s3://crabby-images/8d4e1/8d4e1b057cdbacbefdb264af93472f4710fc49b2" alt=""
data:image/s3,"s3://crabby-images/19550/1955002347a53de41ea61065204d13541f80d9a4" alt=""
data:image/s3,"s3://crabby-images/cf40a/cf40ab0501bcb67ef829a6094fd5f6696f79783f" alt=""
Define the function family
data:image/s3,"s3://crabby-images/15d8c/15d8c34681c60d360261fa88f2599d0a66ad6a78" alt=""
data:image/s3,"s3://crabby-images/a23e7/a23e7e43a37de3f3634a3d7ac986975a06a4f7ba" alt=""
data:image/s3,"s3://crabby-images/61f8c/61f8c03e163614fa50573e3714fb7aa366b842b0" alt=""
data:image/s3,"s3://crabby-images/f0a60/f0a6029554fc24804a812b3bf8fa53f1fb74ec4d" alt=""
data:image/s3,"s3://crabby-images/285b3/285b3c5ac32b209d7a693d1abadbd45e118004f0" alt=""
data:image/s3,"s3://crabby-images/3317d/3317ddc9e68835c43b9428f063939a3ae3914c99" alt=""
data:image/s3,"s3://crabby-images/948c6/948c67bd622218a719667af38decd2ceeb6520e6" alt=""
data:image/s3,"s3://crabby-images/5a1a4/5a1a43a563aff149a4aa4ba1914b2972dd1bab3c" alt=""
data:image/s3,"s3://crabby-images/7ee6e/7ee6ebda5011dbb8f527ed4544549a2d22ae383b" alt=""
Because the symmetric group on n elements has size n!, choosing a truly random permutation from the full symmetric group is infeasible for even moderately sized n. Because of this fact, there has been significant work on finding a family of permutations that is "min-wise independent" - a permutation family for which each element of the domain has equal probability of being the minimum under a randomly chosen
data:image/s3,"s3://crabby-images/5648b/5648b27c3bf9d3ba94580f906effe5d8ae80844b" alt=""
data:image/s3,"s3://crabby-images/4cec7/4cec7711a8d04efc077a9ff2aefa30d0b3b37bc2" alt=""
Because min-wise independent families are too big for practical applications, two variant notions of min-wise independence are introduced: restricted min-wise independent permutations families, and approximate min-wise independent families.
Restricted min-wise independence is the min-wise independence property restricted to certain sets of cardinality at most k .
Approximate min-wise independence differs from the property by at most a fixed
data:image/s3,"s3://crabby-images/4bea6/4bea627b02d0e0c99441e2369fa4447b308b243a" alt=""
Random projection
The random projection method of LSH is designed to approximate the cosine distance between vectors. The basic idea of this technique is to choose a random hyperplaneHyperplane
A hyperplane is a concept in geometry. It is a generalization of the plane into a different number of dimensions.A hyperplane of an n-dimensional space is a flat subset with dimension n − 1...
(defined by a normal unit vector
data:image/s3,"s3://crabby-images/d1f90/d1f903b97ad7512accaba8fe15b39017e3378e88" alt=""
Given an input vector
data:image/s3,"s3://crabby-images/40abb/40abbc515553b8e5056e82a449cee9ebe11a92a9" alt=""
data:image/s3,"s3://crabby-images/0f6d7/0f6d78ca47920f5008cf7497d15773f74ec33a28" alt=""
data:image/s3,"s3://crabby-images/9973a/9973a8acd41451107e1fd13cc84157d913b1a370" alt=""
data:image/s3,"s3://crabby-images/e5934/e59344eb4959fc42f68efb97f522a736fa1e51f5" alt=""
data:image/s3,"s3://crabby-images/2477a/2477a237961587f115f1566091441f5b7d7bf764" alt=""
Each possible choice of
data:image/s3,"s3://crabby-images/fd20f/fd20f372ad15d754ab92afa59f359cdca2b0f8a4" alt=""
data:image/s3,"s3://crabby-images/32b2a/32b2a211a27fda8470af85a68d3cecfa87047aa1" alt=""
data:image/s3,"s3://crabby-images/01574/01574b6d3d62d20244b43ea34186f63dd650c8c1" alt=""
data:image/s3,"s3://crabby-images/a53d8/a53d878c4bd3ce7f1a948fe52446ff1726fed7e3" alt=""
data:image/s3,"s3://crabby-images/37b61/37b614bf36676d8d8da98dea1928d9dc7626aa8b" alt=""
data:image/s3,"s3://crabby-images/cd3b3/cd3b3e961818ff6ee210d260e7a2ea7d585e3c5d" alt=""
data:image/s3,"s3://crabby-images/284ee/284ee06eb267080b166231bd3a956bea1f10d2f3" alt=""
data:image/s3,"s3://crabby-images/f526b/f526be818c759ea7383edd236a72f76f581244aa" alt=""
data:image/s3,"s3://crabby-images/36f4d/36f4db81e861908610a5768f9cc82258de769fa4" alt=""
data:image/s3,"s3://crabby-images/3e7f5/3e7f55d29a6c5a65dcc12fb77d06019371cab813" alt=""
In this instance hashing produces only a single bit. Two vectors' bits match with probability proportional to the cosine of the angle between them.
Stable distributions
The hash functiondata:image/s3,"s3://crabby-images/d8aa7/d8aa7632c5b2d4528e5d82272b332fc39bed1b7f" alt=""
data:image/s3,"s3://crabby-images/5b740/5b740d79dacf2be030b2a40c4b6427e4ffdb1d39" alt=""
in the family is indexed by a choice of random
data:image/s3,"s3://crabby-images/11924/11924ced8640765efe360d057b94569a2978f82d" alt=""
data:image/s3,"s3://crabby-images/68c11/68c11af885573431c7887243e866009cd2f6d90e" alt=""
data:image/s3,"s3://crabby-images/f558c/f558ce43398af068f16d0d2d8ee244f094261c86" alt=""
vector with
entries chosen independently from a stable distribution and
data:image/s3,"s3://crabby-images/f1c38/f1c3873029595bb2775c99e00154b704aa4870d1" alt=""
a real number chosen uniformly from the range [0,r]. For a fixed
data:image/s3,"s3://crabby-images/6b7e4/6b7e4fb2869bac4a3dfcb3d943f738981f60bf26" alt=""
data:image/s3,"s3://crabby-images/f85e1/f85e1915405bb1a8d16c357df67d11cb06ec8d46" alt=""
given by
data:image/s3,"s3://crabby-images/ec0e9/ec0e9ecac86fd45f142dc6425408ca8dcca6ebc3" alt=""
Other construction methods for hash functions have been proposed to better fit the data.
In particular k-means hash functions are better in practice than projection-based hash functions, but without any theoretical guarantee.
LSH algorithm for nearest neighbor search
One of the main application of LSH is to provide efficient nearest neighbor searchNearest neighbor search
Nearest neighbor search , also known as proximity search, similarity search or closest point search, is an optimization problem for finding closest points in metric spaces. The problem is: given a set S of points in a metric space M and a query point q ∈ M, find the closest point in S to q...
algorithms.
Consider any LSH family
data:image/s3,"s3://crabby-images/c37ab/c37ab304ab86225845d0c0208521e389123ed14b" alt=""
algorithm has two main parameters: the width parameter
data:image/s3,"s3://crabby-images/9af6f/9af6f9ed46100351a46c869ee7f7e9a4bbe9d438" alt=""
number of hash tables
data:image/s3,"s3://crabby-images/2e50b/2e50b81d20588153b1186aca6039b3cd0bedcb5e" alt=""
In the first step, we define a new family
data:image/s3,"s3://crabby-images/d721b/d721b00241a1de9eb726fbe040ceda69270b6294" alt=""
functions
data:image/s3,"s3://crabby-images/42c4b/42c4bb89b1695615bfac79f7290c6563d9414043" alt=""
data:image/s3,"s3://crabby-images/168ed/168ed6d8dc0fd6b1b2b065c4a205268c056fa591" alt=""
obtained by concatenating
data:image/s3,"s3://crabby-images/d9393/d939397cb70e06fa4e229bac60d431cd6b4114b9" alt=""
data:image/s3,"s3://crabby-images/e136b/e136b62616fca2162e8fa49843303f6133d9d40e" alt=""
data:image/s3,"s3://crabby-images/dcd21/dcd21a1564463d541cabacc0b91bd53f4b10b4c7" alt=""
data:image/s3,"s3://crabby-images/cd931/cd9317a8cda4672e11e1296895752f5350453698" alt=""
In other words, a random hash function
data:image/s3,"s3://crabby-images/a7603/a760329603c6098bc3fa7c7a83aef5e9c2aa40fe" alt=""
concatenating
data:image/s3,"s3://crabby-images/832d9/832d9ce7f9e31f9e0854f3d243bcc313de49e2d5" alt=""
data:image/s3,"s3://crabby-images/c304a/c304ab1163d5d685c44bc6539205646922a97d63" alt=""
The algorithm then constructs
data:image/s3,"s3://crabby-images/02519/02519ef47e636d15d0c0d588ced24d28ebbdd40c" alt=""
corresponding to
a different randomly chosen hash function
data:image/s3,"s3://crabby-images/88663/886634bb84339682a227f7c1c893cb81f338e350" alt=""
In the preprocessing step we hash all
data:image/s3,"s3://crabby-images/508bd/508bd910d5224819f7ef3264d34eaba57d8f1a5f" alt=""
data:image/s3,"s3://crabby-images/02c9a/02c9af198a8946d16673d90cd993b8f6186f6b92" alt=""
the
data:image/s3,"s3://crabby-images/16432/164322a20d0e126812708fc202159ebe2e9e58a2" alt=""
Given that the resulting hash tables have only
data:image/s3,"s3://crabby-images/fc8b0/fc8b04a9f0a5801e6c745269a423dcc8baba3ef4" alt=""
entries,
one can reduce the amount of memory used per each hash table to
data:image/s3,"s3://crabby-images/cda07/cda07421c606360745ae59a73b95a0a8fc18b449" alt=""
Given a query point
data:image/s3,"s3://crabby-images/0a6ce/0a6ce1c64e634fee5e8032f1878c34634c0830d1" alt=""
data:image/s3,"s3://crabby-images/73a15/73a15d289d59e3b6fb4b8634089b9dc16e56e8c8" alt=""
data:image/s3,"s3://crabby-images/b842c/b842c285f6ab2cc8156c11efd360023250ad6b20" alt=""
For each
data:image/s3,"s3://crabby-images/a1f66/a1f66a27c9ea0831412e6ab9a6e532e9ade681e1" alt=""
are hashed
into the same bucket as
data:image/s3,"s3://crabby-images/d9148/d9148bc6a0e7a3a86bfdd71f78283013a9b1b9f6" alt=""
The process is stopped as soon as a point within distance
data:image/s3,"s3://crabby-images/ec1c0/ec1c0d7b88e21cc1bdb974075e5f09694afcae37" alt=""
data:image/s3,"s3://crabby-images/a3ece/a3ece6f9d14c5e85b23da5429eb862f6e0f5fc7a" alt=""
Given the parameters
data:image/s3,"s3://crabby-images/fc70b/fc70b735ad2e339150e8bf3a610b97203eaf37ac" alt=""
data:image/s3,"s3://crabby-images/991de/991de912043587b2f7e4a3fc7f266ea1f5533042" alt=""
the following performance guarantees:
- preprocessing time:
, where
is the time to evaluate a function
on an input point
;
- space:
, plus the space for storing data points;
- query time:
;
- the algorithm succeeds in finding a point within distance
from
(if it exists) with probability at least
;
For a fixed approximation ratio
data:image/s3,"s3://crabby-images/76599/7659914f9d330f526029f3329955386314558fca" alt=""
data:image/s3,"s3://crabby-images/04ab5/04ab55f7618630aed2f695e6fdefbd6ad317b967" alt=""
data:image/s3,"s3://crabby-images/47664/47664ff8066f4a7dfe46779cb09d367377a1ec5c" alt=""
data:image/s3,"s3://crabby-images/9363e/9363e833b0cbd4dc69f6f01560b0734d6630b069" alt=""
data:image/s3,"s3://crabby-images/7941d/7941d960d6340a3242a73476f21e8cf804887319" alt=""
data:image/s3,"s3://crabby-images/15376/15376cd661df8312a92df81f2235e0f9b2e63cc0" alt=""
Then one obtains the following performance guarantees:
- preprocessing time:
;
- space:
, plus the space for storing data points;
- query time:
;
See also
- Nearest neighbor searchNearest neighbor searchNearest neighbor search , also known as proximity search, similarity search or closest point search, is an optimization problem for finding closest points in metric spaces. The problem is: given a set S of points in a metric space M and a query point q ∈ M, find the closest point in S to q...
- Dimension reduction
- Principal component analysis
- Singular value decompositionSingular value decompositionIn linear algebra, the singular value decomposition is a factorization of a real or complex matrix, with many useful applications in signal processing and statistics....
- Curse of dimensionalityCurse of dimensionalityThe curse of dimensionality refers to various phenomena that arise when analyzing and organizing high-dimensional spaces that do not occur in low-dimensional settings such as the physical space commonly modeled with just three dimensions.There are multiple phenomena referred to by this name in...
- Cluster analysis
- Wavelet compression
- Fourier-related transforms
Further reading
- Samet, H. (2006) Foundations of Multidimensional and Metric Data Structures. Morgan Kaufmann. ISBN 0-12-369446-9
External links
- Alex Andoni's LSH homepage
- LSHKIT: A C++ Locality Sensitive Hashing Library
- Caltech Large Scale Image Search Toolbox: a Matlab toolbox implementing several LSH hash functions, in addition to Kd-Trees, Hierarchical K-Means, and Inverted File search algorithms.