Skip to content

NUbots/hlvs_webots

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Robocup Virtual Humanoid League

This folder contains the simulation setup for the Robocup Virtual Humanoid League.

Requirements

In order to run this simulation, you will need to have a fairly powerful Linux, Windows or macOS computer. You will also need to get familiar with Webots by reading the Webots User Guide and following the Tutorials.

Installation

  1. Install Webots 2022b from https://cyberbotics.com/
  2. Build the latest version of the official RoboCup Humanoid TC fork of the GameController.
    apt-get install ant
    git clone https://github.com/RoboCup-Humanoid-TC/GameController
    cd GameController
    ant
    
  3. Install Python dependencies:
    pip3 install -r controllers/referee/requirements.txt
    
  4. Build the controllers:
    apt-get install protobuf-compiler libprotobuf-dev libjpeg9-dev
    export WEBOTS_HOME=/usr/local/webots # Set WEBOTS_HOME. This might be a different location, depending on your installation type
    make # This requires the environment variable WEBOTS_HOME to be set
    

Run the Demo

  1. Open the robocup.wbt world file in Webots and run it until you see the GameController window showing up.
    GAME_CONTROLLER_HOME=/path/to/GameController JAVA_HOME=/usr webots ./worlds/robocup.wbt
    
    You have to pass the environment variables GAME_CONTROLLER_HOME which points to the GameController folder and JAVA_HOME which points to your Java installation (which might be under /usr).
  2. You can manually move the robots and the ball using the mouse (Shift-right-click-and-drag).
  3. Launch the sample robot controller client.cpp by typing ./client in the controllers/player folder.
  4. The sample client program will simply move the neck of one of the Darwin-OP robot.

Modify the Game and Teams Configuration

  1. Quit Webots.
  2. Edit the game.json file to change the game configuration. The ports in this file are where the API server will open ports and the API servers will only accept traffic from the whitelisted IP, i.e. you might want to change the IPs to 127.0.0.1 for a local setup.
  3. Edit the team_1.json and team_2.json files to change the teams configuration.
  4. Restart the simulation.

Program your Own Robot Controllers

  1. Update the game.json configuration file and create your own team configuration files, taking inspiration from team_1.json and team_2.json.
  2. Create your own robot controllers, taking inspiration from the sample client.cpp.

Create your Own Robot Model

Create your robot model in the protos folder taking inspiration from RobocupRobot.proto and adjust your team configuration file accordingly.

Exposed Parameters

Your proto should have the following exposed parameters:

PROTO MyOwnRobocupRobot [
  field SFVec3f                 translation    0 0 0   # Is `Transform.translation`.
  field SFRotation              rotation       0 0 1 0 # Is `Transform.rotation`.
  field SFString                name           ""      # Is `Solid.name`.
  field MFString                controllerArgs []      # Is `Robot.controllerArgs`.
]
{
  Robot {
    translation IS translation
    rotation IS rotation
    name IS name
    controllerArgs IS controllerArgs}
}

Creating a Jersey with the Correct Color and Player Number

The team color and player number of each robot is set by the referee in the name field of the robot when spawning it. It can takes values like "red player 1" or "blue player 3", etc. You should therefore parse this name field to determine the team color and player number of your robot:

  if fields.name.value ~= '' then
    -- name is supposed to be something like "red player 2" or "blue player 1"
    local words = {}
    for word in fields.name.value:gmatch("%w+") do table.insert(words, word) end
    local color = words[1]
    local number = words[3]

Then, the color and number variables should be used by your PROTO file to display the requested color and player number on the jersey of the robot. This can be achieved by forging a texture name from these variables or using them directly to assign material colors, create shapes, etc. More information about Webots PROTO is available from the Webots Reference Manual.

Add Body Part Tags

The referee needs to identify the different parts of your robot to apply the rules of the game. These parts include the foot, arms, legs, head, etc. In order to identify each part, you should set the model field of each Solid (or derived) node composing your robot with one of the following strings: "foot", "arm", "shoulder", "hip".

Continuous Integration Tests

By default, the referee supervisor will read the game.json file from its local folder. However, if a special environment variable is set, it will use it to load a different game.json file:

export WEBOTS_ROBOCUP_GAME="/path/to/my/special/game.json"

In order to facilitate Continuous Integration (CI) tests, a number of options are available in the game.json file:

{
  "side_left": "red",
  "kickoff": "blue",
  "supervisor": "MyTestSupervisor"
}
  • "left_side" is used to determine which team will play on the left side of the field (x < 0). It can take the following values: "red", "blue", "random". The default value is "random".
  • "kickoff" is used to determine which team has the initial kickoff. It can take the same values as the "left_side" field.
  • "supervisor" is used to define an optional extra supervisor controller process that will run in parallel with the referee. This extra supervisor controller will be spawned by the referee at the beginning of the game. The following new node with be added to the scene after the referee robot: Robot { supervisor TRUE controller "MyTestSupervisor" }.

Model verifier

A semi-automated tool allowing to check if a robot respects the rules is available in the controllers/model_verifier directory. The available scripts are documented in a dedicated README.

game.json settings

Multiple variables can be set to influence the behavior of the simulation.

record_simulation: a file path to where the simulation should be recorded. If it ends in .html a 3D recording is made. If it ends in .mp4 a video from the default perspective is generated.

press_a_key_to_terminate: true or false, allows pressing a key to cleanly end the simulation and save the recording (used for testing)

game_controller_extra_args: used to pass arguments to the game controller, for example

  "game_controller_extra_args": [
    "--halftimeduration",
    "120",
    "--overtimeduration",
    "60"
  ],

can be used to reduce halftime duration.

texture_seed: can be set to an integer to set the random seed used for texture (background, background luminosity, and ball)

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 81.5%
  • C++ 14.3%
  • Shell 3.3%
  • Makefile 0.9%