User Tools

Site Tools


chess:programming:search

Differences

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

Link to this comparison view

Next revision
Previous revision
chess:programming:search [2021/10/11 22:28] – created peterchess:programming:search [2022/01/07 10:05] (current) peter
Line 1: Line 1:
 ====== Chess - Programming - Search ====== ====== Chess - Programming - Search ======
 +
 +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.
 +
 +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.
  
 ---- ----
  
-===== Negamax =====+[[Chess:Programming:Search:About Searching|About Searching]]
  
-Negamax is a common way of implementing minimax and derived algorithms.+[[Chess:Programming:Search:Alpha-Beta|Alpha-Beta]]
  
-  * 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:Programming:Search:Binary Search using pthread|Binary Search using pthread]]
  
-<code> +[[Chess:Programming:Search:Minimax|Minimax]]
-max(a, b) == -min(-a, -b) +
-</code>+
  
-This is how the pseudo-code of the recursive algorithm looks like. For clarity move making and unmaking is omitted.+[[Chess:Programming:Search:Negamax|Negamax]]
  
-<code> +[[Chess:Programming:Search:Quiescence Search|Quiescence Search]]
-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; +
-+
-</code>+
  
 ---- ----
  
 ==== References ==== ==== References ====
 +
 +http://web.archive.org/web/20120421170110/http://chessprogramming.wikispaces.com/Alpha-Beta
 +
 +http://web.archive.org/web/20120209041607/http://chessprogramming.wikispaces.com/Minimax
  
 http://web.archive.org/web/20120209042116/http://chessprogramming.wikispaces.com/Negamax http://web.archive.org/web/20120209042116/http://chessprogramming.wikispaces.com/Negamax
  
 +http://web.archive.org/web/20120427185347/http://chessprogramming.wikispaces.com/Quiescence+Search
  
chess/programming/search.1633991303.txt.gz · Last modified: 2021/10/11 22:28 by peter

Donate Powered by PHP Valid HTML5 Valid CSS Driven by DokuWiki