You need to download and install Webots (the download is around 1.5GB). This is the platform we run our simulation in.

Python Version

You will also need Python installed.

Platform Supported Python Version
Windows 3.7 - 3.8 (64-bit)
macOS 3.7 - 3.8
Linux 3.7 - 3.8

In the competition, Python 3.7 will be used.

There are a small number of external libraries which will be available to your robot code during the competition. Note that for local development you will need to install these yourself.

If there are other libraries you would like included, please let us know via the forums and include a link to the package on PyPI.

Installing the simulation

  1. Download the simulation, and unzip it somewhere on your computer.
  2. Using the Webots IDE, open the worlds/Arena.wbt file.

You may receive a warning about your computer’s GPU not being good enough, which can be ignored.

Changing your version of Python

If webots is picking up the incorrect version of Python, you’ll need to change it. This can be done using Tools > Preferences > General > Python command. You’ll need to ensure a matching version of Python is installed.


Occasionally, we may release an update to the simulation. To update, you will need to delete the competition-simulator-<version> directory, and re-download it using the above link.


Within the Webots IDE, there are a few different panels:

  • In the centre of your screen is the 3D simulated view of the arena
  • On the left is a tree hierarchy of all elements in this “world”
  • At the bottom is the console, where output from your robot code will be displayed
  • At the top are your general controls which include the time controls. Press the centre play button to run the simulation at normal speed.


This is the pre-built robot used in the simulator, with an interface similar to the SR API.

The robot has an array of sensors which can be programmed and a radio system.

Other robots

There are 3 other robots in the arena, all in their starting zones. By default, these robots will not move.

To control these robots, you will need to provide their code:

Create the robot code in zone-x/, where x is zone number 1, 2 or 3. Your code at will be used for zone 0, though you are encouraged to move your code to zone-0/ when running multiple robots. Robots which do not have any robot code in their zone-x directory will not do anything.

├── competition-simulator-<version>
│   ├── ...
│   └─ worlds
│       └── Arena.wbt
├── zone-1
|   └─


In the simulated environment, time advances only at the pace that the simulator is run. The relation between this time and the real passage of time depends on a couple of factors: the speed the simulation is configured to run at and the ability of the computer running the simulation to process it fast enough.

You can configure and observe the speed the simulator is running at from the toolbar in webots:

Here the simulation has run for 13.28 seconds, but is currently paused (the speed multiplier shows 0.00×). You could choose to step a single time increment, run the simulator at real speed (▶), or run the simulator at various faster speeds (▶▶ and ▶▶▶).

These differences mean that your code will need to use a different mechanism to find the current time or to sleep within the simulation. Find out more by heading over to the programming docs on time.