For SR2020, a virtual competition will be run using a brand new simulator.
This simulation is based in Webots, which will need to be downloaded and installed. The download is around 1.5GB.
You will also need Python installed.
|Platform||Supported Python Version|
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.
Installing the simulation
- Download the simulation, and unzip it somewhere on your computer.
- Using the Webots IDE, open the
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, a vision system, and a gripper to pick up tokens, all of which can be programmed.
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
x is zone number
Your code at
robot.py will be used for zone
0, though you are encouraged to move your code to
zone-0/robot.py 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 | └─ robot.py └── robot.py
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.