/othello-ai

Lisp based Othello program designed to investigate AI game playing techniques.

Primary LanguageCommon Lisp

othello-ai

Lisp based Othello program designed to investigate AI game playing techniques.

Othello Game Description

Othello, also known as Reversi, is a game played on an 8x8 grid with 64 discs that are black on one side and white on the other. Based on the following start position:

- - - - - - - -
- - - - - - - - 
- - - - - - - - 
- - - W B - - - 
- - - B W - - - 
- - - - - - - - 
- - - - - - - - 
- - - - - - - - 

the two players (BLACK and WHITE) alternate turns placing discs on the board. In order for a valid turn to be made, discs must be placed to surround enemy pieces. Whenever a row, column, or diagonal of contiguous white pieces are surrounded on both ends by black pieces, the white pieces are "flipped" to the black side, making them black piecs. ( The opposite applies for flipping to white pieces, naturally. ) This is referred to as "flanking", or "bracketing".

In the following demonstration, The black player moves first, places a disc in row 6, column 5. This causes the white disc in row 5, column 5 to flip to the black side.

- - - - - - - -     - - - - - - - -     - - - - - - - - 
- - - - - - - -     - - - - - - - -     - - - - - - - - 
- - - - - - - -     - - - - - - - -     - - - - - - - - 
- - - W B - - -  => - - - W B - - -  => - - - W B - - - 
- - - B W - - -  => - - - B W - - -  => - - - B B - - -  
- - - - - - - -     - - - - B - - -     - - - - B - - - 
- - - - - - - -     - - - - - - - -     - - - - - - - - 
- - - - - - - -     - - - - - - - -     - - - - - - - - 

Whenever a player cannot place a disc that will bracket enemy pieces, that player must forfeit their current turn.

The game continues until either the board is filled, or once a scenario occurs in which neither player can perform a legal move. At this point, the number of discs are counted for each side and the player with the most discs is the victor.

Program Description

For this project, a Lisp program has been implemented for the Othello game. There are options for human vs human, human vs ai, and ai vs ai. The AI implemented for this program is designed to investigate AI game playing techniques. In particular, this program uses the minimax strategy with alpha-beta pruning.

Minimax

Minimax is an algorithm that works well for two-player board games, and exists as a model for making moves based on knowledge of what the other player will do. This algorithm opperates on the truism "What is good for my opponent is bad for me". The general idea of minimax is the following:

  1. Look at all available moves
  2. Assign a rating to each board position that results form each move
  3. Pick the move with the [minimum/maximum] point rating.

This algorithm alternates step 3 for minimum and maximum for the player [maximum] and their opponent [minimum]. One of the benefits of this method is that the point ratings work for both the player moves and the opponent moves; alternating looking at minimum during opponent's turn and maximum during player turn is sufficient. Minimax is performed by creating a graph of available moves and performing depth-first search.

( Minimax Description Source: Land of Lisp, Conrad Barski )

Alpha-beta Pruning

Alpha beta pruning is a search algorithm that decreases the number of nodes needed to be evaluated by the minimax algorithm. This algorithm stops evaluating a particular move when at least one possibility has been found that renders the move to be worse than a previously examined move available for the current player. As a result, the returned solution from minimax without alpha-beta pruning will be identical to the solution from minimax with alpha-beta pruning. The major difference is the amount of time saved by reducing the number of expanded nodes in the search algorithm.

( Alpha-beta Pruning Source: https://en.wikipedia.org/wiki/Alpha-beta_pruning )

Board Weights for Heuristics

The following board is the value map used to determine how the AI prioritize movements:

32 01 16 08 08 16 01 32
01 01 02 02 02 02 01 01
16 02 04 04 04 04 02 16
08 02 04 02 02 04 02 08
08 02 04 02 02 04 02 08
16 02 04 04 04 04 02 16
01 01 02 02 02 02 01 01
32 01 16 08 08 16 01 32

The value map on the board causes the weighted-count heuristic to prioritize specific board positions. All of the weights were assigned as powers of 2.The folling is a list of the weighted regions and the reasoning for those weights.

  • Corners 32: Corners had originally been 16, however in testing the ai gave them up too easily. 32 was a better value, as this causes the ai to almost always prioritize corners when available.
  • Areas around corners 01: Since the areas around corners will give your opponents an opprotunity to take the corner they are the lowest score on the list.
  • Outer Sides 16: Outer sides seemed more important than the inner sides when playing because they are harder to flank. When they were previously equivilent the ai didn't properly defend them which allowed the other player to build up a strong side of the board more easily.
  • Inner Sides 8: The inner sides are more important than the center board but the easiest to flank so we set those up as the weakest of the sides this makes the program build up a side from corner to the next.
  • 2nd Row/Col in 2: These spaces were set to 2 (the default weight) because they open up an opportunity to take a side.
  • 3rd Row/Col in 4: These are usually safe moves so they are prioritized over the standard value of 2. They also open the opponent to less safe move.
  • Starting Positions: These are given the standard value of 2 as to not over influence the game since they are both inconsequential and hard to control.

Program Usage

  • Command Line Usage:

    clisp othello.lsp (player: Black or White)

  • CLISP Usage:

    (load 'othello)

    ( othello [player] )

Othello Tournament

For the Spring 2016 CSC 447/547 course, we are holding an Othello tournament in which our program will compete against the programs written by other students in the course. in order to facilitate the programs playing against one another, the following torunament functions have been supplied:

  • ( make-move position player ply )

This function takes the current board position, the current player who has the next move, and the depth of search (or ply, to look ahead in the game tree). It returns a ( row col ) list that specifies the move selected by the minimax function, or NIL if no legal move exists.

  • ( othello-init )

Another tournament function is othello-init, which takes no arguments. This function is called once, prior to the start of tournament play. Initialization code may be placed in this routine if necessary, but our implementation does not use this function at all.

References

A fair bit of research was put into this program for learning the rules to Othello and gaining an understanding for implementing our strategies. Some sites used for reference:

Authors

  • J. Anthony Brackins
  • Marcus Haberling

Written Spring 2016 for CSC447/547 AI class.