Skip to content

Latest commit

 

History

History
116 lines (75 loc) · 4.32 KB

README.md

File metadata and controls

116 lines (75 loc) · 4.32 KB

CI

Graphics are Copyright GMT Games, copied from the Vassal CC:A module

This work is intended exclusively for education and learning about game-playing AI.

I presented this work in progress at Codemotion Milano 2023; here are the slides and here's the video.

The story of this repo so far

2023-11-27

Implemented the deck. Now we randomize the players' hands.

The MCTS AI has been set aside for the moment; AI is played by the Greedy player.

BUG: it does not reshuffle the deck when the talon is empty!!!

2023-11-25

When I presented at Codemotion, the MCTS-based AI was weak due to two factors:

  • choosing one unit at a time, ie simple moves were not grouped in macromoves
  • using closed loop instead of OpenLoop

Then I implemented Macromoves. This has substantially improved the MCTS AI, but I then realized that closed loop only works when the card distribution is fixed and unchanging, as it is now. This is a simplification over the real game that I initially implemented to get the AI implementation going. I now see that when we implement randomized hands, the closed loop implementation cannot work anymore.

I then implemented OpenLoopMctsPlayer; it works, but

  1. it does not have macromoves
  2. it is much slower than the original closed loop implementation

One way to address 2 is to implement the Flyweight pattern for all commands, which is a large refactoring that I have started but not completed.

How to

Serve locally with make server or python -m http.server

Run tests with make test (you should npm install jest first).
You may run a single test suite with script/test.sh src/whatever.test.js

Play the game with make open. Notice the "End phase" and "AI continue" buttons, you will need to click them at appropriate times to get the game to proceed. Also, keep an AI on the status text on top of the page: it tells you which phase the game is in.

Open your browser's developer tools to read the AI logs.

Configure the AI parameters in file src/config.js.

In the main scenario (Akragas), you play the Syracusan (bottom) while the MCTS AI plays the Carthaginian (top).

The Playout button pits the MCTS AI (bottom) against a greedy player (top). You can speed up or slow down the moves with the delay value in the textbox.

See a visualization of the search tree with make tree. You can tweak the parameters to change the level of detail you want, however be mindful that the more nodes you show, the longer it takes for the image to appear. The parameters are:

  • scenario: the key of the scenario to run
  • depth: how many levels of the tree to show (don't set it too high or it will take forever to get a picture)
  • threshold: the minimum number of visits below which we don't show a node
  • prune n: for the first n nodes in the tree, we only show the main line, not showing other subtrees
  • iterations, playouts: configure AI parameters

WIP

  • use OpenLoop in MCTS: reimplement best commands
  • implement MAP_CENTER and MAP_EAST

AI TESTS

  • Early game
    • The AI should advance compactly -- no weird backward movements
    • The AI should use all units -- not just the light ones
  • 2on2 Melee
    • should advance compactly
    • should choose attacking a weak unit over a strong one
    • should order combat to maximize potential dice
  • 1to1 Melee
    • light unit to avoid close combat
    • light unit to keep pestering the heavy with bows

TODO AI

  • macro-move sampling: avoid duplicate macro-moves in a node's children
  • macro-move sampling: make units not moving an option
  • macro-move sampling: tune the explore/exploit ratio
  • open loop instead of chance nodes
  • implement evasion, to allow the expected game strategy to emerge
  • make end phase automatic

TODO RULES

  • more cards
  • cavalry bonus movement
  • cavalry, chariot bonus combat
  • leaders
  • terrain
  • "if you don't have any X unit, order a unit of your choice"
  • heavy chariot battles back with 3 dice not 4
  • heavy chariot ignores one sword result
  • warriors, elephants, other units