chess:programming:de_bruijn_sequence
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
chess:programming:de_bruijn_sequence [2021/10/30 13:13] – peter | chess:programming:de_bruijn_sequence [2021/10/30 16:52] (current) – peter | ||
---|---|---|---|
Line 1: | Line 1: | ||
====== Chess - Programming - de Bruijn Sequence ====== | ====== Chess - Programming - de Bruijn Sequence ====== | ||
- | A **de Bruijn Sequence** can be used to build a "private **bitScanForward** routine, and to get the LSB (Last Significant Bit). | + | A **de Bruijn Sequence** |
+ | |||
+ | It can be used to build a private **bitScanForward** routine, and to get the LSB (Least Significant Bit). | ||
A chess board is conveniently 8 x 8 squares, and these can be represented by the numbers 0-63, which is a nice fit for a six-bit long De Bruijn sequence. | A chess board is conveniently 8 x 8 squares, and these can be represented by the numbers 0-63, which is a nice fit for a six-bit long De Bruijn sequence. | ||
Line 10: | Line 12: | ||
* There are 64 times more sequences by rotating the initial one. | * There are 64 times more sequences by rotating the initial one. | ||
* So in total 2^32 possible 64*6bit De Bruijn Sequences! | * So in total 2^32 possible 64*6bit De Bruijn Sequences! | ||
+ | |||
+ | ---- | ||
+ | |||
+ | ===== De Bruijn for B(2,4) ===== | ||
+ | |||
+ | The cyclic sequence **0000100110101111** of length 16 is a de Bruijn sequence for n = 4. | ||
+ | |||
+ | The 16 unique sub-strings of length 4 when considered cyclicly are: | ||
+ | |||
+ | < | ||
+ | 0000, | ||
+ | </ | ||
+ | |||
+ | ---- | ||
+ | |||
+ | Taking each 4-bits | ||
+ | |||
+ | < | ||
+ | 0000100110101111 | ||
+ | </ | ||
+ | |||
+ | returns: | ||
+ | |||
+ | < | ||
+ | 0000 | ||
+ | 0001 | ||
+ | 0010 | ||
+ | 0100 | ||
+ | 1001 | ||
+ | 0011 | ||
+ | 0110 | ||
+ | 1101 | ||
+ | 1010 | ||
+ | 0101 | ||
+ | 1011 | ||
+ | 0111 | ||
+ | 1111 | ||
+ | 1110 | ||
+ | </ | ||
+ | |||
+ | <WRAP info> | ||
+ | **NOTE:** The last 3 wraps around to the start to get the 4th digit. | ||
+ | </ | ||
+ | |||
+ | ---- | ||
+ | |||
+ | ===== de Bruijn values ===== | ||
+ | |||
+ | ^n^de Bruijn^ | ||
+ | |1|01| | ||
+ | |2|1100| | ||
+ | |3|00010111| | ||
+ | |3|01110100| | ||
+ | |4|0000100110101111| | ||
+ | |4|1111011001010000| | ||
+ | |5|11010100111011000101111100100000| | ||
+ | |6|0000001000011000101001111010001110010010110111011001101010111111| | ||
---- | ---- | ||
Line 22: | Line 81: | ||
[[Chess: | [[Chess: | ||
+ | |||
+ | [[Chess: | ||
---- | ---- | ||
+ | |||
+ | TODO | ||
+ | |||
+ | < | ||
+ | Why does the standard numbering equation for de Bruijn sequences give differing results for dB(16,4) and dB(2,16), when both are 16 bits? | ||
+ | De Bruijn sequences are numbered by the equation | ||
+ | dB(k,n) = ((k!)^(k^(n-1)))/ | ||
+ | When we have dB(2,16), the computed value is of the order 2.1598E+9859 . | ||
+ | For dB(16,4), the computed value is of the order 2.7629E+54556. | ||
+ | Yet, both sequences are represented within just 64K bytes of memory. | ||
+ | Only one of these computations can be correct. | ||
+ | </ | ||
+ | |||
+ | ---- | ||
+ | |||
===== References ===== | ===== References ===== | ||
Line 32: | Line 108: | ||
http:// | http:// | ||
+ | |||
+ | https:// | ||
https:// | https:// | ||
+ | |||
+ | https:// | ||
https:// | https:// | ||
+ | |||
+ |
chess/programming/de_bruijn_sequence.1635599584.txt.gz · Last modified: 2021/10/30 13:13 by peter