This package is the ROS 2 port of http://wiki.ros.org/topic_tools
Tools for directing, throttling, selecting, and otherwise manipulating ROS 2 topics at a meta-level. These tools do not generally perform serialization on the streams being manipulated, instead acting on generic binary data using rclcpp
's GenericPublisher
and GenericSubscription
.
The tools in this package are provided as composable ROS 2 component nodes, so that they can be spawned into an existing process, launched from launchfiles, or invoked from the command line.
Relay is ROS 2 node that subscribes to a topic and republishes all incoming data to another topic. It can work with any message type.
ros2 run topic_tools relay <intopic> [outtopic]
Subscribe to intopic
and republish to either
outtopic
if specified<intopic>_relay
if not
E.g. rename base_scan
to my_base_scan
:
ros2 run topic_tools relay base_scan my_base_scan
input_topic
(string)- the same as if provided as a command line argument
output_topic
(string, default=<input_topic>_relay
)- the same as if provided as a command line argument
lazy
(bool, default=False)- If True, only subscribe to
input_topic
if there is at least one subscriber on theoutput_topic
- If True, only subscribe to
RelayField is a ROS 2 node that allows to republish data in a different message type
ros2 run topic_tools transform <input topic> <output topic> <output type> [<expression on m>] [--import <modules>] [--field <topic_field>]
Subscribe to input topic
and republish one or many of its fields onto another field in a different message type
E.g. publish the contents of the data
field in a std_msgs/msg/String
onto the frame_id
field of a std_msgs/msg/Header
:
ros2 run topic_tools relay_field /chatter /header std_msgs/Header "{stamp: {sec: 0, nanosec: 0}, frame_id: m.data}"
Transform is a ROS 2 node that allows to take a topic or one of it fields and output it on another topic
ros2 run topic_tools transform <input topic> <output topic> <output type> [<expression on m>] [--import <modules>] [--field <topic_field>]
Subscribe to input topic
and convert topic content or its field into
output topic
whose type isoutput type
based onexpression on m
E.g. transform imu
orientation to norm
:
ros2 run topic_tools transform /imu --field orientation /norm std_msgs/Float64 'std_msgs.msg.Float64(data=numpy.sqrt(numpy.sum(numpy.array([m.x, m.y, m.z, m.w]))))' --import std_msgs numpy
Throttle is ROS 2 node that subscribes to a topic and republishes incoming data to another topic, either at a maximum bandwidth or maximum message rate.
ros2 run topic_tools throttle messages <intopic> <msgs_per_sec> [outtopic]
Throttle messages on intopic
to a particular rate.
intopic
: Incoming topic to subscribe tomsgs_per_sec
: maximum messages per second to let through.outtopic
: Outgoing topic to publish on (default: intopic_throttle)
E.g. throttle bandwidth-hogging laser scans (base_scan) to 1Hz:
ros2 run topic_tools throttle messages base_scan 1.0
ros2 run topic_tools throttle bytes <intopic> <bytes_per_sec> <window> [outtopic]
Throttle messages on intopic
to a particular rate.
intopic
: Incoming topic to subscribe tomsgs_per_sec
: maximum messages per second to let through.outtopic
: Outgoing topic to publish on (default: intopic_throttle)
E.g. throttle bandwidth-hogging laser scans (base_scan) to 1KBps:
ros2 run topic_tools throttle bytes base_scan 1024 1.0
input_topic
(string)- the same as if provided as a command line argument
output_topic
(string, default=<input_topic>_throttle
)- the same as if provided as a command line argument
lazy
(bool, default=False)- If True, only subscribe to
input_topic
if there is at least one subscriber on theoutput_topic
- If True, only subscribe to
use_wall_clock
(bool, default=False)- If True, then perform all rate measurements against wall clock time, regardless of whether simulation / log time is in effect.
Drop is ROS 2 node that can subscribe to a topic and republish incoming data to another topic, dropping X out of every Y incoming messages. It's mainly useful for limiting bandwidth usage, e.g., over a wireless link. It can work with any message type.
ros2 run topic_tools drop <intopic> <X> <Y> [outtopic]
Subscribe to and drop every out of messages.
intopic
: Incoming topic to subscribe toX
,Y
: drop X out of every Y incoming messagesouttopic
: Outgoing topic to publish on (default:intopic
_drop, e.g. when intopic is "base_scan", then it will be base_scan_drop)
E.g. drop every other message published to base_scan:
ros2 run topic_tools drop base_scan 1 2
input_topic
(string)- the same as if provided as a command line argument
output_topic
(string, default=<input_topic>_drop
)- the same as if provided as a command line argument
lazy
(bool, default=False)- If True, only subscribe to
input_topic
if there is at least one subscriber on theoutput_topic
- If True, only subscribe to
X
,Y
(int)- drop X out of every Y incoming messages
mux is a ROS2 node that subscribes to a set of incoming topics and republishes incoming data from one of them to another topic, i.e., it's a multiplexer that switches an output among 1 of N inputs. Services are offered to switch among input topics, and to add and delete input topics. At startup, the first input topic on the command line is selected.
ros2 run topic_tools mux <outopic> <intopic1> [intopic2...]
Subscribe to ...N and publish currently selected topic to outopic. mux will start with selected.
outtopic
: Outgoing topic to publish onintopicN
: Incoming topic to subscribe to
E.g. mux two command streams (auto_cmdvel and joystick_cmdvel) into one (sel_cmdvel):
ros2 run topic_tools topic_tools mux sel_cmdvel auto_cmdvel joystick_cmdvel
input_topics
(string array)- the same as if provided as a command line argument
output_topic
(string, default=~/selected
)- the same as if provided as a command line argument
lazy
(bool, default=False)- If True, only subscribe to
input_topic
if there is at least one subscriber on theoutput_topic
- If True, only subscribe to
initial_topic
(str)- Input topic to select on startup. If __none, start with no input topic. If unset, default to first topic in arguments