GitHub: https://github.com/dsjong/othello/
-
Dion Ong: Implemented the game and MTDF on top of minimax
-
Andrew Wang: Implemented the minimax engine
Othello is a two player strategy game played on an 8×8 board. The game uses 64 disks which are white on one side and black on the other. Players take turns placing disks with their assigned color facing up in a way that outflanks some of the opponent's disks. Doing so flips the outflanked disks, turning them into the current player's color. The objective is to have majority of the disks displaying one's color when the last playable square is filled. Read the rules here.
We implement an iterative deepening MTDF engine that searches to the maximum depth it can reach within 150 ms. This improves on Alpha-Beta pruning with transposition tables by only using null windows for each evaluation. To further increase search depth, the implementation of the game is optimized with bitboarding techniques that parallelize board operations (see src/board.cpp
).
The search uses a heuristic function based on a paper by Rosenbloom. The function considers three measures when assessing the score of the state: mobility, potential mobility, and edge stability. The first two measures maximize the number of options available to the player at any point, while stability helps the player capture valuable squares such as corners. Implementations of these can be found in src/heuristics.cpp
.
To run the test script:
-
Run
git clone [email protected]:dsjong/othello.git
. -
Run
make
to create thebin/runner
executable. Optionally, runmake CFLAGS=-DDEBUG
after doingmake clean
to see debugging outputs. -
Run
./bin/runner num_games engine1 engine2 seed
. The runner outputs the individual scores of2 * num_games
games, as well as the cumulative points gained by each agent. 1 point is awarded for a win, 0.5 for a draw, and 0 for a loss.-
num_games
-- the number of pairs of games to be run. For fairness, both engines start one game in each set first and another game second. -
engine1
-- the first engine to play. The allowed engines are listed in the following table:Engine Description ab
Alpha-beta agent with transposition table mtdf
MTDF agent minimax
Minimax agent random
Random agent -
engine2
-- the second engine to play (same choices as the first engine). -
seed
-- positive integer seed used to randomize the starting board. If seed is0
, no randomization is used and the game starts from the standard starting position.
-
Examples: ./bin/runner 20 mtdf minimax 1
We found the MTDF agent to be the strongest, followed by alpha beta with transposition table then minimax.
Playing 50 sets of games between the three agents (using a seed of 1
) gives the following results (see details in the log
folder):
Engine | MTDF | AB | Minimax | Total |
---|---|---|---|---|
MTDF | 59-41 | 98.5-1.5 | 157.5-42.5 | |
AB | 41-59 | 100-0 | 141-59 | |
Minimax | 1.5-98.5 | 0-100 | 1.5-198.5 |
All three agents beat the random agent almost 100% of the time starting from the standard initial position. To verify this, run the test script with seed 0
(no randomization is needed because the benchmark agent is already random).