User Tools

Site Tools


chess:programming:checklist

This is an old revision of the document!


Chess - Programming - Checklist

A list of items to consider using:

BitBoards

  • Board. [done]
  • Magic Bitboards. [done]

Grids

  • Traditional grid. [done]

Move Generation

  • Opening Books.
    • Own format.
    • Huffman.
    • Polygot.
  • Random Move Generation.
  • Staged Move Generation.

Move Prioritization

  • Best Move (from hash table).
  • Captures
    • by Most Valuable Victim (MVV)
    • by Least Valuable Attacker (LVA).
  • Pawn Promotions.
  • History Heuristic.
  • Killer Moves.

Move Storage

  • FEN. [done]
  • PGN.

Searching

  • Alpha / Beta Negamax search.
  • Aspiration Windows.
  • MinMax search.
  • MultiPV (Single, non-PVS search).
  • Multi Threading.
    • Ponder.
  • Principal Variation Search (PVS).
  • Quiet Search (Quiescence Search).
  • End-Games.
    • Common end-games (K vs KP, K vs KQ, K v KR, K v KBN).

Pruning

  • Futility Pruning.
  • Null Move Pruning.
  • Late Move Pruning (LMP).
  • Late Move Reductions (LMR).

Evaluations

  • Standard Evaluations:
    • Mate
    • Stalemate
    • Draw by 3-fold repetition
    • Draw by insufficient material.
    • 50 moves without a capture of pawn move.
  • Material Values.
    • Different values at different stages of the game (beginning, middle-game, end-game).
  • Positional Knowledge.
    • Piece Locations: [done]
      • Good and Bad squares.
      • Relative to own pieces.
      • Relative to opponent pieces.
      • Threatened pieces.
  • Piece Mobility.
  • Piece Occupancy.
    • Control of Center.
  • End-Games.
    • Drawing end-games.
    • End-games without Pawns.
  • Bishops.
    • On long diagonals.
  • Bishop Pair.
    • In Open games.
  • Knights.
    • In Closed games.
  • Pawns.
    • Blocked.
    • Passed.
    • Passed and escorted by a piece.
    • Passed and escorted by king.
    • Passed and free.
    • Passed and unstoppable.
    • Alone pawns.
  • King Safety.
    • Castled.
    • Near a semi-open file.
    • Near squares attacked by opponent.
    • Pawn Shield.

Speed / Strength

  • Nodes Per Second (Search Speed).
  • Depth settings.
  • Perft. [done]
  • Divide. [done]

Time-Controls

  • Seconds per move.
  • Moves per time-frame.
  • Bullet.
  • Blitz.
  • Rapid chess

Transposition Tables

  • Transposition (hash) Tables. [done]
    • Zorbrist. [done]

Protocols

  • UCI Protocol
  • Winboard
chess/programming/checklist.1636417302.txt.gz · Last modified: 2021/11/09 00:21 by peter

Donate Powered by PHP Valid HTML5 Valid CSS Driven by DokuWiki