• Stars
    star
    131
  • Rank 275,867 (Top 6 %)
  • Language
    Python
  • License
    Apache License 2.0
  • Created over 6 years ago
  • Updated 9 months ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

Utility to convert URDF files to Webots PROTO nodes

urdf2webots

Test Status PyPI version

This tool converts URDF files into Webots PROTO files or into Webots Robot node strings. Python 3.5 or higher is required.

Install

From pip

pip install urdf2webots

On macOS, export the pip binary path to the PATH: export PATH="/Users/$USER/Library/Python/3.7/bin:$PATH"

From Sources

git clone --recurse-submodules https://github.com/cyberbotics/urdf2webots.git
pip install --upgrade --editable urdf2webots

Usage

From pip

python -m urdf2webots.importer --input=someRobot.urdf [--output=outputFile] [--normal] [--box-collision] [--tool-slot=linkName] [--help]

Arguments

The script accepts the following arguments:

  • -h, --help: Show the help message and exit.
  • --input=INPUT: Specifies the URDF file to convert.
  • --output=OUTPUT: If set, specifies the path and, if ending in ".proto", name of the resulting PROTO file. The filename minus the .proto extension will be the robot name (for PROTO conversion only).
  • --robot-name: Specify the name of the robot and generate a Robot node string instead of a PROTO file (has to be unique).
  • --normal: If set, the normals are exported if present in the URDF definition.
  • --box-collision: If set, the bounding objects are approximated using boxes.
  • --tool-slot=LinkName: Specify the link that you want to add a tool slot to (exact link name from URDF, for PROTO conversion only).
  • --translation="0 0 0": Set the translation field of the PROTO file or Webots Robot node string.
  • --rotation="0 0 1 0": Set the rotation field of the PROTO file or Webots Robot node string.
  • --init-pos=JointPositions: Set the initial positions of your robot joints. Example: --init-pos="[1.2, 0.5, -1.5]" would set the first 3 joints of your robot to the specified values, and leave the rest with their default value.
  • --link-to-def: Creates a DEF with the link name for each solid to be able to access it using getFromProtoDef(defName) (for PROTO conversion only).
  • --joint-to-def: Creates a DEF with the joint name for each joint to be able to access it using getFromProtoDef(defName) (for PROTO conversion only).
  • --relative-path-prefix: If --input is not set, the relative paths in your URDF file sent through stdin will use this prefix. For example: filename="head.obj" with --relative-path-prefix="/home/user/myRobot/" will become filename="/home/user/myRobot/head.obj".

In case the --input option is missing, the script will read the URDF content from stdin. In that case, you can pipe the content of your URDF file into the script: cat my_robot.urdf | urdf2proto.py. Relative paths present in your URDF file will be treated relatively to the current directory from which the script is called unless --relative-path-prefix is set.

Previously the --static-base argument was supported in order to set the base link to be static (disabled physics). It has been removed as there is a better way to do it by adding the following to your URDF file (assuming base_link is the root link of your robot):

<link name="world" />
<joint name="world_joint" type="fixed">
   <parent link="world" />
   <child link="base_link" />
</joint>

In your Python Code

Arguments

The command line arguments available from the terminal are also available from the Python interface, but some have different names:

Terminal Python
--input input
--output output
--robot-name robotName
--normal normal
--box-collision boxCollision
--tool-slot toolSlot
--translation initTranslation
--rotation initRotation
--init-pos initPos
--link-to-def linkToDef
--joint-to-def jointToDef
--relative-path-prefix relativePathPrefix

In Python, you can convert a URDF file by passing its path as an argument to the convertUrdfFile() function or directly by passing its content as an argument to the convertUrdfContent() function.

Convert into Webots PROTO files

from urdf2webots.importer import convertUrdfFile
convertUrdfFile(input = 'MY_PATH/MY_URDF.urdf')

or

import pathlib
from urdf2webots.importer import convertUrdfContent
robot_description = pathlib.Path('MY_PATH/MY_URDF.urdf').read_text()
convertUrdfContent(input = robot_description)

Convert into Webots Robot node strings

from urdf2webots.importer import convertUrdfFile
convertUrdfFile(input = 'MY_PATH/MY_URDF.urdf', robotName="myRobot")

or

import pathlib
from urdf2webots.importer import convertUrdfContent
robot_description = pathlib.Path('MY_PATH/MY_URDF.urdf').read_text()
convertUrdfContent(input = robot_description, robotName="myRobot")

