Using ZED with ROS 2 and Isaac Sim
This tutorial guides you to configure the Isaac Sim ROS 2 Bridge to send simulated information to a ZED ROS 2 Wrapper node.
Install the dependencies #
📌 Note: the installation guide is valid only for Ubuntu. For other OS please refer to the official NVIDIA®documentation.
The Isaac Sim ROS 2 Bridge requires the Vision Messages ROS 2 package to run. You can install it by using the command
sudo apt install ros-humble-vision-msgs
If this dependency is not installed the ROS 2 Bridge extension will not start, and you will get an error message similar to this in the Isaac Sim log terminal:
2023-11-24 16:04:22 [73,377ms] [Error] [omni.isaac.ros2_bridge.plugin] Could not load ROS2 Bridge due to missing library dependencies, please make sure your sourced ROS2 workspace has the correct packages/libraries installed
[73.388s] To use the internal libraries included with the extension please set:
RMW_IMPLEMENTATION=rmw_fastrtps_cpp
LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/home/<user>/.local/share/ov/pkg/isaac_sim-2023.1.0-hotfix.1/exts/omni.isaac.ros2_bridge/humble/lib
Before starting Isaac Sim
2023-11-24 16:04:22 [73,377ms] [Error] [omni.isaac.ros2_bridge.scripts.extension] ROS2 Bridge startup failed
IMPORTANT: do not add the new path to LD_LIBRARY_PATH
in ~/.bashrc
as suggested, otherwise you will create conflicts between libraries that will not allow you to start rviz2
and other ROS 2 tools.
For additional details, we recommend reading the official NVIDIA®documentation.
Setup the environment variables for ROS 2 #
Ensure that the ROS environment is sourced in the terminal or in your ~/.bashrc
file before starting Isaac Sim:
source /opt/ros/humble/setup.bash
📌 Note: if you want to launch Isaac Sim by using the Omniverse Launcher it is required that you add the line
source /opt/ros/humble/setup.bash
to~/.bashrc
to automatically configure the ROS 2 environment variables each time you open a terminal console. Otherwise, you must launch that command in the terminal console before manually starting Isaac Sim with the commandisaac-sim.sh
which is located in the folder~/.local/share/ov/pkg/isaac_sim-<version>/
.
Initialize the simulator #
First of all, remember to select the correct ROS Bridge Extension
when starting Isaac Sim: omni.isaac.ros2_bridge
Enable the ROS 2 Bridge Extension #
When Isaac Sim is ready you must enable the ROS2 Bridge
extension.
- Open the Extension view from the menu, Window -> Extensions.
- Search for
ROS2 Bridge
by using the search form in the top left. - Click the
DISABLED
switch to set it toENABLED
. - [Optional] Flag the
AUTOLOAD
option to avoid performing these initialization steps each time you start Isaac Sim.
Enable the ZED Extension #
The ZED Camera Extension is required to send the simulated ZED images to the ZED ROS 2 Wrapper.
- Open the Extension view from the menu, Window -> Extensions.
- Search for “ZED” by using the search form in the top left.
- Select
THIRD PARTY
if you have installed the extension from the GitHub repository (see here for adding the extension if it’s not available).
- Select
- Click the
DISABLED
switch to set it toENABLED
. - [Optional] Flag the
AUTOLOAD
option to avoid performing these initialization steps each time you start Isaac Sim.
Add a scenario to the Stage #
The ZED camera is a visual sensor, so it’s important to add an environment that is rich in visual features for a good simulation experience.
Isaac Sim provides ready environments to be used, from Create -> Isaac -> Environments you can select for example the environment named Small Warehouse with Multiple Shelves
.
If you are using Nucleus and you created a local server, a web page will open with a form to insert some user credentials. If it’s the first that you use it, you must create a new user, and then use the new credentials to login to the server.
Wait for the simulator to load the environment. This task can take a while, according to the dimension of the environment that you selected.
When all the object of the scene are finally loaded, the simulator will display the selected environment from the default point of view of the viewport camera.
Add a ZED camera to the scene #
The ZED X model will be available in the Isaac Assets tab on the bottom panel, with the latest versions of the Isaac Sim app.
If you cannot find the ZED X Model, then you can manually add it by cloning the GitHub repository:
cd <your_workspace>
git clone git@github.com:stereolabs/zed-isaac-sim.git
Select the model ZED_X.usd and drag it in the Viewport to place it in the position that you prefer.
A new prim named ZED_X
will appear in the Stage
view as a child of World
.
The ZED_X
prim has an important XForm named base_link
, this is the reference frame of the mounting point on the bottom of the camera.
Enable the ZED camera #
The data streaming is activated by using the Omnigraph node ZED Camera streamer.
- Create a new
Action Graph
, Create -> Visual Scripting -> Action Graph. - Add a new node of type
On Playback Tick
to the graph. You can easily search for it by writingTick
in the search form. - Type
ZED
in the search form and drag theZED Camera Streamer
node into the graph. - Connect the
ExecIn
input ofZED Camera Streamer
to theTick
output of theOn Playback Tick
node.
- Click on the
ZED Camera Streamer
in the graph and select theProperty
tab on the right. - Click
+ Add Target
nearZED Camera prim
. - Select the root XForm named
ZED_X
and hitSelect
.
Publish simulation time to ROS 2 #
When working with simulated data, the ROS 2 nodes cannot rely on the system clock to timestamp the data accurately. Instead, they have to use the simulation time, which can be faster or slower than the real time.
To handle this behavior, Isaac Sim ROS 2 Bridge provides a method to publish messages to the /clock
topic with simulation time data.
All the ROS 2 nodes have a parameter named use_sim_time
. When this parameter is set to true
, each ROS 2 node subscribes to the /clock
topic, and uses the simulation time as the reference for time instead of the system time.
- Select the
Action Graph
tab in the bottom panel. - Add a new node of type
Isaac Read Simulation Time
.- [Optional] Click on the
Isaac Read Simulation Time
. - [Optional] Select the
Properties
tab in the right panel. - [Optional] Check the
Reset on stop
option to reset to zero the simulation time each time the simulation is stopped and restarted.
- [Optional] Click on the
- Add a new node of type
ROS2 Publish Clock
. - Connect the
Tick
output of theOn Playback Tick
node to theExecIn
input ofROS2 Publish Clock
. - Connect the
Simulation Time
output of theIsaac Read Simulation Time
node to theTime Stamp
input ofROS2 Publish Clock
.
- Start the simulation by hitting the Play button on the left panel
Now you can verify that the configuration is valid:
- open a Terminal console (
Ctrl + Alt + t
). - enter the command
ros2 topic echo /clock
. - verify that the
/clock
topic is correctly published:
$ ros2 topic echo /clock
clock:
sec: 6
nanosec: 900000359
---
clock:
sec: 6
nanosec: 916667027
---
clock:
sec: 6
nanosec: 933333694
---
clock:
sec: 6
nanosec: 950000362
---
[...]
- stop listening to the
/clock
topic withCtrl+c
.
Start the ZED ROS 2 Wrapper node with simulated data #
The ZED ROS 2 Wrapper enables connection to the ZED Isaac Sim Extension, publishing ZED data in ROS 2 as if a real camera is present.
Prerequisites #
The “ZED ROS 2 Wrapper” and the “ZED ROS 2 Examples” packages must be installed in the system.
Follow the relative guides to install them if not already done:
Launch the ZED ROS 2 node #
Launch a standalone ZED ROS 2 node with simulated ZED data as input:
ros2 launch zed_wrapper zed_camera.launch.py camera_model:=zedx sim_mode:=true use_sim_time:=true
Launch options:
- [Mandatory]
sim_mode
: start the ZED node in simulation mode iftrue
. - [Mandatory]
use_sim_time
: force the node to wait for valid messages on the topic/clock
, and use the simulation time as the reference. - [Optional]
sim_address
: set the address of the simulation server. Default is127.0.0.1
and it’s valid if the node runs on the same machine as the simulator. - [Optional]
sim_port
: set the port of the simulation server. It must match the value of the fieldStreaming Port
of the properties of theZED camera streamer
Action Graph node. A differentStreaming Port
value for each camera is required in multi-camera simulations.
camera_model
is currently limited tozedx
. We are working to support other models in the near future.
You can also start a preconfigured instance of rviz2
to visualize all the information available in simulation by using the command:
ros2 launch zed_display_rviz2 display_zed_cam.launch.py camera_model:=zedx sim_mode:=true use_sim_time:=true
the display_zed_cam.launch.py
launch file includes the zed_camera.launch.py
launch file, so it provides the same parameters.
You can get the list of all the available launch parameters by using the -s
launch option:
$ ros2 launch zed_wrapper zed_camera.launch.py -s
$ ros2 launch zed_display_rviz2 display_zed_cam.launch.py -s
Here’s an example of rviz2
running with the simulated information obtained by placing the ZED camera on a shelf of a simulated warehouse: