The current release is version 1.0.0.
For more information about the challenge see the Challenge website .
- Download the release files
- Build your bot
- Submit
- Win
In this project you will find everything you need to build and run a bot on your local machine. This project contains the following:
- Game Engine - The game engine is responsible for running matches between players.
- Sample Bots - Sample bots can be used a starting point for your bot.
- Reference Bot - The reference bot contains some AI logic that will play the game based on predefined rules. You can use this to play against your bot for testing purposes.
- Calibration Bots - Calibration bots are used to calibrate the game engine when running bots to determine the amount of time a player bot is allowed to make a decision before the game engine kills it.
- Binaries - Binaries for the current version of the game. The binaries can be used to run the game without having to compile it your self.
This project can be used to get a better understanding of the rules and to help debug your bot.
Improvements and enhancements may be made to the game engine code over time, but the rules should remain stable. Any changes made to the game engine or rules will be updated here, so check in here now and then to see the changes.
The game engine has been made available to the community for peer review and bug fixes, so if you find any bugs or have any concerns, please e-mail challenge@entelect.co.za, discuss it with us on the Challenge forum or submit a pull request on Github.
The easiest way to start using the game engine is to download the binary release zip. You will also need the .NET framework if you don't have it installed already - you can get the offline installer for .NET Framework 4.5.1 here.
Once you have installed .NET and downloaded the binary release zip file, extract it and open a new Command Prompt in the Binaries/{version}/Game Engine folder.
We have included the reference bot in the binaries version folder, so at this point you can simply run the Run.bat to see the bots play a match.
Once you have written your own bot you can you can use the command line arguments to specify the bots that should be run. You can see the available command line arguments by running Bomberman.exe --help
:
-b, --bot (Default: Empty String Array) Relative path to the folder containing
the bot player. You can add multiple bots by separating each with a space.
-c, -console (Default: 0) The amount of console players to add to the game.
-r, --rules (Default: False) Prints out the rules and saves them in
markdown format to rules.md
--clog (Default: False) Enables Console Logging.
--pretty (Default: False) Draws the game map to console for every round instead of showing logs
-l, --log (Default: ) Relative path where you want the match replay
log files to be output (instead of the default
Replays/{matchSeed}).
-s --seed (Default: Random) The game seed to use for map generation.
--help Display this help screen.
So for example you can do something like this to run your bot against the bundled reference bot: Bomberman.exe --pretty -b "../Reference Bot" "../My Awesome Bot"
.
You might have to change the configurate file depending on your system in order to run the game. The configuration file is in the game engine folder called Bomberman.exe.config
. You can modify the file to update where the game engine looks for the various runtime executables such as the java runtime to use. All paths have to be absolute (unless the executable is in the system path).
We have changed things a bit this year when it comes to compiling and running the bot. You will not longer be able to include a run.bat and compile.bat file, the system will do that for you based on your bot meta you included. One of the reasons we decided to go this route is in order to add additional features to the game engine for instance running calibration bots.
Sample bot project files can be downloaded here.
The game engine requires that you have bot.json
file. This will tell the game engine how to compile and run your bot. The file must contain the following:
{
"Author":"John Doe",
"Email":"john.doe@example.com",
"NickName" :"John",
"BotType": "CSharp",
"ProjectLocation" : "",
"RunFile" : "Reference\\bin\\Debug\\Reference.exe"
}
- Author - Your Name
- Email - Your Email Address
- Nickname - The nickname that will be used by visualizers
- Bot Type - The type of bot
- CSharp
- Java
- JavaScript
- CPlusPlus
- Python2
- Python3
- FSharp
- Project Location - The root location of the project file. For instance in C# solutions, that will point to folder containing the solution (.sln) file. This will be used for bot compilation when you submit your bot.
- Run File - This is the main entry point file for your bot that will be executed to play the game.
- Java user have to ensure that the main class is specified in the manifest file
The game engine might set additional runtime parameter in some scenarios, for instance specifying minimum memory allocation for java bots.
The following package managers are supported by the game engine:
- Microsoft Languages - Nuget. (Requires the nuget.exe to be present in the project location path)
- Java - Maven. (Requires that the project contains a pom file in the project location path)
- JavaScript - NPM. (Requires that project contains a package.json file in the project location path)
- Python - Python Package Index. (Requires that the project contains a requirements.txt file in the project location path)
Your bot will receive two arguments when the for every round in the game:
- Your player key registered in the game
- The directory for the current game files
The game will store game files during a match in the following directory format
...Replays/
............Game seed/
......................Round Number/
...................................engine.log
...................................map.txt
...................................roundinfo.json
...................................state.json
...................................Player Key/
..............................................log.txt
..............................................map.txt
..............................................state.json
..............................................move.txt
Each player will have the map.txt
and state.json
files in their Player Key
folder until they made their move using the move.txt
file, after which the game engine will remove the state and map files to save some disk space. The map.txt
and state.json
files in the Round Number
folder is the same files that were placed in the player folders.
The engine.log
file contains information from the engine while processing the round.
The log.txt
file in the player file contains player specific logs, such as the console output from player bots. If your bot is misbehaving this should be the first place to go have a look. In this file you can also view additional information such as bot run time and bot processor time.
The round.info
folder is mainly for GUI submissions, and reports player stats and the leaderboard.
In order to help with bot calibrations and to speed up things a bit to give your bot the best possible chance at winning we are going to look into the possibility of running each match from a ram disk this year, provided the hardware specs allow for it without affecting bot performance. Keep an eye on the forum to see what our decision will be regarding this.
These are the simplified rules. More in depth rules are further down.
- A player can only make one move during a round.
- A player can make one of the following moves:
- Move Left - Moves on block left.
- Move Right - Moves on block right.
- Move Up - Moves one block up.
- Move Down - Moves one block down.
- Plant Bomb - Plants a bomb (If there are bombs in your bomb bag).
- Trigger Bomb - Takes the bomb with the lowest count down and sets the countdown to 1.
- Bombs will destroy walls, kill players and trigger other bombs.
- A player can pick up power ups to increase their bomb bag and blast radius.
- Players will earn points for destroying walls, killing other players and "discovering" the game map by moving around.
- The game leaderboard will be determined as follows:
- Players that are alive will be on top.
- If multiple players alive when the max rounds have been reached the points will be used.
- Players that have died will be sorted first on points, then based on the round they died.
We have written a number of automated tests to ensure that the game logic and rules have been implemented correctly - if you make any changes to the test harness you should run the tests to ensure that everything is still working correctly before submitting a pull request.
If you add a new feature you should add tests to cover it.
So doing your own little Turing test by playing against your own bot in the console to determine if it is going to turn into the next Skynet is fun and all, but what if you just want to take a break from it all?
That is where the Network (Console)
comes in. Invite some of your friends over or have some fun at the office during lunch time and play against some real human competitors. In the Network (Console)
folder there are two sub folders, the Host
and the Client
. Start the Host/SocketHost.exe
and wait for the clients to connect. Each of your friends, and you, should then launch a new Client/BomberManSocketClient.exe
The socket client will ask for a hostname, which should be your computer name (the host). Then each player will get a change to enter a user name. Once all of the players have connected, type in start into the host and press enter. May the best player win!
The game engine supports 2 to 12 players.
Disclaimer: This feature was developed purely for fun, and will most likely crash from time to time. Here are some tips if that happens
- Make sure you have only one network interface active to bind on
- Make sure that port 19010 is available for binding on your system
- Make sure the clients enter your computer name as it is registered on the network (IP Address might also work, but not always)
- Client players will connect to the host on ports 20001 - 20013
Change Log: 1.Initial release
The maps in the game will be generated randomly based on seed provided to the game engine. The game seed will be random for each match, but can be the same if matches need to be re-run. The map will be divided into four quadrants for generation purposes.
- The map will be surrounded with indestructible walls
- The default map size for 2-4 players will be 21x21 blocks
- Every second square, starting from the outer boundary, will be an indestructible wall. The only exception to this rule will be the center block on the map.
- Each quadrant will be generated such that the entire map will be symmetrical, with each quadrant appearing the same from each users perspective.
- Players will always be placed in a corner of the map. In case the map contains more than 4 players, the remaining players be placed equidistant from the other players along the sides of the map.
- Every player on the map will have a 2 block safe zone horizontally and vertically.
- The center of the map will always contain a Super power up in the center, in place of the indestructible wall.
- The center power up will always be surrounded by a 5x5 area of destructible walls.
- Power ups will be placed randomly across the map, with each quadrant of the map receiving the same amount and type of power ups. When four players are present, a fairness algorithm will be applied to ensure players have the same chance of finding a power up within a certain distance from them.
- Power ups on the map will be determined with the following algorithm
- Two bomb bag power ups will be placed on the map per player.
- Four bomb radius power ups will be placed on the map per player.
- The tournament will only have 2 or 4 players per map. But in some scenarios more players will be placed on the maps, in which case the map size (Width/Height) will dynamically change to accommodate more players.
Players can either be console players or bots. Both follow the same game engine rules. When playing on Unity, the rules will follow the actual game as close as possible, with exceptions made for real time play.
- Players will only be able submit one command per round. The game engine will reject any additional commands sent by the player.
- Only one of the following commands can be submitted by the player during a round:
- Move Command – Left, Right, Up, Down.
- Place Bomb Command – Places a bomb underneath the player.
- Reduce Bomb Timer – Reduces the timer of the bomb with the lowest timer for the player to 1.
- Do Nothing Command – Player skips the round and remains on the same block.
- Players will start with a bomb bag containing 1 bomb.
- Players will start with a bomb radius of 1.
- Players will start with a bomb timer of 4 rounds.
- Bot players will have the following additional rules
- Bot processes will be terminated after 4 seconds
- Bots will not be allowed to exceed a total processor time of 2 seconds
- Bots processes will run with elevated processor priority. (For this reason the game has to be run with administrator privileges)
- Calibrations will be done at the start of a game to determine additional processor time. So if the calibration bot takes 200ms to read the files and make a move decision then your bot will be allowed an additional 200ms to complete.
- Malfunctioning bots or bots that exceed their time limit will send back a do nothing command.
- Bot players that post more than 20 do nothing commands in a row will automatically place a bomb to kill themselves in an attempt to save the game
The following rules describe how the game engine will run and process the game
- The game engine contains the following entities:
- Indestructible Wall
- Destructible Wall
- Player
- Bomb
- Power Ups 1. Bomb Bag 2. Bomb Radius 3. Super Power Up
- A game block can only have one of the following entities at a single time:
- Indestructible Wall
- Destructible Wall
- Player
- Bomb
- Bomb with a player on top after planting
- Power ups will only be revealed once the destructible wall has been destroyed as a result of a bomb blast.
- The game engine will process rounds in the following order:
- Remove old explosions from the map
- Decrease all bomb timers
- Detonate bombs with a timer value of 0
- Trigger bombs that fall within the explosion range of another bomb
- Mark entities for destruction (Any players within a bomb blast at this moment will be killed)
- Process player commands
- Mark entities for destruction (If a player moved into a bomb blast, they will be killed)
- Apply power ups
- Remove marked (Killed/Destroyed) entities from the map
- Apply player movement bonus
- A player entity will not able to move to a space containing another entity, with the exception of power ups.
- A player can only plant a bomb if they have bombs available in their bomb bag. Planting a bomb removes a bomb from the bomb bag and will be returned once a bomb explodes.
- Two player entities will not be able to move onto the same space during a round, if this does happen the game engine will randomly choose a player whose move will be discarded.
- Bombs will start with a timer based on the players current bomb bag. The formula is (bombag size * 3) + 1. The bomb timers will be capped to 10.
- Bomb timers will decrease by 1 every round.
- Bomb radius will equal the radius bonus of the player at the time of planting. Obtaining a radius power up afterwards will not increase bomb radius of bombs currently on the map.
- Destructible Walls can only be destroyed if they fall within the blast radius of a bomb.
- Indestructible Walls will absorb the damage from a bomb and prevent it from continuing past the wall.
- Bombs will absorb the damage from other bombs and prevent it from continuing past the bomb, this will however will cause the affected bomb to detonate causing a chain of detonations.
- If a player is in the range of a bomb blast radius at the start of the round and is killed as result, their commands for that round will be ignored.
- If a player moves into the range of a bomb blast during a round, the player will be killed as a result.
- The game engine will be restricted to a certain amount of rounds. The max rounds for each map will be calculated as follows (map width * map height).
- The leader board for the game will be based on the following
- Players alive
- Then points for the players
- Then the round the players were killed
Power ups can be collected by players to improve their players abilities
- The bomb bag power up will give the player an additional bomb to plant on the map while the timers on other bombs are decreasing.
- The bomb radius power up will multiply the current bomb radius of the player by two.
- The special power up will give the following bonuses:
- Bomb bag power up
- Bomb radius power up
- 50 points
Players will collect points during game play. Points will be used (along with other conditions) to determine the player leaderboard and ultimately the winner
- Players will receive 10 points for destroying destructible walls.
- If two bombs hit the same wall, both players will receive 10 points for destroying the wall. Unless the wall was destroyed as result of a chain explosion.
- Players will receive points for killing another player based on the following equation (100 + (Max point per map for destructible walls / players on map)). So on map with 10 destructible walls with 4 players the points for killing a player will be 50.
- If two bombs hit another player, both players will receive points for killing the player. Unless the player was killed as result of chain explosion.
- Players will receive points based on map coverage:
- Points will only be calculated for each new block touched by a player.
- Points will determine player coverage on the map, with a map coverage of 100% giving the player 100 points.
- Players obtaining the Super Power up will receive additional points.
- When multiple player bombs are triggered in a bomb chain, all players with bombs forming part of the chain will receive the points for all entities destroyed in the chain.
- The round in which a player is killed will cause the player to forfeit all points earned in that round, and the player will lose points equal to the points earned when killing another player.