chess:programming:search:negamax

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:search:negamax [2021/10/11 22:50] peterchess:programming:search:negamax [2021/10/11 23:50] (current) peter
Line 1: Line 1:
 ====== Chess - Programming - Search - Negamax ====== ====== Chess - Programming - Search - Negamax ======
  
-===== Negamax ===== +Negamax is a common way of implementing Minimax and derived algorithms.
- +
-Negamax is a common way of implementing minimax and derived algorithms.+
  
   * 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:   * 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:
 +
 +----
 +
 +===== How to Use NegaMax =====
 +
 +NegaMax is called from a root function.  
 +
 +In the loop which generates all the root moves:
 +
 +  * Generate a **Score** relative to the side being evaluated, for a specific move.
 +  * In the Root retain the returned score for each potential move.
 +  * Pick the move with the lowest score.
 +
 +----
  
 <code> <code>
Line 25: Line 37:
 } }
 </code> </code>
 +
 +<WRAP info>
 +**NOTE:**  In order for NegaMax to work, the Static Evaluation function must return a **score** relative to the side to being evaluated.
 +
 +  * This score must be symmetric.
 +    *  The simplest score evaluation could be: **score = materialWeight * (numWhitePieces - numBlackPieces) * who2move** where who2move = 1 for white, and who2move = -1 for black.
 +
 +</WRAP>
  
 ---- ----
  
 ===== References ===== ===== References =====
 +
 +http://web.archive.org/web/20120209042116/http://chessprogramming.wikispaces.com/Negamax
  
chess/programming/search/negamax.1633992646.txt.gz · Last modified: 2021/10/11 22:50 by peter

Donate Powered by PHP Valid HTML5 Valid CSS Driven by DokuWiki