Final project for course 20596: Prolog programming and aspects to artificial intelligence. \
Joust is a two-player abstract strategy board game that may be considered a two-player variant of the knight's tour. It may also be considered a chess variant. It uses a 8 x 8 checkered board, and two Chess knights as the only game pieces. Each player has one knight of a different color from the other player. The knights move as in the game of Chess, but the square it leaves (upon making a move) becomes "burned", that is, it can no longer be moved upon. As the game progresses, fewer squares are available to be moved upon. The objective is to prevent your opponent's knight from performing a move on its turn. (source: Wikipedia)
The start position of the game:
A possible endgame position. It is the white knight's turn, but it has no where to move, therefore, the black knight wins.
- Install the latest stable release of SWI-Prolog
- Run the
start.bat
file - The game should start automatically. If for some reason it doesn't, just type
joust.
from the SWI-Prolog interface. - Once the game begins, left-click on a square to order your knight to go over.
The game has a configuration file simply named config
, you can use any text editor to edit it and customize the game. Currently, the supported configuration options are:
board_dimensions(X,Y)
: Sets the size of the game board. X and Y are assumed to be positive integer values.difficulty(Level)
: Sets the difficulty of the game.Level
can by any ofnovice
,easy
,medium
,hard
,ultra
ordemigod
.
The AI of the game is based on the Alpha-Beta algorithm as it appears on page 585 in the textbook, where black takes the role of the MAX player while white takes the role of the MIN player. The heuristic function staticval
evaluates a given position as follows:
- If it's the white player's turn and it has no legal moves, then the value is +1000 (guaranteed black win).
- Otherwise (white has at least one move), if it's the white player turn and black has no legal move to perform then the value is -1000 (guaranteed white win).
The case for the black player is symmetric:
- If it's the black player's turn and it has no legal moves, then the value is -1000 (guaranteed white win).
- Otherwise (black has at least one move), if it's the black player turn and white has no legal move to perform then the value is 1000 (guaranteed black win).
For non-terminal game positions, the heuristic function simply estimates its value as the number of legal moves for the black - the number of legal moves for the white. Therefore, the algorithm should prefer positions for which black has plenty of options for continuation while white has fewer.
For example, in the screenshot below we can see a state where the black knight has 7 possible moves, while the white knight has only 4. As a result, the heuristic function will evaluate this state as 7 - 4 = 3
.
The difficulty of the game (see Configuration) sets the maximal search depth of the game tree. The values corresponding to the different difficulty levels are summarized in the following table:
Difficulty | Search depth |
---|---|
novice | 1 |
easy | 2 |
medium | 3 |
hard | 4 |
ultra | 5 |
demigod | 6 |
Based on some tests we've done, it's possible to play the game of it's highest difficulty (demigod
) on 10x10 boards and expect the AI to make a move within a reasonable amount of time (usually couple of seconds).
The project is comprised out of the following files and directories: \
src/ai.pl
: Contains the implementation for the alpha-beta algorithm, as well as some auxillary predicates (staticval
,betterof
, etc.). \src/gui.pl
: Contains predicates for rendering the game board, handling user input, etc. Based on XPCE. \src/moves.pl
: Defines the legal moves for a knight on a chessboard. \src/joust.pl
: Main game logic. Responsible for GUI initialization, turn switching, annoncing the winner, etc. \start.bat
: A small batch script to kick off the game. \config
: Configuration file for the game (see Configuration). \knights
: Directory that contains JPEG images of the knights used in the game. \images
: Directory that contains JPEG images referenced by thisREADME.md
file. \
- Assaf Carlsbad
- Igor Tsemakhovich