To read John Hartmann's Chess Tech Tips 1-3, visit Part 1 of this article.
4. Start your Engines!
Engines are the third leg in the chess technology triad, and in some ways, they are perhaps the most important. When compared with traditional book study, working with ChessBase alone was different only in degree and not in kind. The program allowed users to study much more quickly and efficiently, but they still had to rely on their own calculative skills to make assessments. With the rise of the engines, however, we chess mortals suddenly had unfettered access to Grandmaster-level analysis at the push of a button. Dozens of chess engines are available for sale and for free download on the Internet. So which ones are strongest? Which are best for analysis? The answers to these two questions largely overlap, but it’s worth considering them separately. There are multiple engine ratings lists from reputable testing groups, the most notable lists being those from CCRL, CEGT, IPON and SSDF. Almost all agree that the top three engines are Stockfish 8 (an open-source engine), Komodo 10.3 (commercial), and Houdini 5.01 (commercial), and usually in that order. Stockfish also won the year’s preeminent engine competition, the Top Chess Engine Championship (TCEC), soundly defeating Houdini in a 100 game match on very fast hardware, while Houdini won the TCEC Rapid Tournament. A few other engines are worth mentioning beyond these top three. Deep Shredder 13 (commercial), a new incarnation of a venerable program, is in fourth place on most of the lists above, followed by a slew of less heralded entries like Andscacs, Critter, Equinox, Fizbo, and Gull (all free or open-source) and older favorites like Fritz and Hiarcs (both commercial). While the ratings achieved by these engines are impressive – Stockfish approaches 3500 on some lists! – remember that they only measure results in computer-computer play. Whether an engine is analytically useful is much more subjective. Comparative strength of play is important, but it’s also important to settle upon an engine (or two or three) whose analysis you understand and trust. Some, on the basis of this line of thinking, argue that it’s best to stick with one engine, to learn its qualities, its strengths and its biases. I can see the logic of this, as some engines are better at some things than others. Stockfish 8, for example, is excellent in the endgame, particularly when it has access to tablebases. But it can also ‘cop out’ in very complex positions, returning 0.00 scores that culminate in unnatural perpetuals. Once you know an engine’s weaknesses, you can, in a sense, compensate for them. There are others who think it important to consult a few engines in tough positions. Because engines aren’t perfect, as we will soon see, the idea here would be to solicit multiple opinions and use human judgment to more closely approach the truth. I tend to fall into this camp, but this may simply be personal preference combined with a touch of hubris. My rotation includes many of the engines listed above, with Stockfish and Komodo getting the most use.
5. Trust… but verify!
The key thing to remember about engines is that none are infallible. All of the engines discussed in this article are far, far stronger than any human alive. And it’s true that computers are excellent at finding consistently good moves and avoiding bad ones. This doesn’t mean that the computer always finds the best moves, or that best moves can always be identified. Computer chess enthusiasts have created specialized positions that can fool even the best engines, where completely blocked positions still register as a win for one side, or where bishop underpromotions (not coded into Fritz or Rybka) are the only moves that win. Here, however, I want to take a look at three recent real-life examples to help illustrate both the power and the limits of computer analysis.
Example #1
[pgn][Event "8th London Classic 2016"] [Site "London ENG"] [Date "2016.12.15"] [Round "6.3"] [White "Caruana, Fabiano"] [Black "Nakamura, Hikaru"] [Result "1-0"] [ECO "B96"] [WhiteElo "2823"] [BlackElo "2779"] [SetUp "1"] [FEN "r1bqk2r/5p2/p2p1b1p/3Np3/1P1NP1BP/8/1PP2B2/2KR3R w kq - 0 21"] [PlyCount "23"] [EventDate "2016.12.09"]21. Nf5 $1 Rb8 22. Nxf6+ Qxf6 23. Rxd6 Be6 24. Rhd1 O-O 25. h5 Qg5+ 26. Be3 Qf6 27. Nxh6+ Kh8 28. Bf5 Qe7 29. b5 Qe8 30. Nxf7+ Rxf7 31. Rxe6 Qxb5 32. Rh6+ 1-0 [/pgn]Fabiano Caruana nearly broke the Internet when he played 21.Nf5! (instead of 21.Nc6) against Hikaru Nakamura at the 2016 London Chess Classic. After the game Caruana said that “I’d analyzed this and the computer doesn’t show 21.Nf5. [ed: It was found by his second Rustam Kasimdzhanov in a training game.] The problem is that the computer doesn’t understand that after 21.Nf5 Bxf5 Black is pretty much just lost. It’s one of the saddest positions I’ve ever seen for Black.” The truth, however, is that engines can find this move… provided you give them enough time. When I tested the four leading engines in this position on a moderately fast quad-core machine, I was surprised to learn that three of the four could find the move after all.
There are echoes here of Kramnik’s infamous game 8 loss to Peter Leko in their 2004 World Championship match. Had his assistants let their engines run slightly longer during their preparation, they would have seen that their idea – which Kramnik duly played – was refutable, something that Leko was happy to discover over the board. In both cases the lesson is clear: blindly trusting computer analysis is not without risk. A quick scan with the engine can be useful, but there’s no replacement for rigorous analysis that combines silicon strength with human guile.
Example #2
[pgn][Event "WCh Rapid TB 2016"] [Site "New York USA"] [Date "2016.11.30"] [Round "2"] [White "Carlsen, Magnus"] [Black "Karjakin, Sergey"] [Result "1/2-1/2"] [ECO "C50"] [WhiteElo "2853"] [BlackElo "2772"] [SetUp "1"] [FEN "6k1/5pp1/7p/4r3/8/3BB1PP/5P2/6K1 b - - 0 40"] [PlyCount "88"] [EventDate "2016.11.30"] [EventType "rapid"]40... f6 41. Kg2 Kh8 42. Kf3 Rd5 43. Bg6 Ra5 44. Ke4 Rb5 45. h4 Re5+ 46. Kd4 Ra5 47. Kc4 Re5 48. Bd4 Ra5 49. Bc5 Kg8 50. Kd5 Rb5 51. Kd6 Ra5 52. Be3 Re5 53. Bf4 Ra5 54. Bd3 Ra7 55. Ke6 Rb7 56. Kf5 Rd7 57. Bc2 Rb7 58. Kg6 Rb2 59. Bf5 Rxf2 60. Be6+ Kh8 61. Bd6 Re2 62. Bg4 Re8 63. Bf5 Kg8 64. Bc2 Re3 65. Bb1 Kh8 66. Kf7 Rb3 67. Be4 Re3 68. Bf5 Rc3 69. g4 Rc6 70. Bf8 Rc7+ 71. Kg6 Kg8 72. Bb4 Rb7 73. Bd6 Kh8 74. Bf8 Kg8 75. Ba3 Kh8 76. Be6 Rb6 77. Kf7 Rb7+ 78. Be7 h5 79. gxh5 f5 80. Bxf5 Rxe7+ 81. Kxe7 Kg8 82. Bd3 Kh8 83. Kf8 g5 84. hxg6 1/2-1/2[/pgn]This position is from the second tiebreak game in the recent Carlsen-Karjakin World Championship match, where Carlsen has just played 40.Bd3. I was lucky enough to witness part of the match in person, and as compelling as it was, I think I’ve spent more time in recent weeks thinking about the punditry and the way it framed the match than the actual match itself. Agon’s commentary team made very heavy use of computer analysis in their work, with a ‘prediction bar’ embedded in the graphics package. Grandmaster analysts were continually interrupted by anchorman Knut Solberg’s gleeful shouting of current engine evaluations. All of this worked to reinforce the idea that computer analysis was the best predictor of the game’s correct outcome and each player’s best moves. If you asked a strong human player to evaluate the position above, they might say that the game was somewhere between a win and a draw, but that the ultimate evaluation was not clear. The engine, however, gives White a consistent advantage, and it found more than one win for Carlsen before Karjakin finally held the draw in 84 moves. What is ‘winning’ for an engine isn’t always winning for a human. Sometimes the win requires a move that is completely foreign to human logic. In this case, as Greg Shahade (citing Gregory Kaidanov) has said, it’s best to pretend the move doesn’t exist and instead focus on moves that mortals might actually play. The point is that humans, struggling against a clock, an opponent, and their own psyches, can’t be expected to find moves that a computer will. Carlsen shouldn’t be blamed for missing precise moves in a pressure-filled rapid game. Some of the computer’s proposed wins were literally super-human. There is also a lesson here for the chess analyst. Some computer moves and evaluations are irrelevant for humans. You have to understand why a move is winning, not just that it is. If you can’t win the resulting position over the board, the engine’s brilliancy is of no use, and it’s better to choose a ‘weaker,’ more ‘human’ move. Boris Gelfand has recently made much the same argument: “I am sure that there was someone watching the game [Karjakin-Gelfand, World Cup (6.1), 2009] online who thought I had blundered because the engine’s evaluation went from -6 to -2.5, but this is a complete misunderstanding. If the position is winning and you know how to win, then you are home and dry.” (Dynamic Decision Making in Chess, 239)
Example #3
[pgn][Event "?"] [Site "?"] [Date "2014.03.24"] [Round "?"] [White "2...Kg6"] [Black "Kantorovich/Steckner"] [Result "*"] [Annotator "Aagaard / Poghosyan"] [SetUp "1"] [FEN "8/R4p2/P4kp1/7p/7P/4K1P1/r4P2/8 w - - 0 1"] [PlyCount "4"] [EventDate "2014.??.??"]1. Kd4 g5 (1... Rxf2 $2 2. Rc7 Ra2 3. a7 Kf5 4. Kc4 {Steckner} Kg4 5. Kb3 $18) 2. Kd5 Kg6 $11 {Aagaard, March 2014 - "Looking at this position recently I think I found a simple way to draw: 2...Kg6!? with the idea ...f6, ...Kf5 and counterplay. I cannot see how White can improve his position."} (2... g4 $11 {Poghosyan 2011}) *[/pgn]Our final example comes from the realm of high endgame theory, and in this case, we encounter a position where the engine’s evaluation is fundamentally wrong. Both Stockfish (+2.6 at 57 ply) and Komodo (+1.7 at 47 ply) see the Kantorovich position (taken from Tal-Giplis, 1983) as winning for White. Here we run into an extreme form of the so-called horizon effect, where an engine cannot analyze deeply enough to fully understand the position. Human analysts like Jacob Aagaard and Vartan Pogohysian have – with computer assistance, to be sure – discovered that the position is ultimately drawn following 1.Kd4 g5 2.Kd5 g4 (Poghosyan) or 2…Kg6 followed by …f6, …Kf5 and kingside counterplay (Aagaard). It is rare that computers make mistakes in evaluation like this, but they do occur. Let your engine try to assess 24.Qxe5!! in Gusev-Averbakh (Moscow, 1951) if you want proof, or set it on some of the latest Mar del Plata lines in the King’s Indian and watch it struggle. So where does this leave us? The computer is a powerful tool for improvement, but it is vital to remember that it is just a tool and not allow our thinking to be dominated by it. My rule of thumb is this: a chess engine can always tell you if a move is bad, but it can’t always tell you what move is best. There are multiple good moves in many non-tactical positions, and it’s up to the human user to pick one that suits her style and practical needs. Trust your favorite engine, but don’t forget to verify! John Hartmann is a columnist for Chess Life Magazine and the Chess Journalists of America winner for the “Best Review” category. Read Five Chess Tech Tips for the New Year: Part 1 for tips 1-3.
Categories
Archives
- January 2025 (11)
- December 2024 (34)
- November 2024 (18)
- October 2024 (35)
- September 2024 (23)
- August 2024 (27)
- July 2024 (44)
- June 2024 (27)
- May 2024 (32)
- April 2024 (51)
- March 2024 (34)
- February 2024 (25)
- January 2024 (26)
- December 2023 (29)
- November 2023 (26)
- October 2023 (37)
- September 2023 (27)
- August 2023 (37)
- July 2023 (47)
- June 2023 (33)
- May 2023 (37)
- April 2023 (45)
- March 2023 (37)
- February 2023 (28)
- January 2023 (31)
- December 2022 (23)
- November 2022 (32)
- October 2022 (31)
- September 2022 (19)
- August 2022 (39)
- July 2022 (32)
- June 2022 (35)
- May 2022 (21)
- April 2022 (31)
- March 2022 (33)
- February 2022 (21)
- January 2022 (27)
- December 2021 (36)
- November 2021 (34)
- October 2021 (25)
- September 2021 (25)
- August 2021 (41)
- July 2021 (36)
- June 2021 (29)
- May 2021 (29)
- April 2021 (31)
- March 2021 (33)
- February 2021 (28)
- January 2021 (29)
- December 2020 (38)
- November 2020 (40)
- October 2020 (41)
- September 2020 (35)
- August 2020 (38)
- July 2020 (36)
- June 2020 (46)
- May 2020 (42)
- April 2020 (37)
- March 2020 (60)
- February 2020 (38)
- January 2020 (45)
- December 2019 (35)
- November 2019 (35)
- October 2019 (42)
- September 2019 (45)
- August 2019 (56)
- July 2019 (44)
- June 2019 (35)
- May 2019 (40)
- April 2019 (48)
- March 2019 (61)
- February 2019 (39)
- January 2019 (30)
- December 2018 (29)
- November 2018 (51)
- October 2018 (45)
- September 2018 (29)
- August 2018 (49)
- July 2018 (35)
- June 2018 (31)
- May 2018 (39)
- April 2018 (31)
- March 2018 (26)
- February 2018 (33)
- January 2018 (30)
- December 2017 (26)
- November 2017 (24)
- October 2017 (30)
- September 2017 (30)
- August 2017 (31)
- July 2017 (28)
- June 2017 (32)
- May 2017 (26)
- April 2017 (37)
- March 2017 (28)
- February 2017 (30)
- January 2017 (27)
- December 2016 (29)
- November 2016 (24)
- October 2016 (32)
- September 2016 (31)
- August 2016 (27)
- July 2016 (24)
- June 2016 (26)
- May 2016 (19)
- April 2016 (30)
- March 2016 (36)
- February 2016 (28)
- January 2016 (32)
- December 2015 (26)
- November 2015 (23)
- October 2015 (16)
- September 2015 (28)
- August 2015 (28)
- July 2015 (6)
- June 2015 (1)
- May 2015 (2)
- April 2015 (1)
- February 2015 (3)
- January 2015 (1)
- December 2014 (1)
- July 2010 (1)
- October 1991 (1)
- August 1989 (1)
- January 1988 (1)
- December 1983 (1)