chess:programming:zobrist_hashing
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
chess:programming:zobrist_hashing [2021/10/30 21:27] – peter | chess:programming:zobrist_hashing [2021/10/30 21:41] (current) – [Implementation Consideration] peter | ||
---|---|---|---|
Line 1: | Line 1: | ||
====== Chess - Programming - Zobrist Hashing ====== | ====== Chess - Programming - Zobrist Hashing ====== | ||
- | **Zobrist Hashing** is a technique to transform a board position of arbitrary size into a number of a set length, with an equal distribution over all possible numbers. | + | **Zobrist Hashing** is a hashing function that is widely used in 2 player |
* The main purpose of Zobrist hash codes in chess programming is to get an almost unique index number for any chess position, with a very important requirement that two similar positions generate entirely different indices. | * The main purpose of Zobrist hash codes in chess programming is to get an almost unique index number for any chess position, with a very important requirement that two similar positions generate entirely different indices. | ||
- | * These index numbers are used for faster and more space efficient Hash tables or databases, e.g. transposition tables and opening books. | + | |
+ | * Transposition tables basically store the evaluated values of previous board states, so that if they are encountered again we simply retrieve the stored value from the transposition table. | ||
+ | | ||
---- | ---- | ||
[[Chess: | [[Chess: | ||
- | |||
- | ---- | ||
- | |||
- | Zobrist Hashing is a hashing function that is widely used in 2 player board games. | ||
- | |||
- | * It is the most common hashing function used in transposition tables. | ||
- | * Transposition tables basically store the evaluated values of previous board states, so that if they are encountered again we simply retrieve the stored value from the transposition table. | ||
---- | ---- | ||
Line 166: | Line 161: | ||
<code cpp> | <code cpp> | ||
- | piece*color*square * 8 + 3*8) bits; | + | (piece*color*square * 8 + 3*8) bits; |
</ | </ | ||
* This will reduce array of about 8th in size. | * This will reduce array of about 8th in size. | ||
- | If a bit boundary is used, the array becomes | + | If a bit boundary is used, the array becomes: |
<code cpp> | <code cpp> | ||
- | piece*color*square + 63) bits; | + | (piece*color*square + 63) bits; |
</ | </ | ||
chess/programming/zobrist_hashing.1635629233.txt.gz · Last modified: 2021/10/30 21:27 by peter