I move my pretty useless blog to Hugo about 7 years ago, since I got frustrated at too many security…
Classic Board Games for Computer Implementation?
So, my experiments with my checkers program Milhouse have been fun and interesting. There is still work to be done: I don’t think a machine that can’t properly play first position can be reasonably said to be a good checkers player (even though I still make errors while practicing it myself against Cake), but I’ve learned a lot. I’ve been toying with the possibility of doing a rewrite of Milhouse, but maybe that isn’t the best use of my precious after-hours time. For the last couple of days, I’ve been musing about the possibility of finding other strategic board games that might be fun to try. Here is a rough list of my internal criteria:
- It should be a game that people play. It would be great if there was some existing scholarship on human play, including test positions.
- It should be a game which is uncopyrighted and free from legal restrictions for use. Hence my use of the term “classic”.
- It should be reasonably hard. Trivial games like Tic Tac Toe need not apply.
There are some additional possibilities..
- I’m willing to consider games with a chance component (such as dice in backgammon) or a gambling component (such as the doubling cube in the same).
- I prefer games which are more abstract, whose difficulties arise from position and interaction more than complicated rules.
So, what games are out there?
Well, obviously there is chess and its variants, including Shoji, Xiangqi and a slew of modern variants. Originally I had a goal of implementing chess, but I must admit that it doesn’t appeal to me quite as much now largely because I view it as less abstract than games like checkers. The difficulty of First Position arises not because of complex interactions between different piece types, but because of the interplay of very simple elements. Still, I have considered the possibility of taking one of the variants of chess that are played on small boards perhaps a 5×6 board and developing opening and endgame databases for these. I haven’t done the math on what it would take to resolve the game theoretic value of one of these small games, but it might be tractable with the computing power that I have at my disposal.
There are obviously variants to checkers, including international draughts and the misere variants, also known as suicide checkers. The idea is that the person who loses all their pieces first wins. Martin Fierz has a version of Cake called Suicidal Cake which can play suicide checkers, which is an interesting variant with many of its own subtle problems. International draughts is a much more complicated game, with a larger board and some really interesting rules for jumping. There are other variants as well (Polish, Turkish, Italian) which could be considered as strong candidates.
Othello or Reversi are interesting games of position, and which can use many of the techniques we see in checkers and chess (namely opening books and endgame databases). There is also a fair amount of human knowledge about the game, which is good.
Backgammon introduces chance into the mix, which generally means that you need to use a different set of techniques than we’ve seen so far. I also like to play backgammon (although am only a middling level player). Backgammon has been the subject of quite a bit of machine learning research, and there exists many implementations to spar against.
Hex is a very nearly perfect abstract game: players alternate turns to connect their side of the board to the opposite side. There are no draws possible. The entire games can be displayed as a single graphic, which shows the order in which stones were placed on the board. The high branching factor makes traditional alpha-beta search less attractive.
Go has many of the same characteristics, with the added bonus of having lots of good human players. There has been a lot of interesting research recently about playing Go.
Arimaa was designed to be hard for computers to play, but frankly, I think that it does so only by making a rule system which is complicated. It seems between the push, pull, freeze and trap rules, there are at least two and maybe three that could have been eliminated. I also suspect that while it is (according to the authors) “easy to learn”, I suspect that really only means “easy to learn the rules”. I would make the (unsupported) claim that most human play is quite weak as well.
Games like Awari or other games of the mancala family have been studied quite extensively. Connect 4 has been solved, but is still middling interesting.
Any other board games I’m missing? I await your suggestions and/or advocacy.
Comments
Comment from D. Eppstein
Time 3/25/2010 at 9:17 am
I’m still fond of Fanorona.
Comment from James Harman
Time 3/25/2010 at 12:31 pm
If you want a really abstract challenge – you could take a look at Diplomacy.
Here is a link to what is going on right now with people attempting to do an ai:
http://www.daide.org.uk/index.xml
Diplomacy is unique because of the interaction with 7 other playes as well as the simultaneous moves.
Comment from Tom
Time 3/26/2010 at 7:14 am
Risk.
C’mon, why not take over the world?
Comment from Mark VandeWettering
Time 3/26/2010 at 8:07 am
Risk and Diplomacy are both excellent ideas, but do have the negative side effect that they are both copyrighted, and therefore are likely to encounter difficulties should I later choose to distribute the results of my efforts.
Comment from Hydrogen Units
Time 8/4/2010 at 2:29 am
Try this new and useful technology for a very affordable price only.
Comment from Tom Duff
Time 3/25/2010 at 9:11 am
I liked TwixT, a relative of hex, a lot when I was about 10 years old, but eventually stopped playing for want of an interested opponent. Link: http://en.wikipedia.org/wiki/TwixT Following links from the Wikipedia page looks like it might find a lot of other good possibilities.