Skip to content

Engine written in Java to play PentagoTwist, a two-player strategy game. Game code was written by Dr. Jackie Cheung and TA team. AI written by myself, contained in src/student_player

Notifications You must be signed in to change notification settings

awestm/pentago_twist

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

30 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Pentago Twist AI written in Java for COMP 424 - Artificial Intelligence at McGill University

Code I wrote contained within src/student_player. Created an AI to play Pentago Twist vs a Human or other AI. AI utilizes Alpha-Beta pruning along with the minimax algorithm to determine the best move.

Instructions

Run src/boardgame/Server.java. Go to Launch -> Launch Client (student_player.StudentPlayer) then Launch -> Launch human player to play against the AI.

More information about the game and framework from the original repo written by @SaminYeasar below:

pentago_twist

Pentago-Twist falls into the Moku family of games. Other popular games in this category include Tic-Tac-Toe and Connect-4, although Pentago-Twist has significantly more complexity. The biggest difference in Pentago-Twist is that the board is divided into quadrants, which can be flipped or rotate 90 degree right during the game.

Setup

Pentago-twist is a two-player game played on a 6x6 board, which consists of four 3x3 quadrants. To begin, the board is empty. The first player plays as white and the other plays as black.

Objective

In order to win, each player tries to achieve 5 pieces in a row before their opponent does. A winning row can be achieved horizontally, vertically or diagonally. If all spaces on the board are occupied without a winner then a draw is declared. If rotating/flipping single quadrant results in a five-in-a-row for both players, the game also ends in a draw.

Playing

Moves consist of two phases: placing and rotating/flipping. On a given player's turn, a piece is first placed in an empty slot on the board. The player then selects a quadrant, and can choose either to flip or rotate 90 degree right. A complete move therefore consists of placing a piece, then rotating/flipping.

Strategy

Allowing quadrants to be flipped/rotated introduces significant complexity and your AI agent will need to contend with this high branching complexity. Since quadrants can be flipped/rotated, blocking an opponent's row is not as easy as simply placing an adjacent piece. A good AI agent might consider balancing seeking to win with preventing their opponent from achieving the same.


Navigate through the scripts

src  
|  --- autoplay ( Autoplays games; can be ignored) 
| --- boardgame (Package for implementing boardgames, logging, GUI, and server TCP protocol, can be ignored for this project)
| --- student_player (Package containing your agent)
|      | --- StudentPlayer.java (The class you will implement your AI within)
|      | --- MyTools.java (Placeholder for any extra code you may need)} \nonumber 
| --- pentago_swap (The package implementing all game logic)
|      | --- PentagoBoardPanel.java (Implements the GUI, can be ignored)
|      | --- PentagoBoard.java (Used for server logic, can be ignored)
|      | --- PentagoCoord.java (Simple class representing a board coordinate)
|      | --- PentagoMove.java (A move object for Pentago. Relevant functions)
|      | --- PentagoBoardState.java (Implements all game logic, most important. Note that PentagoBoardState (PBS) manages} logic concerning whose turn it is, rules, and the positions of all pieces)
|      | --- PentagoPlayer.java (Abstract class that all players extend)} 
|      | --- RandomPentagoPlayer.java (A random player, can be used as a baseline)

About

Engine written in Java to play PentagoTwist, a two-player strategy game. Game code was written by Dr. Jackie Cheung and TA team. AI written by myself, contained in src/student_player

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Java 100.0%