This repository contains packages to support the interoperability between BeamNG.tech and ROS2. BeamNG.tech is a driving simulation platform, suitable for commercial and academic use. Inquiries for academic use can be made through our registration form. For inquiries regarding commercial use, contact us at [email protected].
The documentation is generated using rosdoc2
and can be found at https://beamngpy.readthedocs.io/en/latest/_static/beamng_ros2.
The list of ROS2 messages, services and actions is also available online.
The BeamNG ROS2 integration includes support for the remote control of the simulation platform, attaching sensors to vehicles (using scenario files), and getting the sensor data from vehicles.
For using the BeamNG ROS2 integration, a BeamNG.tech build and a Python environment with BeamNGpy installed are required. BeamNGpy has to have compatible version with the BeamNG.tech installation.
For sensor shared memory support, BeamNG.tech and ROS have to be running on the same machine and the same operating system (Windows Subsystem for Linux will not work with shared memory). Shared memory on Linux is not working in the current BeamNG.tech release and the support will come in the next major update.
The BeamNG ROS2 integration is tested with the following ROS2 distributions: Foxy Fitzroy and Humble Hawksbill.
- Setup your ROS2 Humble/Foxy workspace.
- Clone this repository into your ROS2 workspace.
- Use rosdep to install the dependencies for the package.
- Install
beamngpy
using pip or conda in the Python environment you use to run the ROS2 nodes. - To run the bridge, run
ros2 run beamng_ros2 beamng_bridge
.
If available, BeamNG-ROS2 will use the python-rapidjson
library to support JSON files which do not strictly follow the standard:
pip install python-rapidjson
To use this project, a basic knowledge of the BeamNG.tech simulator and the BeamNGpy is neccessary. We recommend to familiarize yourself first with BeamNGpy to get a basic understanding of the platform before using the BeamNG ROS2 Integration.
- After setting up BeamNG.tech and BeamNGpy with a Python environment, the simulation needs to be listening on the BeamNGpy socket. To do that, you can run the executable with the following arguments:
Command prompt (cmd.exe
):
Bin64\BeamNG.tech.x64.exe -console -nosteam -tcom-listen-ip <LISTEN_IP> -lua extensions.tech_techCore.openServer(25252)
PowerShell:
Bin64\BeamNG.tech.x64.exe -console -nosteam -tcom-listen-ip <LISTEN_IP> -lua "extensions.tech_techCore.openServer(25252)"
Linux Terminal:
BinLinux/BeamNG.tech.x64 -nosteam -tcom-listen-ip <LISTEN_IP> -lua "extensions.tech_techCore.openServer(25252)"
<LISTEN_IP>
will be 127.0.0.1
in the case of running BeamNG.tech on the same machine and operating system as the ROS2 interface. If you are running ROS2 using WSL or want to connect to a remote machine, you need to set the listen IP to the one of the corresponding network interface.
- The ROS2 packages from this repository need to be added and built in your colcon workspace. See the ROS2 tutorials for more information on how to set up a colcon workspace.
If you use ROS2 on Windows (without WSL), the
rosdep
command does not work, you will have to skip installing dependencies or install them manually. The integration should still work on that configuration.
source /opt/ros/humble/setup.bash
cd ~/ros2_ws/src
git clone https://github.com/BeamNG/beamng-ros2-integration.git
cd ~/ros2_ws
rosdep install -i --from-path src --rosdistro humble -y
colcon build # or colcon build --symlink-install
- A node connecting ROS2 to the simulation can be started using the
ros2 run
command:
ros2 run beamng_ros2 beamng_bridge
It needs to be configured to contain the correct IP address of the machine hosting the simulation.
- After running the bridge, you can set the IP address of the BeamNG host by calling:
ros2 param set /beamng_bridge host <BEAMNG_ADDRESS>
- To operate the node, you can use the exposed services, you can find their list in https://beamngpy.readthedocs.io/en/latest/_static/beamng_msgs/interfaces/service_definitions.html. Getting access to sensor data requires you to launch a scenario using the StartScenario service:
ros2 service call /beamng_bridge/start_scenario beamng_msgs/srv/StartScenario "{path_to_scenario_definition: '/config/scenarios/example_tech_ground.json'}"
Using it will start up a node that connects to the simulation and starts up a scenario as defined in the beamng_ros2/config/scenarios/example_tech_ground.json
.
Other scenario specifications are available in the same directory.
Running the BeamNG ROS2 integration requires three individual software components, here is a list of compatible versions.
BeamNG.tech | BeamNGpy | BeamNG ROS2 Integration |
---|---|---|
0.34 | 1.31 | 1.2.0 |
0.33 | 1.30 | 1.1.0 |
0.32 | 1.29 | 1.0.0 |
This section lists common issues with BeamNG ROS2 Integration in particular. Since this library is closely tied to BeamNG.tech and thus BeamNG.drive, it is also recommended to consult the documentation on BeamNG.drive here:
https://documentation.beamng.com/
These are issues that we are working on and there is no need to report them:
- Lidar sensor may cause the simulation to crash.
- The integration is using a single thread causing unoptimal performance.
- BeamNGpy is not threadsafe at the moment.
We always welcome user contributions, be sure to check out our contribution guidelines first, before starting your work.
The Python code is formatted using Black, please use it to format the code you want to contribute.