Jump to content

Chess engine: Difference between revisions

From Wikipedia, the free encyclopedia
Content deleted Content added
Filled in 7 bare reference(s) with reFill 2
m Disambiguating links to Junior (chess) (link changed to Junior (chess program); link changed to Junior (chess program); link changed to Junior (chess program); link changed to Junior (chess program); link changed to Junior (chess program)) using DisamAssist.
 
(36 intermediate revisions by 21 users not shown)
Line 1: Line 1:
{{Short description|Computer program for chess analysis and game}}
{{Short description|Computer program for chess analysis and game}}
{{Cleanup bare URLs|date=June 2022}}
{{Chess programming series}}
{{Chess programming series}}
In [[computer chess]], a '''chess engine''' is a [[computer program]] that analyzes [[chess]] or [[List of chess variants|chess variant]] positions, and generates a move or list of moves that it regards as strongest.<ref>blog.chess.com [http://blog.chess.com/zaifrun/creating-a-chess-engine-from-scratch-part-1 Creating a chess engine from scratch (Part 1: Basics)], Link date 28 June 2012</ref>
In [[computer chess]], a '''chess engine''' is a [[computer program]] that analyzes [[chess]] or [[List of chess variants|chess variant]] positions, and generates a move or list of moves that it regards as strongest.<ref>blog.chess.com [http://blog.chess.com/zaifrun/creating-a-chess-engine-from-scratch-part-1 Creating a chess engine from scratch (Part 1: Basics)] {{Webarchive|url=https://web.archive.org/web/20120308201127/http://blog.chess.com/zaifrun/creating-a-chess-engine-from-scratch-part-1 |date=2012-03-08 }}, Link date 28 June 2012</ref>


A chess engine is usually a [[Front and back ends|back end]] with a [[command-line interface]] with no graphics or [[windowing system|windowing]]. Engines are usually used with a front end, a windowed [[graphical user interface]] such as [[Chessbase]] or [[WinBoard]] that the user can interact with via a keyboard, mouse or touchscreen. This allows the user to play against multiple engines without learning a new user interface for each, and allows different engines to play against each other.
A chess [[software engine|engine]] is usually a [[Front and back ends|back end]] with a [[command-line interface]] with no graphics or [[windowing system|windowing]]. Engines are usually used with a front end, a windowed [[graphical user interface]] such as [[Chessbase]] or [[WinBoard]] that the user can interact with via a keyboard, mouse or touchscreen. This allows the user to play against multiple engines without learning a new user interface for each, and allows different engines to play against each other.


Many chess engines are now available for mobile phones and tablets, making them even more accessible.
Many chess engines are now available for mobile phones and tablets, making them even more accessible.
Line 10: Line 9:
==History==
==History==
{{main|History of chess engines}}
{{main|History of chess engines}}
The meaning of the term "chess engine" has evolved over time. In 1986, Linda and Tony Scherzer entered their program Bebe into the 4th [[World Computer Chess Championship]], running it on "Chess Engine," their brand name for the chess computer hardware<ref>{{Cite web|url=https://www.game-ai-forum.org/icga-tournaments/tournament.php?id=65|title = 4th World Computer Chess Championship - New York 1983 (ICGA Tournaments)|website=Game-ai-forum.org}}</ref> made, and marketed by their company Sys-10, Inc.<ref>{{Cite web|url=http://www.sys-10.com/|title=New SYS-10|website=Sys-10.com|access-date=26 June 2022}}</ref> By 1990 the developers of [[Deep Blue (chess computer)|Deep Blue]], [[Feng-hsiung Hsu]] and [[Murray Campbell]], were writing of giving their program a 'searching engine,' apparently referring to the software rather than the hardware.<ref>Feng-hsiung Hsu, Thomas Anantharaman, Murray Campbell and Andreas Nowatzyk. "A Grandmaster Chess Machine." ''Scientific American.'' October 1990.</ref> In December 1991, ''Computer-schach & Spiele'' referred to [[Chessbase]]'s recently released [[Fritz (chess)|Fritz]] as a 'Schach-motor,' the German translation for 'chess engine.<ref>Computer-schach & Spiele would later start using the English word 'engine,' eg. 1997#6 when describing Fritz or [[Hiarcs]].</ref> By early 1993, Marty Hirsch was drawing a distinction between commercial chess programs such as ''[[Chessmaster]] 3000'' or ''[[Battle Chess]]'' on the one hand, and 'chess engines' such as ''[[ChessGenius]]'' or his own ''[[MChess Pro]]'' on the other. In his characterization, commercial chess programs were low in price, had fancy graphics, but did not place high on the SSDF ([[Swedish Chess Computer Association]]) rating lists while engines were more expensive, and did have high ratings.<ref>"The True Value of Chess Software." ''Computer Chess Reports.'' 1992-3. vol. 3 no. 2 p. 22</ref>
The meaning of the term "chess engine" has evolved over time. In 1986, Linda and Tony Scherzer entered their program Bebe into the 4th [[World Computer Chess Championship]], running it on "Chess Engine," their brand name for the chess computer hardware<ref>{{Cite web|url=https://www.game-ai-forum.org/icga-tournaments/tournament.php?id=65|title=4th World Computer Chess Championship - New York 1983 (ICGA Tournaments)|website=Game-ai-forum.org|access-date=2018-12-02|archive-date=2018-12-02|archive-url=https://web.archive.org/web/20181202155211/https://www.game-ai-forum.org/icga-tournaments/tournament.php?id=65|url-status=dead}}</ref> made, and marketed by their company Sys-10, Inc.<ref>{{Cite web|url=http://www.sys-10.com/|title=New SYS-10|website=Sys-10.com|access-date=26 June 2022|archive-date=1 July 2022|archive-url=https://web.archive.org/web/20220701051917/http://sys-10.com/|url-status=live}}</ref> By 1990 the developers of [[Deep Blue (chess computer)|Deep Blue]], [[Feng-hsiung Hsu]] and [[Murray Campbell]], were writing of giving their program a 'searching engine,' apparently referring to the software rather than the hardware.<ref>Feng-hsiung Hsu, Thomas Anantharaman, Murray Campbell and Andreas Nowatzyk. "A Grandmaster Chess Machine." ''Scientific American.'' October 1990.</ref> In December 1991, ''Computer-schach & Spiele'' referred to [[Chessbase]]'s recently released [[Fritz (chess)|Fritz]] as a 'Schach-motor,' the German translation for 'chess engine.'<ref>Computer-schach & Spiele would later start using the English word 'engine,' eg. 1997#6 when describing Fritz or [[Hiarcs]].</ref> By early 1993, Marty Hirsch was drawing a distinction between commercial chess programs such as ''[[Chessmaster]] 3000'' or ''[[Battle Chess]]'' on the one hand, and 'chess engines' such as ''[[ChessGenius]]'' or his own ''[[MChess Pro]]'' on the other. In his characterization, commercial chess programs were low in price, had fancy graphics, but did not place high on the SSDF ([[Swedish Chess Computer Association]]) rating lists while engines were more expensive, and did have high ratings.<ref>"The True Value of Chess Software." ''Computer Chess Reports.'' 1992-3. vol. 3 no. 2 p. 22</ref>


In 1994, Shay Bushinsky was working on an early version of his ''[[Junior (chess)|Junior]]'' program. He wanted to focus on the chess playing part rather than the graphics, and so asked Tim Mann how he could get ''Junior'' to communicate with ''[[Winboard]].'' Tim's answer formed the basis for what became known as the Chess Engine Communication Protocol or Winboard engines, originally a subset of the [[GNU Chess]] command line interface.<ref>{{Cite web|url=http://tim-mann.org/history.html|title = XBoard Project History|website=Tim-mann.org}}</ref>
In 1994, Shay Bushinsky was working on an early version of his ''[[Junior (chess program)|Junior]]'' program. He wanted to focus on the chess playing part rather than the graphics, and so asked Tim Mann how he could get ''Junior'' to communicate with ''[[Winboard]].'' Tim's answer formed the basis for what became known as the Chess Engine Communication Protocol or Winboard engines, originally a subset of the [[GNU Chess]] command line interface.<ref>{{Cite web|url=http://tim-mann.org/history.html|title=XBoard Project History|website=Tim-mann.org|access-date=2018-11-29|archive-date=2018-11-30|archive-url=https://web.archive.org/web/20181130071440/http://tim-mann.org/history.html|url-status=live}}</ref>


Also in 1994, Stephen J. Edwards released the [[Portable Game Notation]] (PGN) specification. It mentions PGN reading programs not needing to have a "full chess engine." It also mentions three "graphical user interfaces" (GUI): [[XBoard]], pgnRead and Slappy the database.<ref>http://www.thechessdrum.net/PGN_Reference.txt {{Bare URL plain text|date=March 2022}}</ref>
Also in 1994, Stephen J. Edwards released the [[Portable Game Notation]] (PGN) specification. It mentions PGN reading programs not needing to have a "full chess engine." It also mentions three "graphical user interfaces" (GUI): [[XBoard]], pgnRead and Slappy the database.<ref>{{cite web|url=http://www.thechessdrum.net/PGN_Reference.txt|format=TXT|title=Standard: Portable Game Notation Specification and Implementation Guide|website=Thechessdrum.net|access-date=2022-06-26|archive-date=2007-08-22|archive-url=https://web.archive.org/web/20070822185456/http://www.thechessdrum.net/PGN_Reference.txt|url-status=live}}</ref>


By the mid-2000s, engines had become so strong that they were able to beat even the best human players. In 2005, [[Michael Adams (chess player)|Michael Adams]], a world top 10 player at the time, was comprehensively beaten 5½ - ½ by [[Hydra (chess)|Hydra]], drawing only one of the six games.<ref>{{cite web|url=http://www.chessbase.com/newsdetail.asp?newsid=2476 |title=Adams 0.5 – Hydra 5.5 |date=28 June 2005 |publisher=Chessbase.com |access-date=2011-12-17}}</ref> Matches between humans and engines are now rare; engines are increasingly regarded as tools for analysis rather than as opponents.
By the mid-2000s, engines had become so strong that they were able to beat even the best human players. Except for entertainment purposes, especially using engines with limited strength, matches between humans and engines are now rare; engines are increasingly regarded as tools for analysis rather than as opponents.


==Interface protocol==
==Interface protocol==
Common Winboard engines would include ''[[Crafty]],'' ''ProDeo'' (based on ''[[REBEL (chess)|Rebel]]''), ''Chenard,'' ''[[Zarkov]]'' and ''Phalanx.''
Common Winboard engines would include ''[[Crafty]],'' ''ProDeo'' (based on ''[[REBEL (chess)|Rebel]]''), ''Chenard,'' ''[[Zarkov]]'' and ''Phalanx.''


In 1995, [[Chessbase]] released a version of their database program including [[Fritz (chess)|Fritz]]&nbsp;4 as a separate engine. This was the first appearance of the Chessbase protocol. Soon after, they added the engines [[Junior (chess)|Junior]] and [[Shredder (chess)|Shredder]] to their product line up, including engines in CB protocol as separate programs which could be installed in the [[Chessbase]] program or one of the other Fritz style GUI's. Fritz 1-14 were only issued as Chessbase engines, while ''[[Hiarcs]],'' ''Nimzo,'' ''[[Chess Tiger]]'' and ''[[Crafty]]'' have been ported to Chessbase format even though they were UCI or Winboard engines. Recently, Chessbase has begun to include [[Universal Chess Interface]] (UCI) engines in their playing programs such as ''[[Komodo (chess)|Komodo]],'' ''[[Houdini (chess)|Houdini]],'' ''[[Fritz (chess)|Fritz]] 15–16'' and ''[[Rybka]]'' rather than convert them to Chessbase engines.
In 1995, [[Chessbase]] released a version of their database program including [[Fritz (chess)|Fritz]]&nbsp;4 as a separate engine. This was the first appearance of the Chessbase protocol. Soon after, they added the engines [[Junior (chess program)|Junior]] and [[Shredder (chess)|Shredder]] to their product line up, including engines in CB protocol as separate programs which could be installed in the [[Chessbase]] program or one of the other Fritz style GUI's. Fritz 1-14 were only issued as Chessbase engines, while ''[[Hiarcs]],'' ''Nimzo,'' ''[[Chess Tiger]]'' and ''[[Crafty]]'' have been ported to Chessbase format even though they were UCI or Winboard engines. Recently, Chessbase has begun to include [[Universal Chess Interface]] (UCI) engines in their playing programs such as ''[[Komodo (chess)|Komodo]],'' ''[[Houdini (chess)|Houdini]],'' ''[[Fritz (chess)|Fritz]] 15–16'' and ''[[Rybka]]'' rather than convert them to Chessbase engines.


In 2000, [[Stefan Meyer-Kahlen]] and Franz Huber released the [[Universal Chess Interface]], a more detailed protocol that introduced a wider set of features. [[Chessbase]] soon after dropped support for Winboard engines, and added support for UCI to their engine GUI's and [[Chessbase]] programs. Most of the top engines are UCI these days: ''[[Stockfish (chess)|Stockfish]],'' ''[[Komodo (chess)|Komodo]],'' ''[[Leela Chess Zero]],'' ''[[Houdini (chess)|Houdini]],'' ''[[Fritz (chess)|Fritz]] 15-16,'' ''[[Rybka]],'' ''[[Shredder (software)|Shredder]],'' ''[[Fruit (software)|Fruit]],'' ''[[Critter (chess)|Critter]],'' ''[[IPPOLIT|Ivanhoe]]'' and ''Ruffian.''
In 2000, [[Stefan Meyer-Kahlen]] and Franz Huber released the [[Universal Chess Interface]], a more detailed protocol that introduced a wider set of features. [[Chessbase]] soon after dropped support for Winboard engines, and added support for UCI to their engine GUI's and [[Chessbase]] programs. Most of the top engines are UCI these days: ''[[Stockfish (chess)|Stockfish]],'' ''[[Komodo (chess)|Komodo]],'' ''[[Leela Chess Zero]],'' ''[[Houdini (chess)|Houdini]],'' ''[[Fritz (chess)|Fritz]] 15-16,'' ''[[Rybka]],'' ''[[Shredder (software)|Shredder]],'' ''[[Fruit (software)|Fruit]],'' ''[[Critter (chess)|Critter]],'' ''[[IPPOLIT|Ivanhoe]]'' and ''Ruffian.''


From 1998, the German company Millenium 2000 briefly moved from dedicated chess computers into the software market, developing the Millennium Chess System (MCS) protocol for a series of CD's containing ''[[ChessGenius]]'' or ''[[Shredder (software)|Shredder]],'' but after 2001 ceased releasing new software.<ref>''Computer-schach & Spiele.''</ref> A more longstanding engine protocol has been used by the Dutch company, Lokasoft,<ref>{{Cite web|url=https://www.lokasoft.nl/|title=Home - Lokasoft - Home of ChessPartner|website=Lokasoft.nl|access-date=26 June 2022}}</ref> which eventually took over the marketing of Ed Schröder's ''[[REBEL (chess)|Rebel]].''
From 1998, the German company Millenium 2000 briefly moved from dedicated chess computers into the software market, developing the Millennium Chess System (MCS) protocol for a series of CD's containing ''[[ChessGenius]]'' or ''[[Shredder (software)|Shredder]],'' but after 2001 ceased releasing new software.<ref>''Computer-schach & Spiele.''</ref> A more longstanding engine protocol has been used by the Dutch company, Lokasoft,<ref>{{Cite web|url=https://www.lokasoft.nl/|title=Home - Lokasoft - Home of ChessPartner|website=Lokasoft.nl|access-date=26 June 2022|archive-date=26 June 2022|archive-url=https://web.archive.org/web/20220626081524/https://www.lokasoft.nl/|url-status=live}}</ref> which eventually took over the marketing of Ed Schröder's ''[[REBEL (chess)|Rebel]].''


==Increasing strength==
==Increasing strength==
Chess engines increase in playing strength continually. This is partly due to the increase in processing power that enables calculations to be made to ever greater depths in a given time. In addition, programming techniques have improved, enabling the engines to be more selective in the lines that they analyze and to acquire a better positional understanding. A chess engine often uses a vast previously computed opening "book" to increase its playing strength for the first several moves, up to possibly 20 moves or more in deeply analyzed lines.{{citation needed|date=June 2017}}
Chess engines increase in playing strength continually. This is partly due to the increase in processing power that enables calculations to be made to ever greater depths in a given time. In addition, programming techniques have improved, enabling the engines to be more selective in the lines that they analyze and to acquire a better positional understanding. A chess engine often uses a vast previously-computed opening "book" to increase its playing strength for the first several moves, up to possibly 20 moves or more in deeply analyzed lines.{{citation needed|date=June 2017}}
[[File:Chess ability of the best computers.png|right|upright=1.5|frameless]]
Some chess engines maintain a database of chess positions, along with previously-computed evaluations and best moves—in effect, a kind of "dictionary" of recurring chess positions. Since these positions are pre-computed, the engine merely plays one of the indicated moves in the database, thereby saving computing time, resulting in stronger, faster play.


Some chess engines use [[endgame tablebase]]s to increase their playing strength during the [[chess endgame|endgame]]. An endgame tablebase includes all possible endgame positions with a small amount of material. Each position is conclusively determined as a win, loss, or draw for the player whose turn it is to move, and the number of moves to the end with best play by both sides. The tablebase identifies for every position the move which will win the fastest against an optimal defense, or the move that will lose the slowest against an optimal offense. Such tablebases are available for all chess endgames with seven pieces or fewer (trivial endgame positions are excluded, such as six white pieces versus a lone black [[king (chess)|king]]).<ref>[http://tb7.chessok.com/shared-positions http://tb7.chessok.com] {{Webarchive|url=https://web.archive.org/web/20201201214914/http://tb7.chessok.com/shared-positions |date=2020-12-01 }} Lomonosov website allowing registered user to access 7-piece tablebase, and a forum with positions found.</ref><ref>[https://www.chess.com/forum/view/endgames/who-wins-from-this-puzzle "Who wins from this? (chess puzzle)"] {{Webarchive|url=https://web.archive.org/web/20201111220720/https://www.chess.com/forum/view/endgames/who-wins-from-this-puzzle |date=2020-11-11 }} An example chess position found from the Lomonosov chess tablebase.</ref>
Some chess engines maintain a database of chess positions, along with previously computed evaluations and best moves, in effect, a kind of "dictionary" of recurring chess positions. Since these positions are pre-computed, the engine merely plays one of the indicated moves in the database, thereby saving computing time, resulting in stronger, faster play.

Some chess engines use [[endgame tablebase]]s to increase their playing strength during the [[chess endgame|endgame]]. An endgame tablebase includes all possible endgame positions with a small amount of material. Each position is conclusively determined as a win, loss, or draw for the player whose turn it is to move, and the number of moves to the end with best play by both sides. The tablebase identifies for every position the move which will win the fastest against an optimal defense, or the move that will lose the slowest against an optimal offense. Such tablebases are available for all chess endgames with seven pieces or fewer (trivial endgame positions are excluded, such as six white pieces versus a lone black [[king (chess)|king]]).<ref>[http://tb7.chessok.com/shared-positions http://tb7.chessok.com] Lomonosov website allowing registered user to access 7-piece tablebase, and a forum with positions found.</ref><ref>[https://www.chess.com/forum/view/endgames/who-wins-from-this-puzzle "Who wins from this? (chess puzzle)"] An example chess position found from the Lomonosov chess tablebase.</ref>


When the maneuvering in an ending to achieve an irreversible improvement takes more moves than the horizon of calculation of a chess engine, an engine is not guaranteed to find the best move without the use of an endgame tablebase, and in many cases can fall foul of the [[fifty-move rule]] as a result. Many engines use [[permanent brain]] (continuing to calculate during the opponent's turn) as a method to increase their strength.
When the maneuvering in an ending to achieve an irreversible improvement takes more moves than the horizon of calculation of a chess engine, an engine is not guaranteed to find the best move without the use of an endgame tablebase, and in many cases can fall foul of the [[fifty-move rule]] as a result. Many engines use [[permanent brain]] (continuing to calculate during the opponent's turn) as a method to increase their strength.


[[Distributed computing]] is also used to improve the software code of chess engines. In 2013, the developers of the [[Stockfish (chess)|Stockfish]] chess playing program started using distributed computing to make improvements in the software code.<ref>{{cite web|url=http://tests.stockfishchess.org/tests|title=Stockfish Testing Framework|website=Tests.stockfishchess.org|access-date=7 March 2014}}</ref><ref>{{cite web|url=http://stockfishchess.org/get-involved/|title=Get Involved|website=Stockfishchess.org|access-date=8 March 2014}}</ref><ref>{{cite web | url=http://www.talkchess.com/forum/viewtopic.php?start=0&t=47885&topic_view=flat&sid=b5662f579ad4c7bea91668bb9d9723a4 | title=Fishtest Distributed Testing Framework | date=1 May 2013 | last=Costalba | first=Marco | website=Talkchess.com | access-date=18 April 2014}}</ref> {{As of|2017|6}}, a total of more than 745 years of CPU time has been used to play more than 485 million chess games, with the results being used to make small and incremental improvements to the chess-playing software.<ref>{{cite web | url=http://tests.stockfishchess.org/users | title=Stockfish Testing Framework - Users | website=Test.stockfishchess.org | access-date=17 June 2017}}</ref> In 2019, Ethereal author Andrew Grant started the distributed computing testing framework OpenBench, based upon Stockfish's testing framework,<ref>{{cite web|url=https://github.com/andygrant/openbench|title=Github - AndyGrant/OpenBench: OpenBench is a Distributed SPRT Testing Framework for Chess Engines|website=Github.com|access-date=23 December 2021}}</ref><ref>{{Cite web|title=OpenBench|url=http://chess.grantnet.us/|access-date=2022-02-16|website=Chess.grantnet.us}}</ref> and it is now the most widely-used testing framework for chess engines.{{Citation needed|date=February 2022}}
[[Distributed computing]] is also used to improve the software code of chess engines. In 2013, the developers of the [[Stockfish (chess)|Stockfish]] chess playing program started using distributed computing to make improvements in the software code.<ref>{{cite web|url=http://tests.stockfishchess.org/tests|title=Stockfish Testing Framework|website=Tests.stockfishchess.org|access-date=7 March 2014|archive-date=22 March 2014|archive-url=https://web.archive.org/web/20140322122039/http://tests.stockfishchess.org/tests|url-status=live}}</ref><ref>{{cite web|url=http://stockfishchess.org/get-involved/|title=Get Involved|website=Stockfishchess.org|access-date=8 March 2014|archive-date=16 June 2013|archive-url=https://web.archive.org/web/20130616211650/http://stockfishchess.org/get-involved/|url-status=live}}</ref><ref>{{cite web | url=http://www.talkchess.com/forum/viewtopic.php?start=0&t=47885&topic_view=flat&sid=b5662f579ad4c7bea91668bb9d9723a4 | title=Fishtest Distributed Testing Framework | date=1 May 2013 | last=Costalba | first=Marco | website=Talkchess.com | access-date=18 April 2014 | archive-date=19 April 2014 | archive-url=https://web.archive.org/web/20140419012854/http://www.talkchess.com/forum/viewtopic.php?start=0&t=47885&topic_view=flat&sid=b5662f579ad4c7bea91668bb9d9723a4 | url-status=live }}</ref> {{As of|2017|6}}, a total of more than 745 years of CPU time has been used to play more than 485 million chess games, with the results being used to make small and incremental improvements to the chess-playing software.<ref>{{cite web | url=http://tests.stockfishchess.org/users | title=Stockfish Testing Framework - Users | website=Test.stockfishchess.org | access-date=17 June 2017 | archive-date=25 June 2018 | archive-url=https://web.archive.org/web/20180625233351/http://tests.stockfishchess.org/users | url-status=dead }}</ref> In 2019, Ethereal author Andrew Grant started the distributed computing testing framework OpenBench, based upon Stockfish's testing framework,<ref>{{cite web|url=https://github.com/andygrant/openbench|title=Github - AndyGrant/OpenBench: OpenBench is a Distributed SPRT Testing Framework for Chess Engines|website=Github.com|access-date=23 December 2021|archive-date=23 December 2021|archive-url=https://web.archive.org/web/20211223142116/https://github.com/andygrant/openbench|url-status=live}}</ref><ref>{{Cite web|title=OpenBench|url=http://chess.grantnet.us/|access-date=2022-02-16|website=Chess.grantnet.us|archive-date=2022-02-16|archive-url=https://web.archive.org/web/20220216060628/http://chess.grantnet.us/|url-status=live}}</ref> and it is now the most widely-used testing framework for chess engines.{{Citation needed|date=February 2022}}


==Limiting an engine's strength==
==Limiting an engine's strength==
By the late 1990s, the top engines had become so strong that few players stood a chance of winning a game against them. To give players more of a chance, engines began to include settings to adjust or limit their strength. In 2000, when [[Stefan Meyer-Kahlen]] and Franz Huber released the [[Universal Chess Interface]] protocol they included the parameters uci_limitstrength and uci_elo allowing engine authors to offer a variety of levels rated in accordance with [[Elo rating]], as calibrated by one of the rating lists. Most GUIs for UCI engines allow users to set this Elo rating within the menus. Even engines that have not adopted this parameter will sometimes have an adjustable strength parameter (e.g. Stockfish 11). Engines which have a uci_elo parameter include [[Houdini (chess)|Houdini]], [[Fritz (chess)|Fritz]] 15–16, [[Rybka]], [[Shredder (software)|Shredder]], [[Hiarcs]], [[Junior (chess)|Junior]], [[Zappa (chess)|Zappa]] and [[Sjeng (software)|Sjeng]]. GUI's such as [[Shredder (software)|Shredder]], [[Chess Assistant]], Convekta Aquarium,<ref>{{Cite web|url=https://shop.chessok.com/|title=ChessOK Shop, Software, Training, Equipment, Books|website=Shop.chessok.com|access-date=26 June 2022}}</ref> [[Hiarcs]] Chess Explorer or Martin Blume's Arena<ref name="auto">{{Cite web |url=http://www.playwitharena.com/ |title=Archived copy |access-date=2018-11-29 |archive-url=https://web.archive.org/web/20070314030733/http://www.playwitharena.com/ |archive-date=2007-03-14 |url-status=dead }}</ref> have dropdown menus for setting the engine's uci_elo parameter. The Fritz family GUI's, [[Chess Assistant]] and Aquarium also have independent means of limiting an engine's strength apparently based on an engine's ability to generate ranked lists of moves (called multipv for 'principle variation').
By the late 1990s, the top engines had become so strong that few players stood a chance of winning a game against them. To give players more of a chance, engines began to include settings to adjust or limit their strength. In 2000, when [[Stefan Meyer-Kahlen]] and Franz Huber released the [[Universal Chess Interface]] protocol they included the parameters uci_limitstrength and uci_elo allowing engine authors to offer a variety of levels rated in accordance with [[Elo rating]], as calibrated by one of the rating lists. Most GUIs for UCI engines allow users to set this Elo rating within the menus. Even engines that have not adopted this parameter will sometimes have an adjustable strength parameter (e.g. Stockfish 11). Engines which have a uci_elo parameter include [[Houdini (chess)|Houdini]], [[Fritz (chess)|Fritz]] 15–16, [[Rybka]], [[Shredder (software)|Shredder]], [[Hiarcs]], [[Junior (chess program)|Junior]], [[Zappa (chess)|Zappa]], and [[Sjeng (software)|Sjeng]]. GUIs such as [[Shredder (software)|Shredder]], [[Chess Assistant]], Convekta Aquarium,<ref>{{Cite web|url=https://shop.chessok.com/|title=ChessOK Shop, Software, Training, Equipment, Books|website=Shop.chessok.com|access-date=26 June 2022|archive-date=26 June 2022|archive-url=https://web.archive.org/web/20220626043458/https://shop.chessok.com/|url-status=live}}</ref> [[Hiarcs]] Chess Explorer, and Martin Blume's Arena<ref name="auto">{{Cite web |url=http://www.playwitharena.com/ |title=Free chess graphical user interface (GUI) Arena for chess engines |access-date=2018-11-29 |archive-url=https://web.archive.org/web/20070314030733/http://www.playwitharena.com/ |archive-date=2007-03-14 |url-status=dead }}</ref> have dropdown menus for setting the engine's uci_elo parameter. The Fritz family GUIs, [[Chess Assistant]], and Aquarium also have independent means of limiting an engine's strength apparently based on an engine's ability to generate ranked lists of moves (called multipv for 'principle variation').


==Comparisons==
==Comparisons==
===Tournaments===
===Tournaments===
The results of computer tournaments give one view of the relative strengths of chess engines. However, tournaments do not play a statistically significant number of games for accurate strength determination. In fact, the number of games that need to be played between fairly evenly matched engines, in order to achieve significance, runs into the thousands and is, therefore, impractical within the framework of a tournament.<ref>{{cite web|url=http://www.mizarchessengine.com/columns/testing-a-chess-engine/|title=mizarchessengine.com<!-- Bot generated title -->|access-date=25 September 2016}}</ref> Most tournaments also allow any types of hardware, so only engine/hardware combinations are being compared.
The results of computer tournaments give one view of the relative strengths of chess engines. However, tournaments do not play a statistically significant number of games for accurate strength determination. In fact, the number of games that need to be played between fairly evenly matched engines, in order to achieve significance, runs into the thousands and is, therefore, impractical within the framework of a tournament.<ref>{{cite web|url=http://www.mizarchessengine.com/columns/testing-a-chess-engine/|title=mizarchessengine.com<!-- Bot generated title -->|access-date=25 September 2016|archive-date=29 January 2013|archive-url=https://archive.today/20130129173958/http://www.mizarchessengine.com/columns/testing-a-chess-engine/|url-status=live}}</ref> Most tournaments also allow any types of hardware, so only engine/hardware combinations are being compared.


Historically, commercial programs have been the strongest engines. If an amateur engine wins a tournament or otherwise performs well (for example, [[Zappa (chess)|Zappa]] in 2005), then it is quickly commercialized. Titles gained in these tournaments garner much prestige for the winning programs, and are thus used for marketing purposes. However, after the rise of [[Volunteer computing|volunteer]] [[distributed computing]] projects such as [[Leela Chess Zero]] and [[Stockfish (chess)|Stockfish]] and testing frameworks such as FishTest and OpenBench in the late 2010s, [[free and open source]] programs have largely displaced commercial programs as the strongest engines in tournaments.
Historically, commercial programs have been the strongest engines. If an amateur engine wins a tournament or otherwise performs well (for example, [[Zappa (chess)|Zappa]] in 2005), then it is quickly commercialized. Titles gained in these tournaments garner much prestige for the winning programs, and are thus used for marketing purposes. However, after the rise of [[Volunteer computing|volunteer]] [[distributed computing]] projects such as [[Leela Chess Zero]] and [[Stockfish (chess)|Stockfish]] and testing frameworks such as FishTest and OpenBench in the late 2010s, [[free and open source]] programs have largely displaced commercial programs as the strongest engines in tournaments.
Line 50: Line 49:
Current tournaments include:
Current tournaments include:
* [[Top Chess Engine Championship]] (TCEC)
* [[Top Chess Engine Championship]] (TCEC)
* [[World Computer Chess Championship]] (WCCC)
* [[World Computer Chess Championship]] (WCCC and WCSC)
** [[World Computer Speed Chess Championship]]
** [[World Computer Speed Chess Championship]]
* [[Chess.com Computer Chess Championship]] (CCC)
* [[Chess.com#Chess.com Computer Chess Championship|Chess.com Computer Chess Championship]] (CCC)


Historic tournaments include:
Historic tournaments include:
* [[Dutch Open Computer Chess Championship]]
* [[Dutch Open Computer Chess Championship]]
* [[Internet Computer Chess Tournament]] (CCT)
* [[Internet Chess Club#Internet Computer Chess Tournament|Internet Computer Chess Tournament]] (CCT)
* [[International Paderborn Computer Chess Championship]]
* [[International Paderborn Computer Chess Championship]]
* [[North American Computer Chess Championship]]
* [[North American Computer Chess Championship]]
Line 65: Line 64:
The ratings on the rating lists, although calculated by using the [[Elo rating system|Elo system]] (or similar rating methods), have no direct relation to FIDE Elo ratings or to other chess federation ratings of human players. Except for some man versus machine games which the SSDF had organized many years ago (when engines were far from today's strength), there is ''no calibration'' between any of these rating lists and player pools. Hence, the results which matter are the ''ranks'' and the ''differences'' between the ratings, and not the absolute values.
The ratings on the rating lists, although calculated by using the [[Elo rating system|Elo system]] (or similar rating methods), have no direct relation to FIDE Elo ratings or to other chess federation ratings of human players. Except for some man versus machine games which the SSDF had organized many years ago (when engines were far from today's strength), there is ''no calibration'' between any of these rating lists and player pools. Hence, the results which matter are the ''ranks'' and the ''differences'' between the ratings, and not the absolute values.


Missing from many rating lists are [[IPPOLIT]] and its derivatives. Although very strong and [[open source]], there are allegations from commercial software interests that they were derived from a disassembled binary of [[Rybka]].<ref>{{Cite web |url=http://www.chessvibes.com/reports/chess-engine-controversy/ |title=Chess engine controversy at chessvibes.com, retrieved 28/May/2010 |access-date=2010-05-28 |archive-url=https://web.archive.org/web/20100528153718/http://www.chessvibes.com/reports/chess-engine-controversy/ |archive-date=2010-05-28 |url-status=dead }}</ref> Due to the [[Rybka#IPPOLIT controversy|controversy]], all these engines have been blacklisted from many tournaments and rating lists. Rybka in turn was accused of being based on [[Fruit (chess)|Fruit]],<ref>{{Cite web |url=https://webspace.utexas.edu/zzw57/rtc/eval/eval.html |title=Evaluation<!-- Bot generated title --> |access-date=2010-12-18 |archive-url=https://web.archive.org/web/20110811141639/https://webspace.utexas.edu/zzw57/rtc/eval/eval.html |archive-date=2011-08-11 |url-status=dead }}</ref> and in June 2011, the ICGA formally claimed Rybka was derived from Fruit and Crafty and banned Rybka from the International Computer Games Association World Computer Chess Championship, and revoked its previous victories (2007, 2008, 2009, and 2010).<ref>{{Cite web |url=http://www.chessvibes.com/reports/rybka-disqualified-and-banned-from-world-computer-chess-championships/ |title=Rybka disqualified and banned from World Computer Chess Championships {{!}} ChessVibes<!-- Bot generated title --> |access-date=2011-06-30 |archive-url=https://web.archive.org/web/20120302233915/http://www.chessvibes.com/reports/rybka-disqualified-and-banned-from-world-computer-chess-championships/ |archive-date=2012-03-02 |url-status=dead }}</ref> The ICGA received some criticism for this decision.<ref name=AGMoJiCCpo>{{cite news|last=Riis|first=Dr. Søren|title=A Gross Miscarriage of Justice in Computer Chess (part one)|url=http://www.chessbase.com/newsdetail.asp?newsid=7791|access-date=19 February 2012|newspaper=Chessbase News|date=January 2, 2012}}</ref> Despite all this, Rybka is still included on many rating lists, such as CCRL and CEGT, in addition to [[Houdini]], a derivative of the IPPOLIT derivative Robbolito,<ref name="chess vibes">{{cite web|title=Free Houdini beats commercial Rybka 23.5-16.5|url=http://www.chessvibes.com/reports/free-houdini-beats-commercial-rybka-23-5-16-5/|archive-url=https://web.archive.org/web/20140410195128/http://www.chessvibes.com/reports/free-houdini-beats-commercial-rybka-23-5-16-5/|archive-date=10 April 2014|publisher=Chessvibes|access-date=25 October 2013|date=10 February 2010}}</ref> and Fire, a derivative of Houdini. In addition, [[ChessBase#Criticism and legal issues|Fat Fritz 2]], a derivative of Stockfish,<ref>{{Cite web|last=The Stockfish Team|date=2021-07-21|title=Our lawsuit against ChessBase|url=https://stockfishchess.org/blog/2021/our-lawsuit-against-chessbase/|url-status=live|archive-url=https://web.archive.org/web/20210721190547/https://stockfishchess.org/blog/2021/our-lawsuit-against-chessbase/|archive-date=2021-07-21|access-date=2021-08-18|website=Stockfishchess.org}}</ref> is also included on most of the rating lists.
Missing from many rating lists are [[IPPOLIT]] and its derivatives. Although very strong and [[open source]], there are allegations from commercial software interests that they were derived from a disassembled binary of [[Rybka]].<ref>{{Cite web |url=http://www.chessvibes.com/reports/chess-engine-controversy/ |title=Chess engine controversy at chessvibes.com, retrieved 28/May/2010 |access-date=2010-05-28 |archive-url=https://web.archive.org/web/20100528153718/http://www.chessvibes.com/reports/chess-engine-controversy/ |archive-date=2010-05-28 |url-status=dead }}</ref> Due to the [[Rybka#IPPOLIT controversy|controversy]], all these engines have been blacklisted from many tournaments and rating lists. Rybka in turn was accused of being based on [[Fruit (chess)|Fruit]],<ref>{{Cite web |url=https://webspace.utexas.edu/zzw57/rtc/eval/eval.html |title=Evaluation<!-- Bot generated title --> |access-date=2010-12-18 |archive-url=https://web.archive.org/web/20110811141639/https://webspace.utexas.edu/zzw57/rtc/eval/eval.html |archive-date=2011-08-11 |url-status=dead }}</ref> and in June 2011, the ICGA formally claimed Rybka was derived from Fruit and Crafty and banned Rybka from the International Computer Games Association World Computer Chess Championship, and revoked its previous victories (2007, 2008, 2009, and 2010).<ref>{{Cite web |url=http://www.chessvibes.com/reports/rybka-disqualified-and-banned-from-world-computer-chess-championships/ |title=Rybka disqualified and banned from World Computer Chess Championships {{!}} ChessVibes<!-- Bot generated title --> |access-date=2011-06-30 |archive-url=https://web.archive.org/web/20120302233915/http://www.chessvibes.com/reports/rybka-disqualified-and-banned-from-world-computer-chess-championships/ |archive-date=2012-03-02 |url-status=dead }}</ref> The ICGA received some criticism for this decision.<ref name=AGMoJiCCpo>{{cite news|last=Riis|first=Dr. Søren|title=A Gross Miscarriage of Justice in Computer Chess (part one)|url=http://www.chessbase.com/newsdetail.asp?newsid=7791|access-date=19 February 2012|newspaper=Chessbase News|date=January 2, 2012|archive-date=7 January 2012|archive-url=https://web.archive.org/web/20120107191340/http://www.chessbase.com/newsdetail.asp?newsid=7791|url-status=live}}</ref> Despite all this, Rybka is still included on many rating lists, such as CCRL and CEGT, in addition to [[Houdini]], a derivative of the IPPOLIT derivative Robbolito,<ref name="chess vibes">{{cite web|title=Free Houdini beats commercial Rybka 23.5-16.5|url=http://www.chessvibes.com/reports/free-houdini-beats-commercial-rybka-23-5-16-5/|archive-url=https://web.archive.org/web/20140410195128/http://www.chessvibes.com/reports/free-houdini-beats-commercial-rybka-23-5-16-5/|archive-date=10 April 2014|publisher=Chessvibes|access-date=25 October 2013|date=10 February 2010}}</ref> and Fire, a derivative of Houdini. In addition, [[ChessBase#Criticism and legal issues|Fat Fritz 2]], a derivative of Stockfish,<ref>{{Cite web|last=The Stockfish Team|date=2021-07-21|title=Our lawsuit against ChessBase|url=https://stockfishchess.org/blog/2021/our-lawsuit-against-chessbase/|url-status=live|archive-url=https://web.archive.org/web/20210721190547/https://stockfishchess.org/blog/2021/our-lawsuit-against-chessbase/|archive-date=2021-07-21|access-date=2021-08-18|website=Stockfishchess.org}}</ref> is also included on most of the rating lists.


====Differences between rating lists====
====Differences between rating lists====
Line 74: Line 73:
** Longer time controls are better suited for determining tournament play strength, but also either make testing more time-consuming or the results less statistically significant.
** Longer time controls are better suited for determining tournament play strength, but also either make testing more time-consuming or the results less statistically significant.
** Increment time controls are better suited for determining tournament play strength since tournaments usually use increment time controls, but many rating lists use cyclic/repeating time controls instead.
** Increment time controls are better suited for determining tournament play strength since tournaments usually use increment time controls, but many rating lists use cyclic/repeating time controls instead.
** Consistent time controls throughout the rating list vs different time controls for each test. The latter results in a smaller [[statistical significance]] than the former because different time controls is a potential [[confounder]]. This is particularly problematic for CCRL because CCRL switched from cyclic/repeating time controls (40/2) to increment time controls (2"+1') in its CCRL Blitz list yet maintains both time controls on the same list.<ref>{{Cite web|url=https://ccrl.chessdom.com/ccrl/404/about.html|title=CCRL Blitz - About|website=Ccrl.chessdom.com|access-date=26 June 2022}}</ref>
** Consistent time controls throughout the rating list vs different time controls for each test. The latter results in a smaller [[statistical significance]] than the former because different time controls is a potential [[confounder]]. This is particularly problematic for CCRL because CCRL uses both cyclic/repeating time controls (40/15) and increment time controls (15"+10') in its CCRL 40/15 list yet maintains both time controls on the same list.<ref>{{Cite web|url=https://talkchess.com/forum3/viewtopic.php?f=6&t=82754|title=CCRL 40/15, 2m1s and FRC 40/2 lists updated (21-10-2023)|website=talkchess.com|access-date=22 October 2023|archive-date=15 June 2024|archive-url=https://web.archive.org/web/20240615081446/https://talkchess.com/forum3/viewtopic.php?f=6&t=82754|url-status=live}}</ref>
* Opponents used in testing engines. Some rating lists only test an engine against the most recent version of each opponent engine, while other rating lists test an engine against the version(s) of each opponent engine closest in elo to the engine being tested.
* Opponents used in testing engines.
** Some rating lists only test an engine against the most recent version of each opponent engine, while other rating lists test an engine against the version(s) of each opponent engine closest in elo to the engine being tested.
** Most rating lists do not test every engine on the rating list vs every other engine on the rating list in a [[round-robin tournament]] format. This causes distortions in the rating lists, especially for CCRL and CEGT.<ref>{{Cite web|url=https://talkchess.com/viewtopic.php?t=83829|title=Experimental testruns of Stockfish / Torch|website=talkchess.com|access-date=29 May 2024|archive-date=15 June 2024|archive-url=https://web.archive.org/web/20240615081446/https://talkchess.com/viewtopic.php?t=83829|url-status=live}}</ref>
* Hardware used:
* Hardware used:
** Faster hardware with more memory leads to stronger play.
** Faster hardware with more memory leads to stronger play.
** 64-bit (vs. 32-bit) hardware and operating systems favor [[bitboard]]-based programs
** 64-bit (vs. 32-bit) hardware and operating systems favor [[bitboard]]-based programs
** Hardware using modern instruction sets such as [[AVX2]] or [[AVX512]] favor engines using vectors and vector intrinsics in their code, common in [[neural networks]].
** Hardware using modern instruction sets such as [[AVX2]] or [[AVX512]] favor engines using vectors and vector intrinsics in their code, common in [[Artificial neural network|neural networks]].
** [[Graphics processing units]] favor programs with [[deep neural networks]].
** [[Graphics processing units]] favor programs with [[deep neural networks]].
** Multiprocessor vs. single processor hardware.
** Multiprocessor vs. single processor hardware.
** Consistent hardware throughout the rating list vs different hardware for every test. The latter results in a smaller [[statistical significance]] than the former because different hardware is a potential [[confounder]]. This is particularly problematic for [[CEGT]] because multiple testers each with their own unique hardware are involved in testing each engine in CEGT.<ref>{{Cite web|url=http://www.cegt.net/testers/testers.html|title=CEGT Testers|website=Cegt.net|access-date=26 June 2022}}</ref>
** Consistent hardware throughout the rating list vs different hardware for every test. The latter results in a smaller [[statistical significance]] than the former because different hardware is a potential [[confounder]]. This is particularly problematic for [[CEGT]] because multiple testers each with their own unique hardware are involved in testing each engine in CEGT.<ref>{{Cite web|url=http://www.cegt.net/testers/testers.html|title=CEGT Testers|website=Cegt.net|access-date=26 June 2022|archive-date=24 May 2022|archive-url=https://web.archive.org/web/20220524090535/http://www.cegt.net/testers/testers.html|url-status=live}}</ref> The same issue arises in [[CCRL]].<ref "CCRL issues">{{Cite web|url=https://talkchess.com/viewtopic.php?p=962945#p962945|title=ShashChess|author=Ray Banks (Modern Times)|website=talkchess.com|access-date=30 April 2024|archive-date=30 April 2024|archive-url=https://web.archive.org/web/20240430232313/https://talkchess.com/viewtopic.php?p=962945#p962945|url-status=live}}</ref>
* Ponder settings (speculative analysis while the opponent is thinking) aka Permanent Brain.
* Ponder settings (speculative analysis while the opponent is thinking) aka Permanent Brain.
* Transposition table sizes.
* Transposition table sizes.
* Opening book settings.
* GUI settings.
* Opening book settings.


These differences affect the results, and make direct comparisons between rating lists difficult.
These differences affect the results, and make direct comparisons between rating lists difficult.
Line 92: Line 94:
Current rating lists and rating list organizations include:
Current rating lists and rating list organizations include:


* [https://ccrl.chessdom.com/ccrl/ Computer Chess Rating Lists] (CCRL)
* [https://www.computerchess.org.uk/ccrl/ Computer Chess Rating Lists] (CCRL)
** [https://ccrl.chessdom.com/ccrl/404/ CCRL Blitz]
** [https://www.computerchess.org.uk/ccrl/404/ CCRL Blitz 2+1]
** [https://ccrl.chessdom.com/ccrl/4040/ CCRL 40/15]
** [https://www.computerchess.org.uk/ccrl/4040/ CCRL 40/15]
** [https://ccrl.chessdom.com/ccrl/404FRC/ CCRL FRC]
** [https://www.computerchess.org.uk/ccrl/404FRC/ CCRL FRC]
* [[Chess Engines Grand Tournament]] (CEGT)
* [[Chess Engines Grand Tournament]] (CEGT)
** [http://www.cegt.net/blitz.htm CEGT Blitz]
** [http://www.cegt.net/blitz.htm CEGT Blitz]
Line 103: Line 105:
** [http://www.cegt.net/rating5plus3pbon.htm CEGT 5"+3']
** [http://www.cegt.net/rating5plus3pbon.htm CEGT 5"+3']
** [http://www.cegt.net/rating25plus8.htm CEGT 25"+8']
** [http://www.cegt.net/rating25plus8.htm CEGT 25"+8']
* [http://fastgm.de FastGM's Rating List] (FGRL)
** [http://fastgm.de/60-0.60.html FGRL 1"+0.6']
** [http://fastgm.de/10min.html FGRL 10"+6']
** [http://fastgm.de/60min.html FGRL 60"+15']
** [http://fastgm.de/16-60-0.6.html FGRL 16 Cores vs RTX 2070]
* [https://rebel13.nl/misc/gambit-rating-list.html Gambit Rating List] (GRL)
* [https://www.sp-cc.de/ Stefan Pohl Computer Chess] (SPCC)
* [https://www.sp-cc.de/ Stefan Pohl Computer Chess] (SPCC)
* [https://www.chessengeria.com/mcerl-2022-09-25 Mac Chess Engine Rating List] (MCERL)
* [https://rebel7775.wixsite.com/rebel/ Anti Draw Rating List] (ADRL)
** [https://rebel7775.wixsite.com/rebel/adrl-blitz ADRL Blitz]
** [https://rebel7775.wixsite.com/rebel/kopie-van-adrl-blitz ADRL 40/120]
* [http://ipmanchess.yolasite.com/ Ipman Chess]
* [http://ipmanchess.yolasite.com/ Ipman Chess]
** [http://ipmanchess.yolasite.com/i9-7980xe.php Ipman Chess Intel i9 7980XE]
** [http://ipmanchess.yolasite.com/i9-7980xe.php Ipman Chess Intel i9 7980XE]
Line 119: Line 119:


Historic rating lists and rating list organizations include:
Historic rating lists and rating list organizations include:
* [https://ccrl.chessdom.com/ccrl/ Computer Chess Rating Lists] (CCRL)

** [https://ccrl.chessdom.com/ccrl/402.archive/ CCRL 40/2 Archive]
* [http://fastgm.de FastGM's Rating List] (FGRL)
* [http://fastgm.de FastGM's Rating List] (FGRL)
** [http://fastgm.de/240-2.40.html FGRL 4"+2.4']
** [http://fastgm.de/240-2.40.html FGRL 4"+2.4']
Line 126: Line 127:
** [http://ipmanchess.yolasite.com/list-i7-970.php Ipman Chess i7 970]
** [http://ipmanchess.yolasite.com/list-i7-970.php Ipman Chess i7 970]
* [https://web.archive.org/web/20190125041233/http://inwoba.de/bayes.html IPON]
* [https://web.archive.org/web/20190125041233/http://inwoba.de/bayes.html IPON]
* [https://rebel13.nl/misc/gambit-rating-list.html Gambit Rating List] (GRL)
* [http://fastgm.de FastGM's Rating List] (FGRL)
** [http://fastgm.de/60-0.60.html FGRL 1"+0.6']
** [http://fastgm.de/10min.html FGRL 10"+6']
** [http://fastgm.de/60min.html FGRL 60"+15']
** [http://fastgm.de/16-60-0.6.html FGRL 16 Cores vs RTX 2070]


===Test suites===
===Test suites===
Engines can be tested by measuring their performance on specific positions. Typical is the use of test suites where for each given position there is one best move to find. These positions can be geared towards positional, tactical or endgame play. The [[Nolot]] test suite, for instance, focuses on deep sacrifices.<ref>{{Cite web |url=http://sccs.muldermedia.de/index.php?section=suites |title=Nolot test suite |access-date=2007-08-04 |archive-url=https://web.archive.org/web/20070817183737/http://sccs.muldermedia.de/index.php?section=suites |archive-date=2007-08-17 |url-status=dead }}</ref> The BT2450 and BT2630 test suites measure the tactical capability of a chess engine and have been used by [[REBEL (chess)|REBEL]].<ref>{{Cite web |url=http://www.fishdev.net/chess/palmchess/bt2450.html |title=BT2450 test suite |access-date=2007-10-10 |archive-url=https://web.archive.org/web/20070907134734/http://www.fishdev.net/chess/palmchess/bt2450.html |archive-date=2007-09-07 |url-status=dead }}</ref><ref>{{cite web|url=http://www.rebel.nl/rebelfaq/rc3faq03.htm|title=Rebel Century FAQ: 3. Using Rebel|first=Manfred|last=Rosenboom|access-date=25 September 2016}}</ref> There is also a general test suite called Brilliancy which was compiled mostly from ''How to Reassess Your Chess Workbook''.<ref>http://www.talkchess.com/forum/viewtopic.php?t=16989</ref> The Strategic Test Suite (STS) tests an engine's strategical strength.<ref>http://sites.google.com/site/strategictestsuite/</ref> Another modern test suite is Nightmare II which contains 30 chess puzzles.<ref>https://glarean-magazin.ch/2016/08/25/computerschach-stellungstest-nightmare2-test-datenbank-walter-eigenmann/</ref>{{irrelevant citation|date=June 2017|reason=not in English, may not support the statement.}}
Engines can be tested by measuring their performance on specific positions. Typical is the use of test suites where for each given position there is one best move to find. These positions can be geared towards positional, tactical or endgame play. The [[Nolot]] test suite, for instance, focuses on deep sacrifices.<ref>{{Cite web |url=http://sccs.muldermedia.de/index.php?section=suites |title=Nolot test suite |access-date=2007-08-04 |archive-url=https://web.archive.org/web/20070817183737/http://sccs.muldermedia.de/index.php?section=suites |archive-date=2007-08-17 |url-status=dead }}</ref> The BT2450 and BT2630 test suites measure the tactical capability of a chess engine and have been used by [[REBEL (chess)|REBEL]].<ref>{{Cite web |url=http://www.fishdev.net/chess/palmchess/bt2450.html |title=BT2450 test suite |access-date=2007-10-10 |archive-url=https://web.archive.org/web/20070907134734/http://www.fishdev.net/chess/palmchess/bt2450.html |archive-date=2007-09-07 |url-status=dead }}</ref><ref>{{cite web|url=http://www.rebel.nl/rebelfaq/rc3faq03.htm|title=Rebel Century FAQ: 3. Using Rebel|first=Manfred|last=Rosenboom|access-date=25 September 2016|archive-date=3 March 2016|archive-url=https://web.archive.org/web/20160303204822/http://www.rebel.nl/rebelfaq/rc3faq03.htm|url-status=live}}</ref> There is also a general test suite called Brilliancy which was compiled mostly from ''How to Reassess Your Chess Workbook''.<ref>{{Cite web|url=http://www.talkchess.com/forum3/viewtopic.php?t=16989|title=BRILLIANCY TEST SUITE (2 min/move)|website=Talkchess.com|access-date=26 June 2022|archive-date=26 June 2022|archive-url=https://web.archive.org/web/20220626210308/http://www.talkchess.com/forum3/viewtopic.php?t=16989|url-status=live}}</ref> The Strategic Test Suite (STS) tests an engine's strategical strength.<ref>{{Cite web|url=https://sites.google.com/site/strategictestsuite/|title=Strategic Test Suite|website=Sites.google.com|access-date=26 June 2022|archive-date=18 January 2017|archive-url=https://web.archive.org/web/20170118055615/https://sites.google.com/site/strategictestsuite/|url-status=live}}</ref> Another modern test suite is Nightmare II which contains 30 chess puzzles.<ref>{{Cite web|url=https://glarean-magazin.ch/2010/10/10/link-fehler-und-url-umleitungen/|title=Uups - Oops: Link-Fehler und URL-Umleitungen|date=10 October 2010|website=Glarean-magazin.ch|access-date=26 June 2022|archive-date=15 June 2024|archive-url=https://web.archive.org/web/20240615081448/https://glarean-magazin.ch/2010/10/10/link-fehler-und-url-umleitungen/|url-status=live}}</ref>{{irrelevant citation|date=June 2017|reason=not in English, may not support the statement.}}


==Kasparov versus the World (chess game played with computer assistance)==
==Kasparov versus the World (chess game played with computer assistance)==
{{Main|Kasparov versus the World}}
In 1999, [[Garry Kasparov]] played a chess game "[[Kasparov versus the World]]" over the [[Internet]], hosted by the [[MSN Gaming Zone]]. Both sides used computer (chess engine) assistance. The "World Team" included the participation of over 50,000 people from more than 75 countries, deciding their moves by [[plurality vote]]. The game lasted four months, ending after Kasparov's 62nd move when he announced a forced [[checkmate]] in 28 moves found with the computer program [[Deep Junior]]. The World Team voters resigned on October 22. After the game, Kasparov said: "It is the greatest game in the history of chess. The sheer number of ideas, the complexity, and the contribution it has made to chess make it the most important game ever played."<ref>Harding, T. (2002). ''64 Great Chess Games'', Dublin: Chess Mail. {{ISBN|0-9538536-4-0}}.</ref>
In 1999, [[Garry Kasparov]] played a chess game called "Kasparov versus the World" over the [[Internet]], hosted by the [[MSN Gaming Zone]]. Both sides used computer (chess engine) assistance. The "World Team" included the participation of over 50,000 people from more than 75 countries, deciding their moves by [[plurality vote]]. The game lasted four months, ending after Kasparov's 62nd move when he announced a forced [[checkmate]] in 28 moves found with the computer program [[Junior (chess program)|Deep Junior]]. The World Team voters resigned on October 22. After the game, Kasparov said: "It is the greatest game in the history of chess. The sheer number of ideas, the complexity, and the contribution it has made to chess make it the most important game ever played."<ref>Harding, T. (2002). ''64 Great Chess Games'', Dublin: Chess Mail. {{ISBN|0-9538536-4-0}}.</ref>


==Engines for chess variants==
==Engines for chess variants==
Line 141: Line 149:
[[XBoard]]/[[Winboard]] was one of the earliest [[graphical user interface]]s (GUI). Tim Mann created it to provide a GUI for the [[GNU Chess]] engine, but after that, other engines such as [[Crafty]] appeared which used the Winboard protocol. Eventually, the program [[Chessmaster]] included the option to import other Winboard engines in addition to the King engine which was included.
[[XBoard]]/[[Winboard]] was one of the earliest [[graphical user interface]]s (GUI). Tim Mann created it to provide a GUI for the [[GNU Chess]] engine, but after that, other engines such as [[Crafty]] appeared which used the Winboard protocol. Eventually, the program [[Chessmaster]] included the option to import other Winboard engines in addition to the King engine which was included.


In 1995, [[Chessbase]] began offering the [[Fritz (chess)|Fritz]] engine as a separate program within the Chessbase database program and within the Fritz GUI. Soon after, they added the [[Junior (chess)|Junior]] and [[Shredder (chess)|Shredder]] engines to their product line up, packaging them within the same GUI as was used for Fritz. In the late 1990s, the Fritz GUI was able to run Winboard engines via an adapter, but after 2000, Chessbase simply added support for UCI engines, and no longer invested much effort in Winboard.
In 1995, [[Chessbase]] began offering the [[Fritz (chess)|Fritz]] engine as a separate program within the Chessbase database program and within the Fritz GUI. Soon after, they added the [[Junior (chess program)|Junior]] and [[Shredder (chess)|Shredder]] engines to their product line up, packaging them within the same GUI as was used for Fritz. In the late 1990s, the Fritz GUI was able to run Winboard engines via an adapter, but after 2000, Chessbase simply added support for UCI engines, and no longer invested much effort in Winboard.


In 2000, [[Stefan Meyer-Kahlen]] started selling Shredder in a separate [[Universal Chess Interface|UCI]] GUI of his own design, allowing UCI or Winboard engines to be imported into it.
In 2000, [[Stefan Meyer-Kahlen]] started selling Shredder in a separate [[Universal Chess Interface|UCI]] GUI of his own design, allowing UCI or Winboard engines to be imported into it.


Convekta's [[Chess Assistant]] and Lokasoft's ChessPartner also added the ability to import Winboard and UCI engines into their products. Shane Hudson developed [[Shane's Chess Information Database]], a free GUI for Linux, Mac and Windows. Martin Blume developed Arena,<ref name="auto"/> another free GUI for Linux and Windows. Lucas Monge entered the field with the free Lucas Chess GUI.<ref>{{Cite web|url=https://lucaschess.pythonanywhere.com/|title=Lucas Chess|website=Lucaschess.pythonanywhere.com|access-date=26 June 2022}}</ref> All three can handle both UCI and Winboard engines.
Convekta's [[Chess Assistant]] and Lokasoft's ChessPartner also added the ability to import Winboard and UCI engines into their products. Shane Hudson developed [[Shane's Chess Information Database]], a free GUI for Linux, Mac and Windows. Martin Blume developed Arena,<ref name="auto"/> another free GUI for Linux and Windows. Lucas Monge entered the field with the free Lucas Chess GUI.<ref>{{Cite web|url=https://lucaschess.pythonanywhere.com/|title=Lucas Chess|website=Lucaschess.pythonanywhere.com|access-date=26 June 2022|archive-date=6 July 2022|archive-url=https://web.archive.org/web/20220706035308/http://lucaschess.pythonanywhere.com/|url-status=live}}</ref> All three can handle both UCI and Winboard engines.


On Android, Aart Bik came out with Chess for Android,<ref>{{Cite web|url=http://www.aartbik.com/android.php|title = Aart Bik's Website|website=Aartbik.com}}</ref> another free GUI, and Gerhard Kalab's Chess PGN Master<ref>{{Cite web|url=http://pgnmaster.kalab.com/|title=Chess PGN Master|website=Pgnmaster.kalab.com|access-date=26 June 2022}}</ref> and Peter Osterlund's Droidfish<ref>http://hem.bredband.net/petero2b/droidfish/index.html</ref> can also serve as GUIs for engines.
On Android, Aart Bik came out with Chess for Android,<ref>{{Cite web|url=http://www.aartbik.com/android.php|title=Aart Bik's Website|website=Aartbik.com|access-date=2018-11-29|archive-date=2018-11-20|archive-url=https://web.archive.org/web/20181120221148/http://www.aartbik.com/android.php|url-status=live}}</ref> another free GUI, and Gerhard Kalab's Chess PGN Master<ref>{{Cite web|url=http://pgnmaster.kalab.com/|title=Chess PGN Master|website=Pgnmaster.kalab.com|access-date=26 June 2022|archive-date=21 January 2021|archive-url=https://web.archive.org/web/20210121220222/http://pgnmaster.kalab.com/|url-status=live}}</ref> and Peter Osterlund's Droidfish<ref>{{Cite web |url=http://hem.bredband.net/petero2b/droidfish/index.html |title=Archived copy |access-date=2018-11-29 |archive-date=2018-12-10 |archive-url=https://web.archive.org/web/20181210051755/http://hem.bredband.net/petero2b/droidfish/index.html |url-status=dead }}</ref> can also serve as GUIs for engines.


The Computer Chess Wiki lists many chess GUIs.<ref>{{Cite web|url=http://computer-chess.org/doku.php?id=computer_chess:wiki:lists:gui_protocol_support_list|title = Computer_chess:wiki:lists:gui_protocol_support_list - Computer Chess Wiki|website=Computer-chess.org}}</ref>
The Computer Chess Wiki lists many chess GUIs.<ref>{{Cite web|url=http://computer-chess.org/doku.php?id=computer_chess:wiki:lists:gui_protocol_support_list|title=Computer_chess:wiki:lists:gui_protocol_support_list - Computer Chess Wiki|website=Computer-chess.org|access-date=2018-11-29|archive-date=2018-11-30|archive-url=https://web.archive.org/web/20181130071601/http://computer-chess.org/doku.php?id=computer_chess:wiki:lists:gui_protocol_support_list|url-status=live}}</ref>


==See also==
==See also==

Latest revision as of 20:42, 23 September 2024

In computer chess, a chess engine is a computer program that analyzes chess or chess variant positions, and generates a move or list of moves that it regards as strongest.[1]

A chess engine is usually a back end with a command-line interface with no graphics or windowing. Engines are usually used with a front end, a windowed graphical user interface such as Chessbase or WinBoard that the user can interact with via a keyboard, mouse or touchscreen. This allows the user to play against multiple engines without learning a new user interface for each, and allows different engines to play against each other.

Many chess engines are now available for mobile phones and tablets, making them even more accessible.

History

[edit]

The meaning of the term "chess engine" has evolved over time. In 1986, Linda and Tony Scherzer entered their program Bebe into the 4th World Computer Chess Championship, running it on "Chess Engine," their brand name for the chess computer hardware[2] made, and marketed by their company Sys-10, Inc.[3] By 1990 the developers of Deep Blue, Feng-hsiung Hsu and Murray Campbell, were writing of giving their program a 'searching engine,' apparently referring to the software rather than the hardware.[4] In December 1991, Computer-schach & Spiele referred to Chessbase's recently released Fritz as a 'Schach-motor,' the German translation for 'chess engine.'[5] By early 1993, Marty Hirsch was drawing a distinction between commercial chess programs such as Chessmaster 3000 or Battle Chess on the one hand, and 'chess engines' such as ChessGenius or his own MChess Pro on the other. In his characterization, commercial chess programs were low in price, had fancy graphics, but did not place high on the SSDF (Swedish Chess Computer Association) rating lists while engines were more expensive, and did have high ratings.[6]

In 1994, Shay Bushinsky was working on an early version of his Junior program. He wanted to focus on the chess playing part rather than the graphics, and so asked Tim Mann how he could get Junior to communicate with Winboard. Tim's answer formed the basis for what became known as the Chess Engine Communication Protocol or Winboard engines, originally a subset of the GNU Chess command line interface.[7]

Also in 1994, Stephen J. Edwards released the Portable Game Notation (PGN) specification. It mentions PGN reading programs not needing to have a "full chess engine." It also mentions three "graphical user interfaces" (GUI): XBoard, pgnRead and Slappy the database.[8]

By the mid-2000s, engines had become so strong that they were able to beat even the best human players. Except for entertainment purposes, especially using engines with limited strength, matches between humans and engines are now rare; engines are increasingly regarded as tools for analysis rather than as opponents.

Interface protocol

[edit]

Common Winboard engines would include Crafty, ProDeo (based on Rebel), Chenard, Zarkov and Phalanx.

In 1995, Chessbase released a version of their database program including Fritz 4 as a separate engine. This was the first appearance of the Chessbase protocol. Soon after, they added the engines Junior and Shredder to their product line up, including engines in CB protocol as separate programs which could be installed in the Chessbase program or one of the other Fritz style GUI's. Fritz 1-14 were only issued as Chessbase engines, while Hiarcs, Nimzo, Chess Tiger and Crafty have been ported to Chessbase format even though they were UCI or Winboard engines. Recently, Chessbase has begun to include Universal Chess Interface (UCI) engines in their playing programs such as Komodo, Houdini, Fritz 15–16 and Rybka rather than convert them to Chessbase engines.

In 2000, Stefan Meyer-Kahlen and Franz Huber released the Universal Chess Interface, a more detailed protocol that introduced a wider set of features. Chessbase soon after dropped support for Winboard engines, and added support for UCI to their engine GUI's and Chessbase programs. Most of the top engines are UCI these days: Stockfish, Komodo, Leela Chess Zero, Houdini, Fritz 15-16, Rybka, Shredder, Fruit, Critter, Ivanhoe and Ruffian.

From 1998, the German company Millenium 2000 briefly moved from dedicated chess computers into the software market, developing the Millennium Chess System (MCS) protocol for a series of CD's containing ChessGenius or Shredder, but after 2001 ceased releasing new software.[9] A more longstanding engine protocol has been used by the Dutch company, Lokasoft,[10] which eventually took over the marketing of Ed Schröder's Rebel.

Increasing strength

[edit]

Chess engines increase in playing strength continually. This is partly due to the increase in processing power that enables calculations to be made to ever greater depths in a given time. In addition, programming techniques have improved, enabling the engines to be more selective in the lines that they analyze and to acquire a better positional understanding. A chess engine often uses a vast previously-computed opening "book" to increase its playing strength for the first several moves, up to possibly 20 moves or more in deeply analyzed lines.[citation needed]

Some chess engines maintain a database of chess positions, along with previously-computed evaluations and best moves—in effect, a kind of "dictionary" of recurring chess positions. Since these positions are pre-computed, the engine merely plays one of the indicated moves in the database, thereby saving computing time, resulting in stronger, faster play.

Some chess engines use endgame tablebases to increase their playing strength during the endgame. An endgame tablebase includes all possible endgame positions with a small amount of material. Each position is conclusively determined as a win, loss, or draw for the player whose turn it is to move, and the number of moves to the end with best play by both sides. The tablebase identifies for every position the move which will win the fastest against an optimal defense, or the move that will lose the slowest against an optimal offense. Such tablebases are available for all chess endgames with seven pieces or fewer (trivial endgame positions are excluded, such as six white pieces versus a lone black king).[11][12]

When the maneuvering in an ending to achieve an irreversible improvement takes more moves than the horizon of calculation of a chess engine, an engine is not guaranteed to find the best move without the use of an endgame tablebase, and in many cases can fall foul of the fifty-move rule as a result. Many engines use permanent brain (continuing to calculate during the opponent's turn) as a method to increase their strength.

Distributed computing is also used to improve the software code of chess engines. In 2013, the developers of the Stockfish chess playing program started using distributed computing to make improvements in the software code.[13][14][15] As of June 2017, a total of more than 745 years of CPU time has been used to play more than 485 million chess games, with the results being used to make small and incremental improvements to the chess-playing software.[16] In 2019, Ethereal author Andrew Grant started the distributed computing testing framework OpenBench, based upon Stockfish's testing framework,[17][18] and it is now the most widely-used testing framework for chess engines.[citation needed]

Limiting an engine's strength

[edit]

By the late 1990s, the top engines had become so strong that few players stood a chance of winning a game against them. To give players more of a chance, engines began to include settings to adjust or limit their strength. In 2000, when Stefan Meyer-Kahlen and Franz Huber released the Universal Chess Interface protocol they included the parameters uci_limitstrength and uci_elo allowing engine authors to offer a variety of levels rated in accordance with Elo rating, as calibrated by one of the rating lists. Most GUIs for UCI engines allow users to set this Elo rating within the menus. Even engines that have not adopted this parameter will sometimes have an adjustable strength parameter (e.g. Stockfish 11). Engines which have a uci_elo parameter include Houdini, Fritz 15–16, Rybka, Shredder, Hiarcs, Junior, Zappa, and Sjeng. GUIs such as Shredder, Chess Assistant, Convekta Aquarium,[19] Hiarcs Chess Explorer, and Martin Blume's Arena[20] have dropdown menus for setting the engine's uci_elo parameter. The Fritz family GUIs, Chess Assistant, and Aquarium also have independent means of limiting an engine's strength apparently based on an engine's ability to generate ranked lists of moves (called multipv for 'principle variation').

Comparisons

[edit]

Tournaments

[edit]

The results of computer tournaments give one view of the relative strengths of chess engines. However, tournaments do not play a statistically significant number of games for accurate strength determination. In fact, the number of games that need to be played between fairly evenly matched engines, in order to achieve significance, runs into the thousands and is, therefore, impractical within the framework of a tournament.[21] Most tournaments also allow any types of hardware, so only engine/hardware combinations are being compared.

Historically, commercial programs have been the strongest engines. If an amateur engine wins a tournament or otherwise performs well (for example, Zappa in 2005), then it is quickly commercialized. Titles gained in these tournaments garner much prestige for the winning programs, and are thus used for marketing purposes. However, after the rise of volunteer distributed computing projects such as Leela Chess Zero and Stockfish and testing frameworks such as FishTest and OpenBench in the late 2010s, free and open source programs have largely displaced commercial programs as the strongest engines in tournaments.

List of tournaments

[edit]

Current tournaments include:

Historic tournaments include:

Ratings

[edit]

Chess engine rating lists aim to provide statistically significant measures of relative engine strength. These lists play multiple games between engines. Some also standardize the opening books, the time controls, and the computer hardware the engines use, in an attempt to measure the strength differences of the engines only. These lists provide not only a ranking, but also margins of error on the given ratings.

The ratings on the rating lists, although calculated by using the Elo system (or similar rating methods), have no direct relation to FIDE Elo ratings or to other chess federation ratings of human players. Except for some man versus machine games which the SSDF had organized many years ago (when engines were far from today's strength), there is no calibration between any of these rating lists and player pools. Hence, the results which matter are the ranks and the differences between the ratings, and not the absolute values.

Missing from many rating lists are IPPOLIT and its derivatives. Although very strong and open source, there are allegations from commercial software interests that they were derived from a disassembled binary of Rybka.[22] Due to the controversy, all these engines have been blacklisted from many tournaments and rating lists. Rybka in turn was accused of being based on Fruit,[23] and in June 2011, the ICGA formally claimed Rybka was derived from Fruit and Crafty and banned Rybka from the International Computer Games Association World Computer Chess Championship, and revoked its previous victories (2007, 2008, 2009, and 2010).[24] The ICGA received some criticism for this decision.[25] Despite all this, Rybka is still included on many rating lists, such as CCRL and CEGT, in addition to Houdini, a derivative of the IPPOLIT derivative Robbolito,[26] and Fire, a derivative of Houdini. In addition, Fat Fritz 2, a derivative of Stockfish,[27] is also included on most of the rating lists.

Differences between rating lists

[edit]

There are a number of factors that vary among the chess engine rating lists:

  • Number of games. More games when testing each engine result in higher statistical significance.
  • Formulae used to calculate the elo of each engine.
  • Time control:
    • Longer time controls are better suited for determining tournament play strength, but also either make testing more time-consuming or the results less statistically significant.
    • Increment time controls are better suited for determining tournament play strength since tournaments usually use increment time controls, but many rating lists use cyclic/repeating time controls instead.
    • Consistent time controls throughout the rating list vs different time controls for each test. The latter results in a smaller statistical significance than the former because different time controls is a potential confounder. This is particularly problematic for CCRL because CCRL uses both cyclic/repeating time controls (40/15) and increment time controls (15"+10') in its CCRL 40/15 list yet maintains both time controls on the same list.[28]
  • Opponents used in testing engines.
    • Some rating lists only test an engine against the most recent version of each opponent engine, while other rating lists test an engine against the version(s) of each opponent engine closest in elo to the engine being tested.
    • Most rating lists do not test every engine on the rating list vs every other engine on the rating list in a round-robin tournament format. This causes distortions in the rating lists, especially for CCRL and CEGT.[29]
  • Hardware used:
    • Faster hardware with more memory leads to stronger play.
    • 64-bit (vs. 32-bit) hardware and operating systems favor bitboard-based programs
    • Hardware using modern instruction sets such as AVX2 or AVX512 favor engines using vectors and vector intrinsics in their code, common in neural networks.
    • Graphics processing units favor programs with deep neural networks.
    • Multiprocessor vs. single processor hardware.
    • Consistent hardware throughout the rating list vs different hardware for every test. The latter results in a smaller statistical significance than the former because different hardware is a potential confounder. This is particularly problematic for CEGT because multiple testers each with their own unique hardware are involved in testing each engine in CEGT.[30] The same issue arises in CCRL.[31]
  • Ponder settings (speculative analysis while the opponent is thinking) aka Permanent Brain.
  • Transposition table sizes.
  • GUI settings.
  • Opening book settings.

These differences affect the results, and make direct comparisons between rating lists difficult.

List of rating lists

[edit]

Current rating lists and rating list organizations include:

Historic rating lists and rating list organizations include:

Test suites

[edit]

Engines can be tested by measuring their performance on specific positions. Typical is the use of test suites where for each given position there is one best move to find. These positions can be geared towards positional, tactical or endgame play. The Nolot test suite, for instance, focuses on deep sacrifices.[32] The BT2450 and BT2630 test suites measure the tactical capability of a chess engine and have been used by REBEL.[33][34] There is also a general test suite called Brilliancy which was compiled mostly from How to Reassess Your Chess Workbook.[35] The Strategic Test Suite (STS) tests an engine's strategical strength.[36] Another modern test suite is Nightmare II which contains 30 chess puzzles.[37][irrelevant citation]

Kasparov versus the World (chess game played with computer assistance)

[edit]

In 1999, Garry Kasparov played a chess game called "Kasparov versus the World" over the Internet, hosted by the MSN Gaming Zone. Both sides used computer (chess engine) assistance. The "World Team" included the participation of over 50,000 people from more than 75 countries, deciding their moves by plurality vote. The game lasted four months, ending after Kasparov's 62nd move when he announced a forced checkmate in 28 moves found with the computer program Deep Junior. The World Team voters resigned on October 22. After the game, Kasparov said: "It is the greatest game in the history of chess. The sheer number of ideas, the complexity, and the contribution it has made to chess make it the most important game ever played."[38]

Engines for chess variants

[edit]

Some chess engines have been developed to play chess variants, adding the necessary code to simulate non-standard chess pieces, or to analyze play on non-standard boards. ChessV and Fairy-Max, for example, are both capable of playing variants on a chessboard up to 12×8 in size, such as Capablanca Chess (10×8 board).

For larger boards, however, there are few chess engines that can play effectively, and indeed chess games played on an unbounded chessboard (infinite chess) are virtually untouched by chess-playing software, although theoretically a program using a MuZero-derived algorithm could handle an unbounded state space.

Graphical user interfaces

[edit]

XBoard/Winboard was one of the earliest graphical user interfaces (GUI). Tim Mann created it to provide a GUI for the GNU Chess engine, but after that, other engines such as Crafty appeared which used the Winboard protocol. Eventually, the program Chessmaster included the option to import other Winboard engines in addition to the King engine which was included.

In 1995, Chessbase began offering the Fritz engine as a separate program within the Chessbase database program and within the Fritz GUI. Soon after, they added the Junior and Shredder engines to their product line up, packaging them within the same GUI as was used for Fritz. In the late 1990s, the Fritz GUI was able to run Winboard engines via an adapter, but after 2000, Chessbase simply added support for UCI engines, and no longer invested much effort in Winboard.

In 2000, Stefan Meyer-Kahlen started selling Shredder in a separate UCI GUI of his own design, allowing UCI or Winboard engines to be imported into it.

Convekta's Chess Assistant and Lokasoft's ChessPartner also added the ability to import Winboard and UCI engines into their products. Shane Hudson developed Shane's Chess Information Database, a free GUI for Linux, Mac and Windows. Martin Blume developed Arena,[20] another free GUI for Linux and Windows. Lucas Monge entered the field with the free Lucas Chess GUI.[39] All three can handle both UCI and Winboard engines.

On Android, Aart Bik came out with Chess for Android,[40] another free GUI, and Gerhard Kalab's Chess PGN Master[41] and Peter Osterlund's Droidfish[42] can also serve as GUIs for engines.

The Computer Chess Wiki lists many chess GUIs.[43]

See also

[edit]

Notes

[edit]

References

[edit]
  1. ^ blog.chess.com Creating a chess engine from scratch (Part 1: Basics) Archived 2012-03-08 at the Wayback Machine, Link date 28 June 2012
  2. ^ "4th World Computer Chess Championship - New York 1983 (ICGA Tournaments)". Game-ai-forum.org. Archived from the original on 2018-12-02. Retrieved 2018-12-02.
  3. ^ "New SYS-10". Sys-10.com. Archived from the original on 1 July 2022. Retrieved 26 June 2022.
  4. ^ Feng-hsiung Hsu, Thomas Anantharaman, Murray Campbell and Andreas Nowatzyk. "A Grandmaster Chess Machine." Scientific American. October 1990.
  5. ^ Computer-schach & Spiele would later start using the English word 'engine,' eg. 1997#6 when describing Fritz or Hiarcs.
  6. ^ "The True Value of Chess Software." Computer Chess Reports. 1992-3. vol. 3 no. 2 p. 22
  7. ^ "XBoard Project History". Tim-mann.org. Archived from the original on 2018-11-30. Retrieved 2018-11-29.
  8. ^ "Standard: Portable Game Notation Specification and Implementation Guide" (TXT). Thechessdrum.net. Archived from the original on 2007-08-22. Retrieved 2022-06-26.
  9. ^ Computer-schach & Spiele.
  10. ^ "Home - Lokasoft - Home of ChessPartner". Lokasoft.nl. Archived from the original on 26 June 2022. Retrieved 26 June 2022.
  11. ^ http://tb7.chessok.com Archived 2020-12-01 at the Wayback Machine Lomonosov website allowing registered user to access 7-piece tablebase, and a forum with positions found.
  12. ^ "Who wins from this? (chess puzzle)" Archived 2020-11-11 at the Wayback Machine An example chess position found from the Lomonosov chess tablebase.
  13. ^ "Stockfish Testing Framework". Tests.stockfishchess.org. Archived from the original on 22 March 2014. Retrieved 7 March 2014.
  14. ^ "Get Involved". Stockfishchess.org. Archived from the original on 16 June 2013. Retrieved 8 March 2014.
  15. ^ Costalba, Marco (1 May 2013). "Fishtest Distributed Testing Framework". Talkchess.com. Archived from the original on 19 April 2014. Retrieved 18 April 2014.
  16. ^ "Stockfish Testing Framework - Users". Test.stockfishchess.org. Archived from the original on 25 June 2018. Retrieved 17 June 2017.
  17. ^ "Github - AndyGrant/OpenBench: OpenBench is a Distributed SPRT Testing Framework for Chess Engines". Github.com. Archived from the original on 23 December 2021. Retrieved 23 December 2021.
  18. ^ "OpenBench". Chess.grantnet.us. Archived from the original on 2022-02-16. Retrieved 2022-02-16.
  19. ^ "ChessOK Shop, Software, Training, Equipment, Books". Shop.chessok.com. Archived from the original on 26 June 2022. Retrieved 26 June 2022.
  20. ^ a b "Free chess graphical user interface (GUI) Arena for chess engines". Archived from the original on 2007-03-14. Retrieved 2018-11-29.
  21. ^ "mizarchessengine.com". Archived from the original on 29 January 2013. Retrieved 25 September 2016.
  22. ^ "Chess engine controversy at chessvibes.com, retrieved 28/May/2010". Archived from the original on 2010-05-28. Retrieved 2010-05-28.
  23. ^ "Evaluation". Archived from the original on 2011-08-11. Retrieved 2010-12-18.
  24. ^ "Rybka disqualified and banned from World Computer Chess Championships | ChessVibes". Archived from the original on 2012-03-02. Retrieved 2011-06-30.
  25. ^ Riis, Dr. Søren (January 2, 2012). "A Gross Miscarriage of Justice in Computer Chess (part one)". Chessbase News. Archived from the original on 7 January 2012. Retrieved 19 February 2012.
  26. ^ "Free Houdini beats commercial Rybka 23.5-16.5". Chessvibes. 10 February 2010. Archived from the original on 10 April 2014. Retrieved 25 October 2013.
  27. ^ The Stockfish Team (2021-07-21). "Our lawsuit against ChessBase". Stockfishchess.org. Archived from the original on 2021-07-21. Retrieved 2021-08-18.
  28. ^ "CCRL 40/15, 2m1s and FRC 40/2 lists updated (21-10-2023)". talkchess.com. Archived from the original on 15 June 2024. Retrieved 22 October 2023.
  29. ^ "Experimental testruns of Stockfish / Torch". talkchess.com. Archived from the original on 15 June 2024. Retrieved 29 May 2024.
  30. ^ "CEGT Testers". Cegt.net. Archived from the original on 24 May 2022. Retrieved 26 June 2022.
  31. ^ Ray Banks (Modern Times). "ShashChess". talkchess.com. Archived from the original on 30 April 2024. Retrieved 30 April 2024.
  32. ^ "Nolot test suite". Archived from the original on 2007-08-17. Retrieved 2007-08-04.
  33. ^ "BT2450 test suite". Archived from the original on 2007-09-07. Retrieved 2007-10-10.
  34. ^ Rosenboom, Manfred. "Rebel Century FAQ: 3. Using Rebel". Archived from the original on 3 March 2016. Retrieved 25 September 2016.
  35. ^ "BRILLIANCY TEST SUITE (2 min/move)". Talkchess.com. Archived from the original on 26 June 2022. Retrieved 26 June 2022.
  36. ^ "Strategic Test Suite". Sites.google.com. Archived from the original on 18 January 2017. Retrieved 26 June 2022.
  37. ^ "Uups - Oops: Link-Fehler und URL-Umleitungen". Glarean-magazin.ch. 10 October 2010. Archived from the original on 15 June 2024. Retrieved 26 June 2022.
  38. ^ Harding, T. (2002). 64 Great Chess Games, Dublin: Chess Mail. ISBN 0-9538536-4-0.
  39. ^ "Lucas Chess". Lucaschess.pythonanywhere.com. Archived from the original on 6 July 2022. Retrieved 26 June 2022.
  40. ^ "Aart Bik's Website". Aartbik.com. Archived from the original on 2018-11-20. Retrieved 2018-11-29.
  41. ^ "Chess PGN Master". Pgnmaster.kalab.com. Archived from the original on 21 January 2021. Retrieved 26 June 2022.
  42. ^ "Archived copy". Archived from the original on 2018-12-10. Retrieved 2018-11-29.{{cite web}}: CS1 maint: archived copy as title (link)
  43. ^ "Computer_chess:wiki:lists:gui_protocol_support_list - Computer Chess Wiki". Computer-chess.org. Archived from the original on 2018-11-30. Retrieved 2018-11-29.
[edit]