In-Depth Tutorial

Check out this tutorial for a more in-depth, step by step instruction, on how to:

  • Generate a URDF file from a ROS repository.
  • Convert your URDF file to a Webots PROTO file.
  • Load your converted model into Webots and make final adjustments.
  • Convert your URDF file to a Webots Robot string and import it.

Notes

This tool was tested using Webots R2022b on Ubuntu22.04. You can find the sources of these URDF files here:

Acknowledgements

rosin_logo

Supported by ROSIN - ROS-Industrial Quality-Assured Robot Software Components. More information: rosin-project.eu

eu_flag

This project has received funding from the European Unionโ€™s Horizon 2020 research and innovation programme under grant agreement no. 732287.


opendr_logo

Supported by OpenDR - Open Deep Learning Toolkit for Robotics. More information: opendr.eu

eu_flag

This project has received funding from the European Unionโ€™s Horizon 2020 research and innovation programme under grant agreement no. 871449.

More Repositories

1

webots

Webots Robot Simulator
C++
3,231
star
2

webots_ros2

Webots ROS 2 packages
C
404
star
3

webots_ros

Webots ROS package
C++
88
star
4

epuck_ros2

ROS2 node for the e-puck robot and its simulation model
C++
58
star
5

wrestling

Humanoid robot wrestling competition
Python
48
star
6

pyikfast

Python bindings for the `ikfast` library and utilities to generate the analytical inverse kinematics solution
C++
42
star
7

blender-webots-exporter

Blender add-on to export Webots files
Python
38
star
8

community-projects

Webots projects (PROTO files, controllers, simulation worlds, etc.) contributed by the community.
28
star
9

naoqisim

NAOqi enabled controller for simulated NAO robots in Webots
C++
23
star
10

robot-designer

Web robot designer for Webots robotics simulator
JavaScript
21
star
11

webots-docker

This repository is used to build GPU accelerated docker images of the Webots open-source robot simulator.
Dockerfile
15
star
12

webots-animation-action

Create and publish animated robot simulation with GitHub Action
Python
13
star
13

webots-server

Repository containing necessary files to run a server able to run Webots simulation
Python
9
star
14

webots-projects

Additional Webots projects (PROTO files, controllers, simulation worlds, etc.) officially released by Cyberbotics.
Python
7
star
15

competition-template

Generate a copy of this repository to create your own competition
HTML
6
star
16

webots-doc

Documentation for the Webots software
JavaScript
5
star
17

webots-cloud-simulation-template

Template repository of a simulation deployed on webots.cloud
C
5
star
18

webots-cloud-simulation-examples

Repository hosting simulations samples for webots.cloud
C
4
star
19

AROSYS

This repository allows to use the Webots simulator in the SmartMDSD Toolchain
C++
4
star
20

webots-snap

This is the snapcraft repository used by snapcraft.io to build the Webots snap package for Linux
Shell
3
star
21

simgait

SimGait.org
JavaScript
3
star
22

robot-programming-competition-disabled

HTML
3
star
23

wrestling-fatima

Controller example for the Humanoid Robot Wrestling Competition. Demonstrates the gait manager (inverse kinematics + simple ellipsoid path)
Python
2
star
24

optima

C++
2
star
25

webots-cloud

JavaScript
2
star
26

wrestling-alice-ros-2

Minimalist ROS 2 controller example for the Humanoid Robot Wrestling Competition.
Python
2
star
27

webots-animation-template

Webots project template that generates Webots animation previews with GitHub Actions
Python
2
star
28

pit-escape-competition

Webots competition. Program a BB-8 robot lost in a sand desert to climb out of a pit as quickly as possible.
HTML
2
star
29

webots-competition-organizer-template

Python
2
star
30

webots_ros2-release

Webots ROS 2 release repository
1
star
31

syllabus

HTML
1
star
32

wrestling-eve

Controller example for the Robot Wrestling Tournament. Demonstrates how to use the camera.
Jupyter Notebook
1
star
33

HsWebots

Webots bindings for Haskell
Haskell
1
star
34

webots-competition-competitor-template

Python
1
star
35

robot-programming-competition

Learn how to program to perform some simple task
HTML
1
star
36

wall-following-competition

Program a Pioneer 3-DX robot to follow a random wall on its left-hand side, quickly and precisely.
C
1
star
37

visual-tracking-competition

Program an Aibo robot to move its head to track a rubber duck moving in a scattered environment
Python
1
star