User Tools

Site Tools


chess:programming:bitboards

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revisionPrevious revision
Next revision
Previous revision
chess:programming:bitboards [2021/10/12 12:59] peterchess:programming:bitboards [2021/10/29 00:56] (current) peter
Line 2: Line 2:
  
 A BitBoard is comprised of a 64-bit word, which is used to store the positions of different Chess Pieces. A BitBoard is comprised of a 64-bit word, which is used to store the positions of different Chess Pieces.
 +
 +<code>
 +8 0 0 0 0 0 0 0 0 
 +7 0 0 0 0 0 0 0 0 
 +6 0 0 0 0 0 0 0 0 
 +5 0 0 0 0 0 0 0 0 
 +4 0 0 0 0 0 0 0 0 
 +3 0 0 0 0 0 0 0 0 
 +2 0 0 0 0 0 0 0 0 
 +1 0 0 0 0 0 0 0 0 
 +  a b c d e f g h
 +</code>
  
 Every square on a Chess Board is represented by one bit in the 64-bit word. Every square on a Chess Board is represented by one bit in the 64-bit word.
Line 122: Line 134:
 . . . 1 . 1 . .     . . . . . . . .     . . . . . . . . . . . 1 . 1 . .     . . . . . . . .     . . . . . . . .
 . . . 1 . . . .     . . . . . . . .     . . . . . . . . . . . 1 . . . .     . . . . . . . .     . . . . . . . .
 +</code>
 +
 +----
 +
 +===== Determine Empty Squares =====
 +
 +The set of empty squares for instance is the complement-set of all occupied squares and vice versa:
 +
 +<code>
 +~occupied squares  =   empty squares
 +  1 . 1 1 1 1 1 1      . 1 . . . . . .
 +  1 1 1 1 . 1 1 1      . . . . 1 . . .
 +  . . 1 . . . . .      1 1 . 1 1 1 1 1
 +  . . . . 1 . . .      1 1 1 1 . 1 1 1
 +~ . . . . 1 . . .  =   1 1 1 1 . 1 1 1
 +  . . . . . 1 . .      1 1 1 1 1 . 1 1
 +  1 1 1 1 . 1 1 1      . . . . 1 . . .
 +  1 1 1 1 1 1 . 1      . . . . . . 1 .
 +</code>
 +
 +----
 +
 +===== Determine Squares which are exclusively set in one of the two sets  =====
 +
 +Use XOR (Exclusive or).
 +
 +<code>
 +1 . . . . . . 1     . . . . . . . .     1 . . . . . . 1
 +. 1 . . . . 1 .     . . . . . . . .     . 1 . . . . 1 .
 +. . 1 . . 1 . .     . . 1 1 1 1 . .     . . . 1 1 . . .
 +. . . 1 1 . . .     . . 1 1 1 1 . .     . . 1 . . 1 . .
 +. . . 1 1 . . .  ^  . . 1 1 1 1 . .  =  . . 1 . . 1 . .
 +. . 1 . . 1 . .     . . 1 1 1 1 . .     . . . 1 1 . . .
 +. 1 . . . . 1 .     . . . . . . . .     . 1 . . . . 1 .
 +1 . . . . . . 1     . . . . . . . .     1 . . . . . . 1
 +</code>
 +
 +----
 +
 +===== Determine Squares which are set in both BitBoards =====
 +
 +Determine if one Bitboard is a subset of the other.
 +
 +  * Use xor (or subtraction).
 +
 +<code>
 +super               sub                 super &~ sub
 +. . . . . . . .     . . . . . . . .     . . . . . . . .
 +. 1 1 1 1 1 1 .     . . . . . . . .     . 1 1 1 1 1 1 .
 +. 1 1 1 1 1 1 .     . . 1 1 1 1 . .     . 1 . . . . 1 .
 +. 1 1 1 1 1 1 .  ^  . . 1 1 1 1 . .     . 1 . . . . 1 .
 +. 1 1 1 1 1 1 .     . . 1 1 1 1 . .  =  . 1 . . . . 1 .
 +. 1 1 1 1 1 1 .  -  . . 1 1 1 1 . .     . 1 . . . . 1 .
 +. 1 1 1 1 1 1 .     . . . . . . . .     . 1 1 1 1 1 1 .
 +. . . . . . . .     . . . . . . . .     . . . . . . . .
 </code> </code>
  
chess/programming/bitboards.1634043572.txt.gz · Last modified: 2021/10/12 12:59 by peter

Donate Powered by PHP Valid HTML5 Valid CSS Driven by DokuWiki