I built a game playing agent tournament. To give some context this wasn't entirely from scratch. I had the benefit of learning from the previous tournament which had a few flaws.
December 2020 tournament
The previous tournament was written in python3 with the rough architecture above. It worked roughly like the following:
- A participant would write their agents in python3. They would implement a get_action function which the game would call each tick. The function would pass in game_state as a parameter and participants could do computation on that to evaluate what would make a good move.
- These would run as a python subprocess for some level of isolation.
The main problems with this design:
- Fair resource allocation between agents since the agents and game ran in the same process.
- Lack of support for other languages.
- Lack of similarity between tournament and dev environments. Participants were unsure of how
- Participants had to send in requests for specific libraries to be included on the production tournament environment running machine (eg. pandas / numpy).
April 2021 tournament
The new ran three docker containers; one for each of the agents + game server and the communication channel was over websockets. The webapp / game ui also connected and served as a visual and debugging aid for the game.
The new iteration was designed with the previous considerations in mind:
- With complete isolation of resources one agent spinning up too much CPU would have no impact on the other agent. It would also prevent issues where an agent would slow down the game.
- Any language that can be run in a Linux host could now be run in a docker container.
- Exact CPU count + memory allocation could be defined for containers and since the submissions were self container as long as it ran in the dev environment a participant could guarantee it would perform the same in the actual tournament
- As long as a participant knew how to build their image, they could bundle whatever dependencies / libraries and binaries they wanted.