The Entelect Challenge is an annual coding competition where students, professional developers, and enthusiasts develop an intelligent bot to play a game.
This year, the game is Sproutopia 🌱!
Best regards and good luck!
We have made it as simple as possible to get started. Just follow the steps below.
Download the zip file and extract it to the folder you want to work.
The application can be run using docker via the following commands from the root of the project:
.\run.cmd
./run.sh
These scripts will build the Docker image if it doesn't exist and run it. If the image already exists and you want to force rebuilding it for some reason, you can pass in the -b
or --build
command line argument to the script.
Sign up to the player portal here, and follow the steps to upload your bot and participate in tournaments!
Customize the provided logic or create your own to enhance one of the given starter bots, and then upload it to the player portal to see how it stacks up against the competition!
To create the best possible testing experience, and help our newest players hit the ground running. The Entelect Challenge now comes packaged with a visualiser and testing bot (dummy bot)!
To run the visualiser and dummy bot see the instructions below:
ℹ️: For simplicity, this example will be done using Visual Studio 2022
- Open the
Sproutopia.sln
in Visual Studio 2022 - Note the following projects in your IDE
- Select the
Configure Startup Projects...
- In the
Startup Project
section selectMultiple startup projects
and select the following projects (order dose not matter): - Note the following setup
- Press the play button on the
Visualiser
window (bottom of image), this will connectVisualiser
to the Game Engine - On the terminal window running the dummy bot (top left of image) enter a nickname for the dummy bot and hit enter
- The
Visualiser
should come alive and display the world map - Enter
W/A/S/D
in the dummy but terminal to see your bot move!
- The Pause ⏸️ button pauses the game (hit the play
▶️ button again to Unpause) - The Step ⏯️ button advances the game one tick per click
- The Visualiser independently connects to the Game Engine. Therefore you do not need to use the dummy bot at all. Feel free to connect your own bots and test
For more information, visit one of the following:
Or read the rules in the game-rules.md file.
In this project you will find everything we use to build a starter pack that will assist you to run a bot on your local machine. which comprises of the following:
- Sproutopia - This base project contains the following files:
- SproutopiaEngine - The engine enforces the game's rules by applying the bot commands to the game state if they are valid.
- Runner - The runner runs matches between players, calling the appropriate commands as given by the bots and handing them to the engine to execute.
- Logger - The logger captures all changes to game state, as well as any exceptions, and writes them to a log file at the end of the game.
- StarterBots - Coming Soon - Starter bots with limited logic that can be used as a starting point for your bot. This folder also contains a bot called
ReferenceBot
, which you can use to test your bot against!
This project can be used to get a better understanding of the rules and to help debug your bot.
Improvements and enhancements will be made to the game engine code over time.
The game engine is available to the community for peer review and bug fixes. If you find any bugs or have any concerns, please e-mail us or discuss it with us on the forum. Alternatively submit a pull request on Github, and we will review it.
When you run the Game Engine in debug configuration, it writes a log file for each game in the ./Sproutopia/bin/Debug/net8.0/logs
folder.
When you run the Game Engine in Docker, using the run.sh
or run.cmd
scripts, it writes a log file for each game in the ./dockerlogs
folder.
Each line entry in the log file is in json
format but it is important to note that the overall log file will not be recognised as valid json by a json parser. This is because log entries are appended to the file in real time and so maintaining an overall valid json structure would not be feasible.
There is a utility in the root of the project however which you can use to convert a log file to a valid json file. The utility is available as both a bash script (.sh) and a Windows command script (.cmd).
To convert a log file to json, the utility can be used as follows:
.\log2json.cmd inputfilename.log outputfilename.json
./run.sh inputfilename.log outputfilename.json
We have automated submissions through GitHub! For more information, sign up for the player portal here, and follow the steps!