haslam22/blackstone
How To Win Five In A Row Game Pigeon Forge
Gomoku (Five in a Row) game manager with a powerful built-in AI, written in Java with a clean, minimal interface.
Old lines (lines) as well as in this online game you need to build in a line of five identical elements — balls or rocks. You can find this game in Balls, Puzzles, Logical games sections, where also located a number of similar free online games. Rules of the Game. Connect Four (or Four in a Row) is a two-player strategy game. Each player takes turns dropping a chip of his color into a column. The first player to align four chips wins. The Connect 4 game is a solved strategy game: the first player (Red) has a winning strategy allowing him to always win.
- Users starred: 30
- Users forked: 9
- Users watching: 30
- Updated at: 2020-06-06 01:24:33
How To Win Five In A Row Game Pigeons
A Gomoku (Five in a Row) game manager featuring a powerful AI written in Java
. Download the latest release here (runnable jar). Compatible with Java 12 +.
There are two main components in this project:
- A strong AI player based on Minimax with α-β pruning, alongside many performance optimisations (haslam.blackstone.players/negamax)
- An easy to use game manager with a minimal GUI created using JavaFX (see below for features) (haslam.blackstone.gui)
Features
- Loading of external AI's supporting the Piskvork protocol (Download page)
- Freestyle Gomoku games against the built-in Negamax AI
- Beautiful, fully resizable and flexible Gomoku board, supporting high DPI displays
- Configurable game settings including time per move, time per game and board size
- Easy saving and loading of positions with move order maintained
Install
Clone the project and open in any IDE that supports Maven projects or install Maven directly and use mvn clean install
from the command line in the root directory to build the project in one step.
Known limitations of AI performance
- Position evaluation is slow. The evaluation is computed in real time, when it could be computed using a lookup table. This lookup table also has the potential to be very small (around 256x256 entries). Similarly, threat calculation can be achieved via the lookup table. This would decrease the amount of computation performed per position - leading to a much higher number of positions evaluated per second. There's a branch in progress for improving both position evaluation and threat calculation here.
- No detection of double threats. Double threats are basically a win, and this would reduce the prevalence of a Horizon effect where we can't see a win/loss just over our depth limit.
- No transposition table. This could be used to cut off large subtrees in the alpha-beta search.
- No VCT (Victory by Continuous Threats) search. See academic paper here describing this search algorithm that works in the space of threats. Can be very powerful in determining a win/loss in a given scenario.