one-eyed-king |
So then, what's all this all about?I just wanted a simple chess program to practice against. Casual, like. What I found is a dedicated band of chess-engine builders locked in an algorithmic arms-race. This has produced a growing selection of free chess bots for us mere mortals to enjoy. I started compiling the better-known engines on an abandoned Raspberry Pi v1, just to see how well they might work.
All the engines here will have a full-strength ELO rating of at least 2500. Stockfish6 is current king - at full strength it's ELO rating is 3250 and still improving. Engine strength on the Pi - whilst obviously somewhat limited by the meagre hardware - should still be enough to crush most club players. Where possible, the engines have been compiled from latest-version source. I have exposed the key skill settings for some engines, but tuning will require a lot of experimentation. Next steps: Eventual aim is to host on a GitHub repo and prepare a ready-to-go ISO file for Raspberry Pi owners, many of whom have probably upgraded to PI 2 by now, are and looking to re-purpose. WebUI courtesy of Dr. R. Urban and chessboard.js. Contact stimresp at gmail. |
Engine Settings Explained |
MovetimeThe engine should be allowed to 'think' for this number of milliseconds. Maximum is usually 5 seconds, but default settings around 500ms are sufficient to out-fox most human players. |
Skill LevelScale of 0-20, but don't be fooled, even the lowest settings they can still serve-up some serious ass whoopin' if you're not careful. |
Contempt"Contempt of draw", i.e. the extent to which it prefers to continue a game it considers level rather than draw. The value is expressed in centipawns (e.g. 25 is a quarter of a pawn). A negative contempt value means that the engine prefers to draw rather than continue even with a slight advantage. Technically, an engine evaluates a draw as minus the contempt value. A positive contempt value is useful in avoiding quick chance draws against weaker opponents.The Contempt Factor reflects the estimated superiority/inferiority of the program over its opponent. If the engine has high contempt for its opponent, it should adopt a more attacking style. |
AggressivenessMakes the engine more or less aggressive. |
CowardiceDefine how defensive towards its own king the engine should be. |
Mobility - Midgame/EndgameA factor for how much the engine will value piece mobility. More mobility leads to more attacking and unpredictable positions. |
HashSets the size (in megabytes) of the the transposition ("hash") table. The larger the hash table, the more effective the engine's search. A doubling of hash table size will result in a moderate increase in playing strength |
Pawn structureDescribe the positions of all the pawns on the board, ignoring all other pieces. Pawn structure encompasses a broad range of ideas, from the general shape of the pawns (such as closed or open) to specific characteristics of individual pawns. |
Book selectivityThe minimum probability percentage to make an internal opening book move playable. Moves with lower probability will not be played. This option may be used to control the selectivity of the (internal) opening book: Higher selectivity means that only the most common moves will be played. Lower selectivity means that Deep Junior will occasionally select less frequent moves. |
ThreadsSets the number of CPU cores (threads) that Deep Junior will utilize when thinking (up to 40 cores). The default is to use all available CPU cores. You may reduce this number in order not to utilize the full CPU resources of your computer. |
PonderControls whether the engine will think on the opponent's time. For obvious reasons, this feature has been disabled on engines running on the Pi.. |
MultiPVSets how many alternatives to find in analysis mode: If MultiPV is set to, e.g., 3, the engine analysis will suggest a best move, a 2nd best move and a 3rd best move. The default is to suggest a best move only. |
Futility Pruningin its pure form is implemented at the frontier nodes (depth == 1). It discards the moves that have no potential of raising alpha, which in turn requires some estimate of a potential value of a move. This is calculated by adding a futility margin (representing the largest conceivable positional gain) to the evaluation of the current position. If this does not exceed alpha then the futility pruning is triggered (which usually means setting a flag like f_prune = 1). In short futility pruning prunes nodes that are so bad that they most likely can not compete with the principal variation. |
|
Understanding the UCI Protocol |
It's quite simple really, but somewhat confusing at first. The UCI Protocl is explained here and it's definitely worth the 5 minutes it takes to read. The most important 'gotcha' for me was to realise that you have to input all the moves. The engine analyses a position you feed it, anf rom that will only suggest the best move to make. The GUI handles functions such a books... |
|
Links |
The Chess Programming Wiki is a repository of information about programming computers to play chess. |