chess:programming:search
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
chess:programming:search [2021/10/11 22:44] – peter | chess:programming:search [2022/01/07 10:05] (current) – peter | ||
---|---|---|---|
Line 1: | Line 1: | ||
====== Chess - Programming - Search ====== | ====== Chess - Programming - Search ====== | ||
- | [[Chess: | + | The object of Chess is to checkmate the other player, to avoid being checkmated, or to achieve a draw if that is the best thing given the circumstances. |
- | + | ||
- | [[Chess: | + | |
- | + | ||
- | [[Chess: | + | |
- | + | ||
- | [[Chess: | + | |
+ | A chess program selects moves via use of a search function. | ||
+ | * A search function is a function that is passed information about the game, and tries to find the best move for side that the program is playing. | ||
---- | ---- | ||
+ | [[Chess: | ||
- | ---- | + | [[Chess: |
- | ===== Negamax ===== | + | [[Chess: |
- | Negamax is a common way of implementing minimax and derived algorithms. | + | [[Chess: |
- | * Instead of using two separate subroutines for the Min player and the Max player, it passes on the negated score due to following mathematical relation: | + | [[Chess: |
- | + | ||
- | < | + | |
- | max(a, b) == -min(-a, -b) | + | |
- | </ | + | |
- | + | ||
- | This is how the pseudo-code of the recursive algorithm looks like. For clarity move making and unmaking is omitted. | + | |
- | + | ||
- | < | + | |
- | int negaMax( int depth ) { | + | |
- | if ( depth == 0 ) return evaluate(); | + | |
- | int max = -oo; | + | |
- | for ( all moves) | + | |
- | score = -negaMax( depth - 1 ); | + | |
- | if( score > max ) | + | |
- | max = score; | + | |
- | } | + | |
- | return max; | + | |
- | } | + | |
- | </ | + | |
- | + | ||
- | ---- | + | |
- | + | ||
- | ===== Quiescence | + | |
- | + | ||
- | < | + | |
- | int Quiesce( int alpha, int beta ) { | + | |
- | int stand_pat = Evaluate(); | + | |
- | if( stand_pat >= beta ) | + | |
- | return beta; | + | |
- | if( alpha < stand_pat ) | + | |
- | alpha = stand_pat; | + | |
- | + | ||
- | until( every_capture_has_been_examined ) { | + | |
- | MakeCapture(); | + | |
- | score = -Quiesce( -beta, -alpha ); | + | |
- | TakeBackMove(); | + | |
- | + | ||
- | if( score >= beta ) | + | |
- | return beta; | + | |
- | if( score > alpha ) | + | |
- | alpha = score; | + | |
- | } | + | |
- | return alpha; | + | |
- | } | + | |
- | </ | + | |
+ | [[Chess: | ||
---- | ---- |
chess/programming/search.1633992259.txt.gz · Last modified: 2021/10/11 22:44 by peter