|
| related topics |
| {math, number, function} |
| {system, computer, user} |
| {rate, high, increase} |
| {album, band, music} |
|
|
A hash function is any well-defined procedure or mathematical function that converts a large, possibly variable-sized amount of data into a small datum, usually a single integer that may serve as an index to an array (cf. associative array). The values returned by a hash function are called hash values, hash codes, hash sums, checksums or simply hashes.
Hash functions are mostly used to speed up table lookup or data comparison tasks—such as finding items in a database, detecting duplicated or similar records in a large file, finding similar stretches in DNA sequences, and so on.
A hash function may map two or more keys to the same hash value. In many applications, it is desirable to minimize the occurrence of such collisions, which means that the hash function must map the keys to the hash values as evenly as possible. Depending on the application, other properties may be required as well. Although the idea was conceived in the 1950s,[1] the design of good hash functions is still a topic of active research.
Hash functions are related to (and often confused with) checksums, check digits, fingerprints, randomization functions, error correcting codes, and cryptographic hash functions. Although these concepts overlap to some extent, each has its own uses and requirements and is designed and optimised differently. The HashKeeper database maintained by the American National Drug Intelligence Center, for instance, is more aptly described as a catalog of file fingerprints than of hash values.
Contents
Full article ▸
|
|
| related documents |
| Interval (mathematics) |
| Absolute value |
| Simplex |
| Huffman coding |
| Proofs of Fermat's little theorem |
| Lua (programming language) |
| Gaussian elimination |
| RSA |
| Cardinal number |
| Frame problem |
| Compass and straightedge constructions |
| Factorial |
| Kernel (algebra) |
| Numerical analysis |
| Sequence alignment |
| Group action |
| Prime number theorem |
| Abelian group |
| Dynamic programming |
| Central limit theorem |
| Denotational semantics |
| Multivariate normal distribution |
| Entropy (information theory) |
| Computable number |
| Fundamental group |
| Hyperreal number |
| Complete lattice |
| Binary-coded decimal |
| Logic programming |
| Infinity |
|