Package symbol

autoware_agnocast_wrapper package from autoware_core repo

autoware_adapi_adaptors autoware_adapi_specs autoware_core_api autoware_default_adapi autoware_core autoware_agnocast_wrapper autoware_component_interface_specs autoware_geography_utils autoware_global_parameter_loader autoware_interpolation autoware_kalman_filter autoware_lanelet2_utils autoware_marker_utils autoware_motion_utils autoware_node autoware_object_recognition_utils autoware_osqp_interface autoware_point_types autoware_qos_utils autoware_qp_interface autoware_signal_processing autoware_trajectory autoware_vehicle_info_utils autoware_core_control autoware_simple_pure_pursuit autoware_awsim_sensor_kit_description autoware_sample_sensor_kit_description autoware_sample_vehicle_description autoware_core_localization autoware_ekf_localizer autoware_gyro_odometer autoware_localization_util autoware_ndt_scan_matcher autoware_pose_initializer autoware_stop_filter autoware_twist2accel autoware_core_map autoware_lanelet2_map_visualizer autoware_map_height_fitter autoware_map_loader autoware_map_projection_loader autoware_core_perception autoware_euclidean_cluster_object_detector autoware_ground_filter autoware_perception_objects_converter autoware_core_planning autoware_mission_planner autoware_objects_of_interest_marker_interface autoware_path_generator autoware_planning_factor_interface autoware_planning_topic_converter autoware_route_handler autoware_velocity_smoother autoware_behavior_velocity_planner autoware_behavior_velocity_planner_common autoware_behavior_velocity_stop_line_module autoware_motion_velocity_obstacle_stop_module autoware_motion_velocity_planner autoware_motion_velocity_planner_common autoware_core_sensing autoware_crop_box_filter autoware_downsample_filters autoware_gnss_poser autoware_vehicle_velocity_converter autoware_planning_test_manager autoware_pyplot autoware_test_node autoware_test_utils autoware_testing autoware_core_vehicle

ROS Distro
humble

Package Summary

Version 1.8.0
License Apache License 2.0
Build type AMENT_CMAKE
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/autowarefoundation/autoware_core.git
VCS Type git
VCS Version main
Last Updated 2026-05-12
Dev Status DEVELOPED
Released RELEASED
Contributing Help Wanted (-)
Good First Issues (-)
Pull Requests to Review (-)

Package Description

Wrapper macros for Agnocast (true zero-copy communication library)

Maintainers

  • Takahiro Ishikawa-Aso
  • Koichi Imai
  • Atsushi Yano

Authors

No additional authors.

autoware_agnocast_wrapper

The purpose of this package is to integrate Agnocast, a zero-copy middleware, into each topic in Autoware with minimal side effects. Agnocast is a library designed to work alongside ROS 2, enabling true zero-copy publish/subscribe communication for all ROS 2 message types, including unsized message types.

This package provides macros that wrap functions for publish/subscribe operations and smart pointer types for handling ROS 2 messages. When Autoware is built using the default build command, Agnocast is not enabled. However, setting the environment variable ENABLE_AGNOCAST=1 enables Agnocast and results in a build that includes its integration. This design ensures backward compatibility for users who are unaware of Agnocast, minimizing disruption.

Two Integration Approaches

This package provides two approaches for integrating Agnocast. Both will coexist for the foreseeable future.

1. Node Wrapper (agnocast_wrapper::Node)

Use this when you want the entire node to transparently switch between rclcpp::Node and agnocast::Node at runtime. The node wrapper automatically selects the correct underlying implementation based on the ENABLE_AGNOCAST environment variable.

Currently supported APIs:

  • Publisher / Subscription / PollingSubscriber
  • Parameters
  • Logger, Clock
  • Callback groups
  • Node interfaces (partial: get_node_base_interface(), get_node_topics_interface(), get_node_parameters_interface())

Note: Timer (create_wall_timer, create_timer) is not yet supported and will be added in a future update.

#include <autoware/agnocast_wrapper/node.hpp>

class MyNode : public autoware::agnocast_wrapper::Node
{
public:
  explicit MyNode(const rclcpp::NodeOptions & options)
  : Node("my_node", options)
  {
    pub_ = create_publisher<std_msgs::msg::String>("output", 10);
    sub_ = create_subscription<std_msgs::msg::String>(
      "input", 10, [this](std::unique_ptr<const std_msgs::msg::String> msg) { /* ... */ });
  }

private:
  autoware::agnocast_wrapper::Publisher<std_msgs::msg::String>::SharedPtr pub_;
  autoware::agnocast_wrapper::Subscription<std_msgs::msg::String>::SharedPtr sub_;
};

To use the Node wrapper in your package, add the following to your CMakeLists.txt:

find_package(autoware_agnocast_wrapper REQUIRED)
ament_target_dependencies(my_node_component autoware_agnocast_wrapper)

Registering a Node with autoware_agnocast_wrapper_register_node

Instead of calling rclcpp_components_register_node directly, use the autoware_agnocast_wrapper_register_node macro to register your component node. This macro:

  1. Registers the component with rclcpp_components (for component container support)
  2. Creates a standalone executable that can switch between rclcpp::Node and agnocast::Node at runtime based on the ENABLE_AGNOCAST environment variable

When ENABLE_AGNOCAST is not set or set to 0, this macro falls back to standard rclcpp_components_register_node behavior.

find_package(autoware_agnocast_wrapper REQUIRED)

ament_auto_add_library(my_node_component SHARED src/my_node.cpp)
ament_target_dependencies(my_node_component autoware_agnocast_wrapper)

autoware_agnocast_wrapper_register_node(my_node_component
  PLUGIN "my_package::MyNode"
  EXECUTABLE my_node
)

Parameters:

Parameter Required Default Description
PLUGIN Yes - Fully qualified class name of the component
EXECUTABLE Yes - Executable name for the node
ROS2_EXECUTOR No SingleThreadedExecutor Executor to use when ENABLE_AGNOCAST=0 at runtime
AGNOCAST_EXECUTOR No SingleThreadedAgnocastExecutor Executor to use when ENABLE_AGNOCAST=1 at runtime

Valid executor values:

  • ROS2_EXECUTOR: SingleThreadedExecutor, MultiThreadedExecutor
  • AGNOCAST_EXECUTOR: SingleThreadedAgnocastExecutor, MultiThreadedAgnocastExecutor, CallbackIsolatedAgnocastExecutor, AgnocastOnlySingleThreadedExecutor, AgnocastOnlyMultiThreadedExecutor, AgnocastOnlyCallbackIsolatedExecutor

Node class requirements:

The required PLUGIN base class depends on the AGNOCAST_EXECUTOR type. The generated template enforces this via if constexpr at compile time:

AGNOCAST_EXECUTOR Required PLUGIN base class
AgnocastOnly* executors autoware::agnocast_wrapper::Node
Other agnocast executors Any rclcpp::Node-compatible class

Non-AgnocastOnly executors use NodeInstanceWrapper::get_node_base_interface() directly, which works with any node type (rclcpp::Node, agnocast_wrapper::Node, etc.) without requiring a cast. AgnocastOnly executors require get_agnocast_node(), which is only available on autoware::agnocast_wrapper::Node.

File truncated at 100 lines see the full file

CHANGELOG

Changelog for package autoware_agnocast_wrapper

1.8.0 (2026-05-01)

  • chore: align package versions to 1.7.0 and reset changelogs

  • Merge remote-tracking branch 'origin/main' into tmp/bot/bump_version_base

  • docs(autoware_agnocast_wrapper): use FindPackageShare and PathJoinSubstitution in Python launch examples (#999)

  • fix(autoware_agnocast_wrapper): support jazzy (rclcpp 28~) (#980) fix(autoware_agnocast_wrapper): fix Jazzy build by using version-conditional callback type alias

  • fix(autoware_agnocast_wrapper): fix false positive LD_PRELOAD warning in agnocast_env.launch.py (#973)

  • refactor(autoware_agnocast_wrapper): remove executor threading model consistency validation (#970)

    • refactor(autoware_agnocast_wrapper): remove executor threading model consistency validation
    • docs(autoware_agnocast_wrapper): clarify behavior reference tables in README

    - Reword introductory sentence to clarify that only ROS2_EXECUTOR matters when ENABLE_AGNOCAST=0

    - Use full CMake option strings (e.g. SingleThreadedExecutor) instead of abbreviations in both behavior reference tables

    • style(pre-commit): autofix

    * fix(autoware_agnocast_wrapper): fix forbidden word ROS2 to ROS 2 in README ---------Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>

  • feat(autoware_agnocast_wrapper): support message filter in agnocast wrapper (#951)

    * feat(autoware_agnocast_wrapper): add register_node macro for runtime rclcpp/agnocast switching Add [autoware_agnocast_wrapper_register_node]{.title-ref} CMake macro as a drop-in replacement for [rclcpp_components_register_node]{.title-ref}. When ENABLE_AGNOCAST=1, it generates a standalone executable that can switch between rclcpp::Node and agnocast::Node at runtime based on the ENABLE_AGNOCAST environment variable. When ENABLE_AGNOCAST is not set, it falls back to standard rclcpp_components_register_node behavior with zero overhead. Key features:

    • Configurable ROS2 and Agnocast executor types
    • Two-pass template generation (configure_file + file(GENERATE))
    • Support for both rclcpp::Node and agnocast_wrapper::Node plugins
    • Target existence validation at configure time
    • ABI consistency enforcement via autoware_agnocast_wrapper_setup()
    • Change agnocastlib from build_depend to depend
    • fix(autoware_agnocast_wrapper): add static_assert to enforce PLUGIN base class at compile time

    * fix(autoware_agnocast_wrapper): add runtime ROS2 fallback for AgnocastOnly executors When agnocast_only=true but ENABLE_AGNOCAST=0 at runtime, the node now falls back to the ROS2 executor instead of unconditionally using the AgnocastOnly executor.

    * fix(autoware_agnocast_wrapper): warn on mismatched executor threading models Emit a CMake WARNING when ROS2_EXECUTOR and AGNOCAST_EXECUTOR have different threading models (e.g., SingleThreadedExecutor with MultiThreadedAgnocastExecutor), as this silently changes behavior depending on the runtime ENABLE_AGNOCAST value.

    • docs(autoware_agnocast_wrapper): add executor behavior reference table to README
    • style(pre-commit): autofix
    • fix(autoware_agnocast_wrapper): replace forbidden word ROS2 with ROS 2
    • style(pre-commit): autofix

    * fix(autoware_agnocast_wrapper): remove static_assert that fails in non-template main() The static_assert inside if constexpr (agnocast_only) is always evaluated because main() is not a template function. Additionally, the component type header is not included in the generated source (loaded via class_loader at runtime), so the type cannot be resolved at compile time.

    • delete deprecated mark from publish(const MessageT&) API
    • support message_filter in agnocast_wrapper
    • style(pre-commit): autofix
    • fix cpplint
    • fix cpplint
    • add comments

File truncated at 100 lines see the full file

Launch files

Messages

No message files found.

Services

No service files found

Plugins

No plugins found.

Recent questions tagged autoware_agnocast_wrapper at Robotics Stack Exchange

Package symbol

autoware_agnocast_wrapper package from autoware_core repo

autoware_adapi_adaptors autoware_adapi_specs autoware_core_api autoware_default_adapi autoware_core autoware_agnocast_wrapper autoware_component_interface_specs autoware_geography_utils autoware_global_parameter_loader autoware_interpolation autoware_kalman_filter autoware_lanelet2_utils autoware_marker_utils autoware_motion_utils autoware_node autoware_object_recognition_utils autoware_osqp_interface autoware_point_types autoware_qos_utils autoware_qp_interface autoware_signal_processing autoware_trajectory autoware_vehicle_info_utils autoware_core_control autoware_simple_pure_pursuit autoware_awsim_sensor_kit_description autoware_sample_sensor_kit_description autoware_sample_vehicle_description autoware_core_localization autoware_ekf_localizer autoware_gyro_odometer autoware_localization_util autoware_ndt_scan_matcher autoware_pose_initializer autoware_stop_filter autoware_twist2accel autoware_core_map autoware_lanelet2_map_visualizer autoware_map_height_fitter autoware_map_loader autoware_map_projection_loader autoware_core_perception autoware_euclidean_cluster_object_detector autoware_ground_filter autoware_perception_objects_converter autoware_core_planning autoware_mission_planner autoware_objects_of_interest_marker_interface autoware_path_generator autoware_planning_factor_interface autoware_planning_topic_converter autoware_route_handler autoware_velocity_smoother autoware_behavior_velocity_planner autoware_behavior_velocity_planner_common autoware_behavior_velocity_stop_line_module autoware_motion_velocity_obstacle_stop_module autoware_motion_velocity_planner autoware_motion_velocity_planner_common autoware_core_sensing autoware_crop_box_filter autoware_downsample_filters autoware_gnss_poser autoware_vehicle_velocity_converter autoware_planning_test_manager autoware_pyplot autoware_test_node autoware_test_utils autoware_testing autoware_core_vehicle

ROS Distro
jazzy

Package Summary

Version 1.8.0
License Apache License 2.0
Build type AMENT_CMAKE
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/autowarefoundation/autoware_core.git
VCS Type git
VCS Version main
Last Updated 2026-05-12
Dev Status DEVELOPED
Released RELEASED
Contributing Help Wanted (-)
Good First Issues (-)
Pull Requests to Review (-)

Package Description

Wrapper macros for Agnocast (true zero-copy communication library)

Maintainers

  • Takahiro Ishikawa-Aso
  • Koichi Imai
  • Atsushi Yano

Authors

No additional authors.

autoware_agnocast_wrapper

The purpose of this package is to integrate Agnocast, a zero-copy middleware, into each topic in Autoware with minimal side effects. Agnocast is a library designed to work alongside ROS 2, enabling true zero-copy publish/subscribe communication for all ROS 2 message types, including unsized message types.

This package provides macros that wrap functions for publish/subscribe operations and smart pointer types for handling ROS 2 messages. When Autoware is built using the default build command, Agnocast is not enabled. However, setting the environment variable ENABLE_AGNOCAST=1 enables Agnocast and results in a build that includes its integration. This design ensures backward compatibility for users who are unaware of Agnocast, minimizing disruption.

Two Integration Approaches

This package provides two approaches for integrating Agnocast. Both will coexist for the foreseeable future.

1. Node Wrapper (agnocast_wrapper::Node)

Use this when you want the entire node to transparently switch between rclcpp::Node and agnocast::Node at runtime. The node wrapper automatically selects the correct underlying implementation based on the ENABLE_AGNOCAST environment variable.

Currently supported APIs:

  • Publisher / Subscription / PollingSubscriber
  • Parameters
  • Logger, Clock
  • Callback groups
  • Node interfaces (partial: get_node_base_interface(), get_node_topics_interface(), get_node_parameters_interface())

Note: Timer (create_wall_timer, create_timer) is not yet supported and will be added in a future update.

#include <autoware/agnocast_wrapper/node.hpp>

class MyNode : public autoware::agnocast_wrapper::Node
{
public:
  explicit MyNode(const rclcpp::NodeOptions & options)
  : Node("my_node", options)
  {
    pub_ = create_publisher<std_msgs::msg::String>("output", 10);
    sub_ = create_subscription<std_msgs::msg::String>(
      "input", 10, [this](std::unique_ptr<const std_msgs::msg::String> msg) { /* ... */ });
  }

private:
  autoware::agnocast_wrapper::Publisher<std_msgs::msg::String>::SharedPtr pub_;
  autoware::agnocast_wrapper::Subscription<std_msgs::msg::String>::SharedPtr sub_;
};

To use the Node wrapper in your package, add the following to your CMakeLists.txt:

find_package(autoware_agnocast_wrapper REQUIRED)
ament_target_dependencies(my_node_component autoware_agnocast_wrapper)

Registering a Node with autoware_agnocast_wrapper_register_node

Instead of calling rclcpp_components_register_node directly, use the autoware_agnocast_wrapper_register_node macro to register your component node. This macro:

  1. Registers the component with rclcpp_components (for component container support)
  2. Creates a standalone executable that can switch between rclcpp::Node and agnocast::Node at runtime based on the ENABLE_AGNOCAST environment variable

When ENABLE_AGNOCAST is not set or set to 0, this macro falls back to standard rclcpp_components_register_node behavior.

find_package(autoware_agnocast_wrapper REQUIRED)

ament_auto_add_library(my_node_component SHARED src/my_node.cpp)
ament_target_dependencies(my_node_component autoware_agnocast_wrapper)

autoware_agnocast_wrapper_register_node(my_node_component
  PLUGIN "my_package::MyNode"
  EXECUTABLE my_node
)

Parameters:

Parameter Required Default Description
PLUGIN Yes - Fully qualified class name of the component
EXECUTABLE Yes - Executable name for the node
ROS2_EXECUTOR No SingleThreadedExecutor Executor to use when ENABLE_AGNOCAST=0 at runtime
AGNOCAST_EXECUTOR No SingleThreadedAgnocastExecutor Executor to use when ENABLE_AGNOCAST=1 at runtime

Valid executor values:

  • ROS2_EXECUTOR: SingleThreadedExecutor, MultiThreadedExecutor
  • AGNOCAST_EXECUTOR: SingleThreadedAgnocastExecutor, MultiThreadedAgnocastExecutor, CallbackIsolatedAgnocastExecutor, AgnocastOnlySingleThreadedExecutor, AgnocastOnlyMultiThreadedExecutor, AgnocastOnlyCallbackIsolatedExecutor

Node class requirements:

The required PLUGIN base class depends on the AGNOCAST_EXECUTOR type. The generated template enforces this via if constexpr at compile time:

AGNOCAST_EXECUTOR Required PLUGIN base class
AgnocastOnly* executors autoware::agnocast_wrapper::Node
Other agnocast executors Any rclcpp::Node-compatible class

Non-AgnocastOnly executors use NodeInstanceWrapper::get_node_base_interface() directly, which works with any node type (rclcpp::Node, agnocast_wrapper::Node, etc.) without requiring a cast. AgnocastOnly executors require get_agnocast_node(), which is only available on autoware::agnocast_wrapper::Node.

File truncated at 100 lines see the full file

CHANGELOG

Changelog for package autoware_agnocast_wrapper

1.8.0 (2026-05-01)

  • chore: align package versions to 1.7.0 and reset changelogs

  • Merge remote-tracking branch 'origin/main' into tmp/bot/bump_version_base

  • docs(autoware_agnocast_wrapper): use FindPackageShare and PathJoinSubstitution in Python launch examples (#999)

  • fix(autoware_agnocast_wrapper): support jazzy (rclcpp 28~) (#980) fix(autoware_agnocast_wrapper): fix Jazzy build by using version-conditional callback type alias

  • fix(autoware_agnocast_wrapper): fix false positive LD_PRELOAD warning in agnocast_env.launch.py (#973)

  • refactor(autoware_agnocast_wrapper): remove executor threading model consistency validation (#970)

    • refactor(autoware_agnocast_wrapper): remove executor threading model consistency validation
    • docs(autoware_agnocast_wrapper): clarify behavior reference tables in README

    - Reword introductory sentence to clarify that only ROS2_EXECUTOR matters when ENABLE_AGNOCAST=0

    - Use full CMake option strings (e.g. SingleThreadedExecutor) instead of abbreviations in both behavior reference tables

    • style(pre-commit): autofix

    * fix(autoware_agnocast_wrapper): fix forbidden word ROS2 to ROS 2 in README ---------Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>

  • feat(autoware_agnocast_wrapper): support message filter in agnocast wrapper (#951)

    * feat(autoware_agnocast_wrapper): add register_node macro for runtime rclcpp/agnocast switching Add [autoware_agnocast_wrapper_register_node]{.title-ref} CMake macro as a drop-in replacement for [rclcpp_components_register_node]{.title-ref}. When ENABLE_AGNOCAST=1, it generates a standalone executable that can switch between rclcpp::Node and agnocast::Node at runtime based on the ENABLE_AGNOCAST environment variable. When ENABLE_AGNOCAST is not set, it falls back to standard rclcpp_components_register_node behavior with zero overhead. Key features:

    • Configurable ROS2 and Agnocast executor types
    • Two-pass template generation (configure_file + file(GENERATE))
    • Support for both rclcpp::Node and agnocast_wrapper::Node plugins
    • Target existence validation at configure time
    • ABI consistency enforcement via autoware_agnocast_wrapper_setup()
    • Change agnocastlib from build_depend to depend
    • fix(autoware_agnocast_wrapper): add static_assert to enforce PLUGIN base class at compile time

    * fix(autoware_agnocast_wrapper): add runtime ROS2 fallback for AgnocastOnly executors When agnocast_only=true but ENABLE_AGNOCAST=0 at runtime, the node now falls back to the ROS2 executor instead of unconditionally using the AgnocastOnly executor.

    * fix(autoware_agnocast_wrapper): warn on mismatched executor threading models Emit a CMake WARNING when ROS2_EXECUTOR and AGNOCAST_EXECUTOR have different threading models (e.g., SingleThreadedExecutor with MultiThreadedAgnocastExecutor), as this silently changes behavior depending on the runtime ENABLE_AGNOCAST value.

    • docs(autoware_agnocast_wrapper): add executor behavior reference table to README
    • style(pre-commit): autofix
    • fix(autoware_agnocast_wrapper): replace forbidden word ROS2 with ROS 2
    • style(pre-commit): autofix

    * fix(autoware_agnocast_wrapper): remove static_assert that fails in non-template main() The static_assert inside if constexpr (agnocast_only) is always evaluated because main() is not a template function. Additionally, the component type header is not included in the generated source (loaded via class_loader at runtime), so the type cannot be resolved at compile time.

    • delete deprecated mark from publish(const MessageT&) API
    • support message_filter in agnocast_wrapper
    • style(pre-commit): autofix
    • fix cpplint
    • fix cpplint
    • add comments

File truncated at 100 lines see the full file

Launch files

Messages

No message files found.

Services

No service files found

Plugins

No plugins found.

Recent questions tagged autoware_agnocast_wrapper at Robotics Stack Exchange

No version for distro kilted showing humble. Known supported distros are highlighted in the buttons above.
Package symbol

autoware_agnocast_wrapper package from autoware_core repo

autoware_adapi_adaptors autoware_adapi_specs autoware_core_api autoware_default_adapi autoware_core autoware_agnocast_wrapper autoware_component_interface_specs autoware_geography_utils autoware_global_parameter_loader autoware_interpolation autoware_kalman_filter autoware_lanelet2_utils autoware_marker_utils autoware_motion_utils autoware_node autoware_object_recognition_utils autoware_osqp_interface autoware_point_types autoware_qos_utils autoware_qp_interface autoware_signal_processing autoware_trajectory autoware_vehicle_info_utils autoware_core_control autoware_simple_pure_pursuit autoware_awsim_sensor_kit_description autoware_sample_sensor_kit_description autoware_sample_vehicle_description autoware_core_localization autoware_ekf_localizer autoware_gyro_odometer autoware_localization_util autoware_ndt_scan_matcher autoware_pose_initializer autoware_stop_filter autoware_twist2accel autoware_core_map autoware_lanelet2_map_visualizer autoware_map_height_fitter autoware_map_loader autoware_map_projection_loader autoware_core_perception autoware_euclidean_cluster_object_detector autoware_ground_filter autoware_perception_objects_converter autoware_core_planning autoware_mission_planner autoware_objects_of_interest_marker_interface autoware_path_generator autoware_planning_factor_interface autoware_planning_topic_converter autoware_route_handler autoware_velocity_smoother autoware_behavior_velocity_planner autoware_behavior_velocity_planner_common autoware_behavior_velocity_stop_line_module autoware_motion_velocity_obstacle_stop_module autoware_motion_velocity_planner autoware_motion_velocity_planner_common autoware_core_sensing autoware_crop_box_filter autoware_downsample_filters autoware_gnss_poser autoware_vehicle_velocity_converter autoware_planning_test_manager autoware_pyplot autoware_test_node autoware_test_utils autoware_testing autoware_core_vehicle

ROS Distro
humble

Package Summary

Version 1.8.0
License Apache License 2.0
Build type AMENT_CMAKE
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/autowarefoundation/autoware_core.git
VCS Type git
VCS Version main
Last Updated 2026-05-12
Dev Status DEVELOPED
Released RELEASED
Contributing Help Wanted (-)
Good First Issues (-)
Pull Requests to Review (-)

Package Description

Wrapper macros for Agnocast (true zero-copy communication library)

Maintainers

  • Takahiro Ishikawa-Aso
  • Koichi Imai
  • Atsushi Yano

Authors

No additional authors.

autoware_agnocast_wrapper

The purpose of this package is to integrate Agnocast, a zero-copy middleware, into each topic in Autoware with minimal side effects. Agnocast is a library designed to work alongside ROS 2, enabling true zero-copy publish/subscribe communication for all ROS 2 message types, including unsized message types.

This package provides macros that wrap functions for publish/subscribe operations and smart pointer types for handling ROS 2 messages. When Autoware is built using the default build command, Agnocast is not enabled. However, setting the environment variable ENABLE_AGNOCAST=1 enables Agnocast and results in a build that includes its integration. This design ensures backward compatibility for users who are unaware of Agnocast, minimizing disruption.

Two Integration Approaches

This package provides two approaches for integrating Agnocast. Both will coexist for the foreseeable future.

1. Node Wrapper (agnocast_wrapper::Node)

Use this when you want the entire node to transparently switch between rclcpp::Node and agnocast::Node at runtime. The node wrapper automatically selects the correct underlying implementation based on the ENABLE_AGNOCAST environment variable.

Currently supported APIs:

  • Publisher / Subscription / PollingSubscriber
  • Parameters
  • Logger, Clock
  • Callback groups
  • Node interfaces (partial: get_node_base_interface(), get_node_topics_interface(), get_node_parameters_interface())

Note: Timer (create_wall_timer, create_timer) is not yet supported and will be added in a future update.

#include <autoware/agnocast_wrapper/node.hpp>

class MyNode : public autoware::agnocast_wrapper::Node
{
public:
  explicit MyNode(const rclcpp::NodeOptions & options)
  : Node("my_node", options)
  {
    pub_ = create_publisher<std_msgs::msg::String>("output", 10);
    sub_ = create_subscription<std_msgs::msg::String>(
      "input", 10, [this](std::unique_ptr<const std_msgs::msg::String> msg) { /* ... */ });
  }

private:
  autoware::agnocast_wrapper::Publisher<std_msgs::msg::String>::SharedPtr pub_;
  autoware::agnocast_wrapper::Subscription<std_msgs::msg::String>::SharedPtr sub_;
};

To use the Node wrapper in your package, add the following to your CMakeLists.txt:

find_package(autoware_agnocast_wrapper REQUIRED)
ament_target_dependencies(my_node_component autoware_agnocast_wrapper)

Registering a Node with autoware_agnocast_wrapper_register_node

Instead of calling rclcpp_components_register_node directly, use the autoware_agnocast_wrapper_register_node macro to register your component node. This macro:

  1. Registers the component with rclcpp_components (for component container support)
  2. Creates a standalone executable that can switch between rclcpp::Node and agnocast::Node at runtime based on the ENABLE_AGNOCAST environment variable

When ENABLE_AGNOCAST is not set or set to 0, this macro falls back to standard rclcpp_components_register_node behavior.

find_package(autoware_agnocast_wrapper REQUIRED)

ament_auto_add_library(my_node_component SHARED src/my_node.cpp)
ament_target_dependencies(my_node_component autoware_agnocast_wrapper)

autoware_agnocast_wrapper_register_node(my_node_component
  PLUGIN "my_package::MyNode"
  EXECUTABLE my_node
)

Parameters:

Parameter Required Default Description
PLUGIN Yes - Fully qualified class name of the component
EXECUTABLE Yes - Executable name for the node
ROS2_EXECUTOR No SingleThreadedExecutor Executor to use when ENABLE_AGNOCAST=0 at runtime
AGNOCAST_EXECUTOR No SingleThreadedAgnocastExecutor Executor to use when ENABLE_AGNOCAST=1 at runtime

Valid executor values:

  • ROS2_EXECUTOR: SingleThreadedExecutor, MultiThreadedExecutor
  • AGNOCAST_EXECUTOR: SingleThreadedAgnocastExecutor, MultiThreadedAgnocastExecutor, CallbackIsolatedAgnocastExecutor, AgnocastOnlySingleThreadedExecutor, AgnocastOnlyMultiThreadedExecutor, AgnocastOnlyCallbackIsolatedExecutor

Node class requirements:

The required PLUGIN base class depends on the AGNOCAST_EXECUTOR type. The generated template enforces this via if constexpr at compile time:

AGNOCAST_EXECUTOR Required PLUGIN base class
AgnocastOnly* executors autoware::agnocast_wrapper::Node
Other agnocast executors Any rclcpp::Node-compatible class

Non-AgnocastOnly executors use NodeInstanceWrapper::get_node_base_interface() directly, which works with any node type (rclcpp::Node, agnocast_wrapper::Node, etc.) without requiring a cast. AgnocastOnly executors require get_agnocast_node(), which is only available on autoware::agnocast_wrapper::Node.

File truncated at 100 lines see the full file

CHANGELOG

Changelog for package autoware_agnocast_wrapper

1.8.0 (2026-05-01)

  • chore: align package versions to 1.7.0 and reset changelogs

  • Merge remote-tracking branch 'origin/main' into tmp/bot/bump_version_base

  • docs(autoware_agnocast_wrapper): use FindPackageShare and PathJoinSubstitution in Python launch examples (#999)

  • fix(autoware_agnocast_wrapper): support jazzy (rclcpp 28~) (#980) fix(autoware_agnocast_wrapper): fix Jazzy build by using version-conditional callback type alias

  • fix(autoware_agnocast_wrapper): fix false positive LD_PRELOAD warning in agnocast_env.launch.py (#973)

  • refactor(autoware_agnocast_wrapper): remove executor threading model consistency validation (#970)

    • refactor(autoware_agnocast_wrapper): remove executor threading model consistency validation
    • docs(autoware_agnocast_wrapper): clarify behavior reference tables in README

    - Reword introductory sentence to clarify that only ROS2_EXECUTOR matters when ENABLE_AGNOCAST=0

    - Use full CMake option strings (e.g. SingleThreadedExecutor) instead of abbreviations in both behavior reference tables

    • style(pre-commit): autofix

    * fix(autoware_agnocast_wrapper): fix forbidden word ROS2 to ROS 2 in README ---------Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>

  • feat(autoware_agnocast_wrapper): support message filter in agnocast wrapper (#951)

    * feat(autoware_agnocast_wrapper): add register_node macro for runtime rclcpp/agnocast switching Add [autoware_agnocast_wrapper_register_node]{.title-ref} CMake macro as a drop-in replacement for [rclcpp_components_register_node]{.title-ref}. When ENABLE_AGNOCAST=1, it generates a standalone executable that can switch between rclcpp::Node and agnocast::Node at runtime based on the ENABLE_AGNOCAST environment variable. When ENABLE_AGNOCAST is not set, it falls back to standard rclcpp_components_register_node behavior with zero overhead. Key features:

    • Configurable ROS2 and Agnocast executor types
    • Two-pass template generation (configure_file + file(GENERATE))
    • Support for both rclcpp::Node and agnocast_wrapper::Node plugins
    • Target existence validation at configure time
    • ABI consistency enforcement via autoware_agnocast_wrapper_setup()
    • Change agnocastlib from build_depend to depend
    • fix(autoware_agnocast_wrapper): add static_assert to enforce PLUGIN base class at compile time

    * fix(autoware_agnocast_wrapper): add runtime ROS2 fallback for AgnocastOnly executors When agnocast_only=true but ENABLE_AGNOCAST=0 at runtime, the node now falls back to the ROS2 executor instead of unconditionally using the AgnocastOnly executor.

    * fix(autoware_agnocast_wrapper): warn on mismatched executor threading models Emit a CMake WARNING when ROS2_EXECUTOR and AGNOCAST_EXECUTOR have different threading models (e.g., SingleThreadedExecutor with MultiThreadedAgnocastExecutor), as this silently changes behavior depending on the runtime ENABLE_AGNOCAST value.

    • docs(autoware_agnocast_wrapper): add executor behavior reference table to README
    • style(pre-commit): autofix
    • fix(autoware_agnocast_wrapper): replace forbidden word ROS2 with ROS 2
    • style(pre-commit): autofix

    * fix(autoware_agnocast_wrapper): remove static_assert that fails in non-template main() The static_assert inside if constexpr (agnocast_only) is always evaluated because main() is not a template function. Additionally, the component type header is not included in the generated source (loaded via class_loader at runtime), so the type cannot be resolved at compile time.

    • delete deprecated mark from publish(const MessageT&) API
    • support message_filter in agnocast_wrapper
    • style(pre-commit): autofix
    • fix cpplint
    • fix cpplint
    • add comments

File truncated at 100 lines see the full file

Launch files

Messages

No message files found.

Services

No service files found

Plugins

No plugins found.

Recent questions tagged autoware_agnocast_wrapper at Robotics Stack Exchange

No version for distro rolling showing humble. Known supported distros are highlighted in the buttons above.
Package symbol

autoware_agnocast_wrapper package from autoware_core repo

autoware_adapi_adaptors autoware_adapi_specs autoware_core_api autoware_default_adapi autoware_core autoware_agnocast_wrapper autoware_component_interface_specs autoware_geography_utils autoware_global_parameter_loader autoware_interpolation autoware_kalman_filter autoware_lanelet2_utils autoware_marker_utils autoware_motion_utils autoware_node autoware_object_recognition_utils autoware_osqp_interface autoware_point_types autoware_qos_utils autoware_qp_interface autoware_signal_processing autoware_trajectory autoware_vehicle_info_utils autoware_core_control autoware_simple_pure_pursuit autoware_awsim_sensor_kit_description autoware_sample_sensor_kit_description autoware_sample_vehicle_description autoware_core_localization autoware_ekf_localizer autoware_gyro_odometer autoware_localization_util autoware_ndt_scan_matcher autoware_pose_initializer autoware_stop_filter autoware_twist2accel autoware_core_map autoware_lanelet2_map_visualizer autoware_map_height_fitter autoware_map_loader autoware_map_projection_loader autoware_core_perception autoware_euclidean_cluster_object_detector autoware_ground_filter autoware_perception_objects_converter autoware_core_planning autoware_mission_planner autoware_objects_of_interest_marker_interface autoware_path_generator autoware_planning_factor_interface autoware_planning_topic_converter autoware_route_handler autoware_velocity_smoother autoware_behavior_velocity_planner autoware_behavior_velocity_planner_common autoware_behavior_velocity_stop_line_module autoware_motion_velocity_obstacle_stop_module autoware_motion_velocity_planner autoware_motion_velocity_planner_common autoware_core_sensing autoware_crop_box_filter autoware_downsample_filters autoware_gnss_poser autoware_vehicle_velocity_converter autoware_planning_test_manager autoware_pyplot autoware_test_node autoware_test_utils autoware_testing autoware_core_vehicle

ROS Distro
humble

Package Summary

Version 1.8.0
License Apache License 2.0
Build type AMENT_CMAKE
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/autowarefoundation/autoware_core.git
VCS Type git
VCS Version main
Last Updated 2026-05-12
Dev Status DEVELOPED
Released RELEASED
Contributing Help Wanted (-)
Good First Issues (-)
Pull Requests to Review (-)

Package Description

Wrapper macros for Agnocast (true zero-copy communication library)

Maintainers

  • Takahiro Ishikawa-Aso
  • Koichi Imai
  • Atsushi Yano

Authors

No additional authors.

autoware_agnocast_wrapper

The purpose of this package is to integrate Agnocast, a zero-copy middleware, into each topic in Autoware with minimal side effects. Agnocast is a library designed to work alongside ROS 2, enabling true zero-copy publish/subscribe communication for all ROS 2 message types, including unsized message types.

This package provides macros that wrap functions for publish/subscribe operations and smart pointer types for handling ROS 2 messages. When Autoware is built using the default build command, Agnocast is not enabled. However, setting the environment variable ENABLE_AGNOCAST=1 enables Agnocast and results in a build that includes its integration. This design ensures backward compatibility for users who are unaware of Agnocast, minimizing disruption.

Two Integration Approaches

This package provides two approaches for integrating Agnocast. Both will coexist for the foreseeable future.

1. Node Wrapper (agnocast_wrapper::Node)

Use this when you want the entire node to transparently switch between rclcpp::Node and agnocast::Node at runtime. The node wrapper automatically selects the correct underlying implementation based on the ENABLE_AGNOCAST environment variable.

Currently supported APIs:

  • Publisher / Subscription / PollingSubscriber
  • Parameters
  • Logger, Clock
  • Callback groups
  • Node interfaces (partial: get_node_base_interface(), get_node_topics_interface(), get_node_parameters_interface())

Note: Timer (create_wall_timer, create_timer) is not yet supported and will be added in a future update.

#include <autoware/agnocast_wrapper/node.hpp>

class MyNode : public autoware::agnocast_wrapper::Node
{
public:
  explicit MyNode(const rclcpp::NodeOptions & options)
  : Node("my_node", options)
  {
    pub_ = create_publisher<std_msgs::msg::String>("output", 10);
    sub_ = create_subscription<std_msgs::msg::String>(
      "input", 10, [this](std::unique_ptr<const std_msgs::msg::String> msg) { /* ... */ });
  }

private:
  autoware::agnocast_wrapper::Publisher<std_msgs::msg::String>::SharedPtr pub_;
  autoware::agnocast_wrapper::Subscription<std_msgs::msg::String>::SharedPtr sub_;
};

To use the Node wrapper in your package, add the following to your CMakeLists.txt:

find_package(autoware_agnocast_wrapper REQUIRED)
ament_target_dependencies(my_node_component autoware_agnocast_wrapper)

Registering a Node with autoware_agnocast_wrapper_register_node

Instead of calling rclcpp_components_register_node directly, use the autoware_agnocast_wrapper_register_node macro to register your component node. This macro:

  1. Registers the component with rclcpp_components (for component container support)
  2. Creates a standalone executable that can switch between rclcpp::Node and agnocast::Node at runtime based on the ENABLE_AGNOCAST environment variable

When ENABLE_AGNOCAST is not set or set to 0, this macro falls back to standard rclcpp_components_register_node behavior.

find_package(autoware_agnocast_wrapper REQUIRED)

ament_auto_add_library(my_node_component SHARED src/my_node.cpp)
ament_target_dependencies(my_node_component autoware_agnocast_wrapper)

autoware_agnocast_wrapper_register_node(my_node_component
  PLUGIN "my_package::MyNode"
  EXECUTABLE my_node
)

Parameters:

Parameter Required Default Description
PLUGIN Yes - Fully qualified class name of the component
EXECUTABLE Yes - Executable name for the node
ROS2_EXECUTOR No SingleThreadedExecutor Executor to use when ENABLE_AGNOCAST=0 at runtime
AGNOCAST_EXECUTOR No SingleThreadedAgnocastExecutor Executor to use when ENABLE_AGNOCAST=1 at runtime

Valid executor values:

  • ROS2_EXECUTOR: SingleThreadedExecutor, MultiThreadedExecutor
  • AGNOCAST_EXECUTOR: SingleThreadedAgnocastExecutor, MultiThreadedAgnocastExecutor, CallbackIsolatedAgnocastExecutor, AgnocastOnlySingleThreadedExecutor, AgnocastOnlyMultiThreadedExecutor, AgnocastOnlyCallbackIsolatedExecutor

Node class requirements:

The required PLUGIN base class depends on the AGNOCAST_EXECUTOR type. The generated template enforces this via if constexpr at compile time:

AGNOCAST_EXECUTOR Required PLUGIN base class
AgnocastOnly* executors autoware::agnocast_wrapper::Node
Other agnocast executors Any rclcpp::Node-compatible class

Non-AgnocastOnly executors use NodeInstanceWrapper::get_node_base_interface() directly, which works with any node type (rclcpp::Node, agnocast_wrapper::Node, etc.) without requiring a cast. AgnocastOnly executors require get_agnocast_node(), which is only available on autoware::agnocast_wrapper::Node.

File truncated at 100 lines see the full file

CHANGELOG

Changelog for package autoware_agnocast_wrapper

1.8.0 (2026-05-01)

  • chore: align package versions to 1.7.0 and reset changelogs

  • Merge remote-tracking branch 'origin/main' into tmp/bot/bump_version_base

  • docs(autoware_agnocast_wrapper): use FindPackageShare and PathJoinSubstitution in Python launch examples (#999)

  • fix(autoware_agnocast_wrapper): support jazzy (rclcpp 28~) (#980) fix(autoware_agnocast_wrapper): fix Jazzy build by using version-conditional callback type alias

  • fix(autoware_agnocast_wrapper): fix false positive LD_PRELOAD warning in agnocast_env.launch.py (#973)

  • refactor(autoware_agnocast_wrapper): remove executor threading model consistency validation (#970)

    • refactor(autoware_agnocast_wrapper): remove executor threading model consistency validation
    • docs(autoware_agnocast_wrapper): clarify behavior reference tables in README

    - Reword introductory sentence to clarify that only ROS2_EXECUTOR matters when ENABLE_AGNOCAST=0

    - Use full CMake option strings (e.g. SingleThreadedExecutor) instead of abbreviations in both behavior reference tables

    • style(pre-commit): autofix

    * fix(autoware_agnocast_wrapper): fix forbidden word ROS2 to ROS 2 in README ---------Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>

  • feat(autoware_agnocast_wrapper): support message filter in agnocast wrapper (#951)

    * feat(autoware_agnocast_wrapper): add register_node macro for runtime rclcpp/agnocast switching Add [autoware_agnocast_wrapper_register_node]{.title-ref} CMake macro as a drop-in replacement for [rclcpp_components_register_node]{.title-ref}. When ENABLE_AGNOCAST=1, it generates a standalone executable that can switch between rclcpp::Node and agnocast::Node at runtime based on the ENABLE_AGNOCAST environment variable. When ENABLE_AGNOCAST is not set, it falls back to standard rclcpp_components_register_node behavior with zero overhead. Key features:

    • Configurable ROS2 and Agnocast executor types
    • Two-pass template generation (configure_file + file(GENERATE))
    • Support for both rclcpp::Node and agnocast_wrapper::Node plugins
    • Target existence validation at configure time
    • ABI consistency enforcement via autoware_agnocast_wrapper_setup()
    • Change agnocastlib from build_depend to depend
    • fix(autoware_agnocast_wrapper): add static_assert to enforce PLUGIN base class at compile time

    * fix(autoware_agnocast_wrapper): add runtime ROS2 fallback for AgnocastOnly executors When agnocast_only=true but ENABLE_AGNOCAST=0 at runtime, the node now falls back to the ROS2 executor instead of unconditionally using the AgnocastOnly executor.

    * fix(autoware_agnocast_wrapper): warn on mismatched executor threading models Emit a CMake WARNING when ROS2_EXECUTOR and AGNOCAST_EXECUTOR have different threading models (e.g., SingleThreadedExecutor with MultiThreadedAgnocastExecutor), as this silently changes behavior depending on the runtime ENABLE_AGNOCAST value.

    • docs(autoware_agnocast_wrapper): add executor behavior reference table to README
    • style(pre-commit): autofix
    • fix(autoware_agnocast_wrapper): replace forbidden word ROS2 with ROS 2
    • style(pre-commit): autofix

    * fix(autoware_agnocast_wrapper): remove static_assert that fails in non-template main() The static_assert inside if constexpr (agnocast_only) is always evaluated because main() is not a template function. Additionally, the component type header is not included in the generated source (loaded via class_loader at runtime), so the type cannot be resolved at compile time.

    • delete deprecated mark from publish(const MessageT&) API
    • support message_filter in agnocast_wrapper
    • style(pre-commit): autofix
    • fix cpplint
    • fix cpplint
    • add comments

File truncated at 100 lines see the full file

Launch files

Messages

No message files found.

Services

No service files found

Plugins

No plugins found.

Recent questions tagged autoware_agnocast_wrapper at Robotics Stack Exchange

No version for distro ardent showing humble. Known supported distros are highlighted in the buttons above.
Package symbol

autoware_agnocast_wrapper package from autoware_core repo

autoware_adapi_adaptors autoware_adapi_specs autoware_core_api autoware_default_adapi autoware_core autoware_agnocast_wrapper autoware_component_interface_specs autoware_geography_utils autoware_global_parameter_loader autoware_interpolation autoware_kalman_filter autoware_lanelet2_utils autoware_marker_utils autoware_motion_utils autoware_node autoware_object_recognition_utils autoware_osqp_interface autoware_point_types autoware_qos_utils autoware_qp_interface autoware_signal_processing autoware_trajectory autoware_vehicle_info_utils autoware_core_control autoware_simple_pure_pursuit autoware_awsim_sensor_kit_description autoware_sample_sensor_kit_description autoware_sample_vehicle_description autoware_core_localization autoware_ekf_localizer autoware_gyro_odometer autoware_localization_util autoware_ndt_scan_matcher autoware_pose_initializer autoware_stop_filter autoware_twist2accel autoware_core_map autoware_lanelet2_map_visualizer autoware_map_height_fitter autoware_map_loader autoware_map_projection_loader autoware_core_perception autoware_euclidean_cluster_object_detector autoware_ground_filter autoware_perception_objects_converter autoware_core_planning autoware_mission_planner autoware_objects_of_interest_marker_interface autoware_path_generator autoware_planning_factor_interface autoware_planning_topic_converter autoware_route_handler autoware_velocity_smoother autoware_behavior_velocity_planner autoware_behavior_velocity_planner_common autoware_behavior_velocity_stop_line_module autoware_motion_velocity_obstacle_stop_module autoware_motion_velocity_planner autoware_motion_velocity_planner_common autoware_core_sensing autoware_crop_box_filter autoware_downsample_filters autoware_gnss_poser autoware_vehicle_velocity_converter autoware_planning_test_manager autoware_pyplot autoware_test_node autoware_test_utils autoware_testing autoware_core_vehicle

ROS Distro
humble

Package Summary

Version 1.8.0
License Apache License 2.0
Build type AMENT_CMAKE
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/autowarefoundation/autoware_core.git
VCS Type git
VCS Version main
Last Updated 2026-05-12
Dev Status DEVELOPED
Released RELEASED
Contributing Help Wanted (-)
Good First Issues (-)
Pull Requests to Review (-)

Package Description

Wrapper macros for Agnocast (true zero-copy communication library)

Maintainers

  • Takahiro Ishikawa-Aso
  • Koichi Imai
  • Atsushi Yano

Authors

No additional authors.

autoware_agnocast_wrapper

The purpose of this package is to integrate Agnocast, a zero-copy middleware, into each topic in Autoware with minimal side effects. Agnocast is a library designed to work alongside ROS 2, enabling true zero-copy publish/subscribe communication for all ROS 2 message types, including unsized message types.

This package provides macros that wrap functions for publish/subscribe operations and smart pointer types for handling ROS 2 messages. When Autoware is built using the default build command, Agnocast is not enabled. However, setting the environment variable ENABLE_AGNOCAST=1 enables Agnocast and results in a build that includes its integration. This design ensures backward compatibility for users who are unaware of Agnocast, minimizing disruption.

Two Integration Approaches

This package provides two approaches for integrating Agnocast. Both will coexist for the foreseeable future.

1. Node Wrapper (agnocast_wrapper::Node)

Use this when you want the entire node to transparently switch between rclcpp::Node and agnocast::Node at runtime. The node wrapper automatically selects the correct underlying implementation based on the ENABLE_AGNOCAST environment variable.

Currently supported APIs:

  • Publisher / Subscription / PollingSubscriber
  • Parameters
  • Logger, Clock
  • Callback groups
  • Node interfaces (partial: get_node_base_interface(), get_node_topics_interface(), get_node_parameters_interface())

Note: Timer (create_wall_timer, create_timer) is not yet supported and will be added in a future update.

#include <autoware/agnocast_wrapper/node.hpp>

class MyNode : public autoware::agnocast_wrapper::Node
{
public:
  explicit MyNode(const rclcpp::NodeOptions & options)
  : Node("my_node", options)
  {
    pub_ = create_publisher<std_msgs::msg::String>("output", 10);
    sub_ = create_subscription<std_msgs::msg::String>(
      "input", 10, [this](std::unique_ptr<const std_msgs::msg::String> msg) { /* ... */ });
  }

private:
  autoware::agnocast_wrapper::Publisher<std_msgs::msg::String>::SharedPtr pub_;
  autoware::agnocast_wrapper::Subscription<std_msgs::msg::String>::SharedPtr sub_;
};

To use the Node wrapper in your package, add the following to your CMakeLists.txt:

find_package(autoware_agnocast_wrapper REQUIRED)
ament_target_dependencies(my_node_component autoware_agnocast_wrapper)

Registering a Node with autoware_agnocast_wrapper_register_node

Instead of calling rclcpp_components_register_node directly, use the autoware_agnocast_wrapper_register_node macro to register your component node. This macro:

  1. Registers the component with rclcpp_components (for component container support)
  2. Creates a standalone executable that can switch between rclcpp::Node and agnocast::Node at runtime based on the ENABLE_AGNOCAST environment variable

When ENABLE_AGNOCAST is not set or set to 0, this macro falls back to standard rclcpp_components_register_node behavior.

find_package(autoware_agnocast_wrapper REQUIRED)

ament_auto_add_library(my_node_component SHARED src/my_node.cpp)
ament_target_dependencies(my_node_component autoware_agnocast_wrapper)

autoware_agnocast_wrapper_register_node(my_node_component
  PLUGIN "my_package::MyNode"
  EXECUTABLE my_node
)

Parameters:

Parameter Required Default Description
PLUGIN Yes - Fully qualified class name of the component
EXECUTABLE Yes - Executable name for the node
ROS2_EXECUTOR No SingleThreadedExecutor Executor to use when ENABLE_AGNOCAST=0 at runtime
AGNOCAST_EXECUTOR No SingleThreadedAgnocastExecutor Executor to use when ENABLE_AGNOCAST=1 at runtime

Valid executor values:

  • ROS2_EXECUTOR: SingleThreadedExecutor, MultiThreadedExecutor
  • AGNOCAST_EXECUTOR: SingleThreadedAgnocastExecutor, MultiThreadedAgnocastExecutor, CallbackIsolatedAgnocastExecutor, AgnocastOnlySingleThreadedExecutor, AgnocastOnlyMultiThreadedExecutor, AgnocastOnlyCallbackIsolatedExecutor

Node class requirements:

The required PLUGIN base class depends on the AGNOCAST_EXECUTOR type. The generated template enforces this via if constexpr at compile time:

AGNOCAST_EXECUTOR Required PLUGIN base class
AgnocastOnly* executors autoware::agnocast_wrapper::Node
Other agnocast executors Any rclcpp::Node-compatible class

Non-AgnocastOnly executors use NodeInstanceWrapper::get_node_base_interface() directly, which works with any node type (rclcpp::Node, agnocast_wrapper::Node, etc.) without requiring a cast. AgnocastOnly executors require get_agnocast_node(), which is only available on autoware::agnocast_wrapper::Node.

File truncated at 100 lines see the full file

CHANGELOG

Changelog for package autoware_agnocast_wrapper

1.8.0 (2026-05-01)

  • chore: align package versions to 1.7.0 and reset changelogs

  • Merge remote-tracking branch 'origin/main' into tmp/bot/bump_version_base

  • docs(autoware_agnocast_wrapper): use FindPackageShare and PathJoinSubstitution in Python launch examples (#999)

  • fix(autoware_agnocast_wrapper): support jazzy (rclcpp 28~) (#980) fix(autoware_agnocast_wrapper): fix Jazzy build by using version-conditional callback type alias

  • fix(autoware_agnocast_wrapper): fix false positive LD_PRELOAD warning in agnocast_env.launch.py (#973)

  • refactor(autoware_agnocast_wrapper): remove executor threading model consistency validation (#970)

    • refactor(autoware_agnocast_wrapper): remove executor threading model consistency validation
    • docs(autoware_agnocast_wrapper): clarify behavior reference tables in README

    - Reword introductory sentence to clarify that only ROS2_EXECUTOR matters when ENABLE_AGNOCAST=0

    - Use full CMake option strings (e.g. SingleThreadedExecutor) instead of abbreviations in both behavior reference tables

    • style(pre-commit): autofix

    * fix(autoware_agnocast_wrapper): fix forbidden word ROS2 to ROS 2 in README ---------Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>

  • feat(autoware_agnocast_wrapper): support message filter in agnocast wrapper (#951)

    * feat(autoware_agnocast_wrapper): add register_node macro for runtime rclcpp/agnocast switching Add [autoware_agnocast_wrapper_register_node]{.title-ref} CMake macro as a drop-in replacement for [rclcpp_components_register_node]{.title-ref}. When ENABLE_AGNOCAST=1, it generates a standalone executable that can switch between rclcpp::Node and agnocast::Node at runtime based on the ENABLE_AGNOCAST environment variable. When ENABLE_AGNOCAST is not set, it falls back to standard rclcpp_components_register_node behavior with zero overhead. Key features:

    • Configurable ROS2 and Agnocast executor types
    • Two-pass template generation (configure_file + file(GENERATE))
    • Support for both rclcpp::Node and agnocast_wrapper::Node plugins
    • Target existence validation at configure time
    • ABI consistency enforcement via autoware_agnocast_wrapper_setup()
    • Change agnocastlib from build_depend to depend
    • fix(autoware_agnocast_wrapper): add static_assert to enforce PLUGIN base class at compile time

    * fix(autoware_agnocast_wrapper): add runtime ROS2 fallback for AgnocastOnly executors When agnocast_only=true but ENABLE_AGNOCAST=0 at runtime, the node now falls back to the ROS2 executor instead of unconditionally using the AgnocastOnly executor.

    * fix(autoware_agnocast_wrapper): warn on mismatched executor threading models Emit a CMake WARNING when ROS2_EXECUTOR and AGNOCAST_EXECUTOR have different threading models (e.g., SingleThreadedExecutor with MultiThreadedAgnocastExecutor), as this silently changes behavior depending on the runtime ENABLE_AGNOCAST value.

    • docs(autoware_agnocast_wrapper): add executor behavior reference table to README
    • style(pre-commit): autofix
    • fix(autoware_agnocast_wrapper): replace forbidden word ROS2 with ROS 2
    • style(pre-commit): autofix

    * fix(autoware_agnocast_wrapper): remove static_assert that fails in non-template main() The static_assert inside if constexpr (agnocast_only) is always evaluated because main() is not a template function. Additionally, the component type header is not included in the generated source (loaded via class_loader at runtime), so the type cannot be resolved at compile time.

    • delete deprecated mark from publish(const MessageT&) API
    • support message_filter in agnocast_wrapper
    • style(pre-commit): autofix
    • fix cpplint
    • fix cpplint
    • add comments

File truncated at 100 lines see the full file

Launch files

Messages

No message files found.

Services

No service files found

Plugins

No plugins found.

Recent questions tagged autoware_agnocast_wrapper at Robotics Stack Exchange

No version for distro bouncy showing humble. Known supported distros are highlighted in the buttons above.
Package symbol

autoware_agnocast_wrapper package from autoware_core repo

autoware_adapi_adaptors autoware_adapi_specs autoware_core_api autoware_default_adapi autoware_core autoware_agnocast_wrapper autoware_component_interface_specs autoware_geography_utils autoware_global_parameter_loader autoware_interpolation autoware_kalman_filter autoware_lanelet2_utils autoware_marker_utils autoware_motion_utils autoware_node autoware_object_recognition_utils autoware_osqp_interface autoware_point_types autoware_qos_utils autoware_qp_interface autoware_signal_processing autoware_trajectory autoware_vehicle_info_utils autoware_core_control autoware_simple_pure_pursuit autoware_awsim_sensor_kit_description autoware_sample_sensor_kit_description autoware_sample_vehicle_description autoware_core_localization autoware_ekf_localizer autoware_gyro_odometer autoware_localization_util autoware_ndt_scan_matcher autoware_pose_initializer autoware_stop_filter autoware_twist2accel autoware_core_map autoware_lanelet2_map_visualizer autoware_map_height_fitter autoware_map_loader autoware_map_projection_loader autoware_core_perception autoware_euclidean_cluster_object_detector autoware_ground_filter autoware_perception_objects_converter autoware_core_planning autoware_mission_planner autoware_objects_of_interest_marker_interface autoware_path_generator autoware_planning_factor_interface autoware_planning_topic_converter autoware_route_handler autoware_velocity_smoother autoware_behavior_velocity_planner autoware_behavior_velocity_planner_common autoware_behavior_velocity_stop_line_module autoware_motion_velocity_obstacle_stop_module autoware_motion_velocity_planner autoware_motion_velocity_planner_common autoware_core_sensing autoware_crop_box_filter autoware_downsample_filters autoware_gnss_poser autoware_vehicle_velocity_converter autoware_planning_test_manager autoware_pyplot autoware_test_node autoware_test_utils autoware_testing autoware_core_vehicle

ROS Distro
humble

Package Summary

Version 1.8.0
License Apache License 2.0
Build type AMENT_CMAKE
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/autowarefoundation/autoware_core.git
VCS Type git
VCS Version main
Last Updated 2026-05-12
Dev Status DEVELOPED
Released RELEASED
Contributing Help Wanted (-)
Good First Issues (-)
Pull Requests to Review (-)

Package Description

Wrapper macros for Agnocast (true zero-copy communication library)

Maintainers

  • Takahiro Ishikawa-Aso
  • Koichi Imai
  • Atsushi Yano

Authors

No additional authors.

autoware_agnocast_wrapper

The purpose of this package is to integrate Agnocast, a zero-copy middleware, into each topic in Autoware with minimal side effects. Agnocast is a library designed to work alongside ROS 2, enabling true zero-copy publish/subscribe communication for all ROS 2 message types, including unsized message types.

This package provides macros that wrap functions for publish/subscribe operations and smart pointer types for handling ROS 2 messages. When Autoware is built using the default build command, Agnocast is not enabled. However, setting the environment variable ENABLE_AGNOCAST=1 enables Agnocast and results in a build that includes its integration. This design ensures backward compatibility for users who are unaware of Agnocast, minimizing disruption.

Two Integration Approaches

This package provides two approaches for integrating Agnocast. Both will coexist for the foreseeable future.

1. Node Wrapper (agnocast_wrapper::Node)

Use this when you want the entire node to transparently switch between rclcpp::Node and agnocast::Node at runtime. The node wrapper automatically selects the correct underlying implementation based on the ENABLE_AGNOCAST environment variable.

Currently supported APIs:

  • Publisher / Subscription / PollingSubscriber
  • Parameters
  • Logger, Clock
  • Callback groups
  • Node interfaces (partial: get_node_base_interface(), get_node_topics_interface(), get_node_parameters_interface())

Note: Timer (create_wall_timer, create_timer) is not yet supported and will be added in a future update.

#include <autoware/agnocast_wrapper/node.hpp>

class MyNode : public autoware::agnocast_wrapper::Node
{
public:
  explicit MyNode(const rclcpp::NodeOptions & options)
  : Node("my_node", options)
  {
    pub_ = create_publisher<std_msgs::msg::String>("output", 10);
    sub_ = create_subscription<std_msgs::msg::String>(
      "input", 10, [this](std::unique_ptr<const std_msgs::msg::String> msg) { /* ... */ });
  }

private:
  autoware::agnocast_wrapper::Publisher<std_msgs::msg::String>::SharedPtr pub_;
  autoware::agnocast_wrapper::Subscription<std_msgs::msg::String>::SharedPtr sub_;
};

To use the Node wrapper in your package, add the following to your CMakeLists.txt:

find_package(autoware_agnocast_wrapper REQUIRED)
ament_target_dependencies(my_node_component autoware_agnocast_wrapper)

Registering a Node with autoware_agnocast_wrapper_register_node

Instead of calling rclcpp_components_register_node directly, use the autoware_agnocast_wrapper_register_node macro to register your component node. This macro:

  1. Registers the component with rclcpp_components (for component container support)
  2. Creates a standalone executable that can switch between rclcpp::Node and agnocast::Node at runtime based on the ENABLE_AGNOCAST environment variable

When ENABLE_AGNOCAST is not set or set to 0, this macro falls back to standard rclcpp_components_register_node behavior.

find_package(autoware_agnocast_wrapper REQUIRED)

ament_auto_add_library(my_node_component SHARED src/my_node.cpp)
ament_target_dependencies(my_node_component autoware_agnocast_wrapper)

autoware_agnocast_wrapper_register_node(my_node_component
  PLUGIN "my_package::MyNode"
  EXECUTABLE my_node
)

Parameters:

Parameter Required Default Description
PLUGIN Yes - Fully qualified class name of the component
EXECUTABLE Yes - Executable name for the node
ROS2_EXECUTOR No SingleThreadedExecutor Executor to use when ENABLE_AGNOCAST=0 at runtime
AGNOCAST_EXECUTOR No SingleThreadedAgnocastExecutor Executor to use when ENABLE_AGNOCAST=1 at runtime

Valid executor values:

  • ROS2_EXECUTOR: SingleThreadedExecutor, MultiThreadedExecutor
  • AGNOCAST_EXECUTOR: SingleThreadedAgnocastExecutor, MultiThreadedAgnocastExecutor, CallbackIsolatedAgnocastExecutor, AgnocastOnlySingleThreadedExecutor, AgnocastOnlyMultiThreadedExecutor, AgnocastOnlyCallbackIsolatedExecutor

Node class requirements:

The required PLUGIN base class depends on the AGNOCAST_EXECUTOR type. The generated template enforces this via if constexpr at compile time:

AGNOCAST_EXECUTOR Required PLUGIN base class
AgnocastOnly* executors autoware::agnocast_wrapper::Node
Other agnocast executors Any rclcpp::Node-compatible class

Non-AgnocastOnly executors use NodeInstanceWrapper::get_node_base_interface() directly, which works with any node type (rclcpp::Node, agnocast_wrapper::Node, etc.) without requiring a cast. AgnocastOnly executors require get_agnocast_node(), which is only available on autoware::agnocast_wrapper::Node.

File truncated at 100 lines see the full file

CHANGELOG

Changelog for package autoware_agnocast_wrapper

1.8.0 (2026-05-01)

  • chore: align package versions to 1.7.0 and reset changelogs

  • Merge remote-tracking branch 'origin/main' into tmp/bot/bump_version_base

  • docs(autoware_agnocast_wrapper): use FindPackageShare and PathJoinSubstitution in Python launch examples (#999)

  • fix(autoware_agnocast_wrapper): support jazzy (rclcpp 28~) (#980) fix(autoware_agnocast_wrapper): fix Jazzy build by using version-conditional callback type alias

  • fix(autoware_agnocast_wrapper): fix false positive LD_PRELOAD warning in agnocast_env.launch.py (#973)

  • refactor(autoware_agnocast_wrapper): remove executor threading model consistency validation (#970)

    • refactor(autoware_agnocast_wrapper): remove executor threading model consistency validation
    • docs(autoware_agnocast_wrapper): clarify behavior reference tables in README

    - Reword introductory sentence to clarify that only ROS2_EXECUTOR matters when ENABLE_AGNOCAST=0

    - Use full CMake option strings (e.g. SingleThreadedExecutor) instead of abbreviations in both behavior reference tables

    • style(pre-commit): autofix

    * fix(autoware_agnocast_wrapper): fix forbidden word ROS2 to ROS 2 in README ---------Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>

  • feat(autoware_agnocast_wrapper): support message filter in agnocast wrapper (#951)

    * feat(autoware_agnocast_wrapper): add register_node macro for runtime rclcpp/agnocast switching Add [autoware_agnocast_wrapper_register_node]{.title-ref} CMake macro as a drop-in replacement for [rclcpp_components_register_node]{.title-ref}. When ENABLE_AGNOCAST=1, it generates a standalone executable that can switch between rclcpp::Node and agnocast::Node at runtime based on the ENABLE_AGNOCAST environment variable. When ENABLE_AGNOCAST is not set, it falls back to standard rclcpp_components_register_node behavior with zero overhead. Key features:

    • Configurable ROS2 and Agnocast executor types
    • Two-pass template generation (configure_file + file(GENERATE))
    • Support for both rclcpp::Node and agnocast_wrapper::Node plugins
    • Target existence validation at configure time
    • ABI consistency enforcement via autoware_agnocast_wrapper_setup()
    • Change agnocastlib from build_depend to depend
    • fix(autoware_agnocast_wrapper): add static_assert to enforce PLUGIN base class at compile time

    * fix(autoware_agnocast_wrapper): add runtime ROS2 fallback for AgnocastOnly executors When agnocast_only=true but ENABLE_AGNOCAST=0 at runtime, the node now falls back to the ROS2 executor instead of unconditionally using the AgnocastOnly executor.

    * fix(autoware_agnocast_wrapper): warn on mismatched executor threading models Emit a CMake WARNING when ROS2_EXECUTOR and AGNOCAST_EXECUTOR have different threading models (e.g., SingleThreadedExecutor with MultiThreadedAgnocastExecutor), as this silently changes behavior depending on the runtime ENABLE_AGNOCAST value.

    • docs(autoware_agnocast_wrapper): add executor behavior reference table to README
    • style(pre-commit): autofix
    • fix(autoware_agnocast_wrapper): replace forbidden word ROS2 with ROS 2
    • style(pre-commit): autofix

    * fix(autoware_agnocast_wrapper): remove static_assert that fails in non-template main() The static_assert inside if constexpr (agnocast_only) is always evaluated because main() is not a template function. Additionally, the component type header is not included in the generated source (loaded via class_loader at runtime), so the type cannot be resolved at compile time.

    • delete deprecated mark from publish(const MessageT&) API
    • support message_filter in agnocast_wrapper
    • style(pre-commit): autofix
    • fix cpplint
    • fix cpplint
    • add comments

File truncated at 100 lines see the full file

Launch files

Messages

No message files found.

Services

No service files found

Plugins

No plugins found.

Recent questions tagged autoware_agnocast_wrapper at Robotics Stack Exchange

No version for distro crystal showing humble. Known supported distros are highlighted in the buttons above.
Package symbol

autoware_agnocast_wrapper package from autoware_core repo

autoware_adapi_adaptors autoware_adapi_specs autoware_core_api autoware_default_adapi autoware_core autoware_agnocast_wrapper autoware_component_interface_specs autoware_geography_utils autoware_global_parameter_loader autoware_interpolation autoware_kalman_filter autoware_lanelet2_utils autoware_marker_utils autoware_motion_utils autoware_node autoware_object_recognition_utils autoware_osqp_interface autoware_point_types autoware_qos_utils autoware_qp_interface autoware_signal_processing autoware_trajectory autoware_vehicle_info_utils autoware_core_control autoware_simple_pure_pursuit autoware_awsim_sensor_kit_description autoware_sample_sensor_kit_description autoware_sample_vehicle_description autoware_core_localization autoware_ekf_localizer autoware_gyro_odometer autoware_localization_util autoware_ndt_scan_matcher autoware_pose_initializer autoware_stop_filter autoware_twist2accel autoware_core_map autoware_lanelet2_map_visualizer autoware_map_height_fitter autoware_map_loader autoware_map_projection_loader autoware_core_perception autoware_euclidean_cluster_object_detector autoware_ground_filter autoware_perception_objects_converter autoware_core_planning autoware_mission_planner autoware_objects_of_interest_marker_interface autoware_path_generator autoware_planning_factor_interface autoware_planning_topic_converter autoware_route_handler autoware_velocity_smoother autoware_behavior_velocity_planner autoware_behavior_velocity_planner_common autoware_behavior_velocity_stop_line_module autoware_motion_velocity_obstacle_stop_module autoware_motion_velocity_planner autoware_motion_velocity_planner_common autoware_core_sensing autoware_crop_box_filter autoware_downsample_filters autoware_gnss_poser autoware_vehicle_velocity_converter autoware_planning_test_manager autoware_pyplot autoware_test_node autoware_test_utils autoware_testing autoware_core_vehicle

ROS Distro
humble

Package Summary

Version 1.8.0
License Apache License 2.0
Build type AMENT_CMAKE
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/autowarefoundation/autoware_core.git
VCS Type git
VCS Version main
Last Updated 2026-05-12
Dev Status DEVELOPED
Released RELEASED
Contributing Help Wanted (-)
Good First Issues (-)
Pull Requests to Review (-)

Package Description

Wrapper macros for Agnocast (true zero-copy communication library)

Maintainers

  • Takahiro Ishikawa-Aso
  • Koichi Imai
  • Atsushi Yano

Authors

No additional authors.

autoware_agnocast_wrapper

The purpose of this package is to integrate Agnocast, a zero-copy middleware, into each topic in Autoware with minimal side effects. Agnocast is a library designed to work alongside ROS 2, enabling true zero-copy publish/subscribe communication for all ROS 2 message types, including unsized message types.

This package provides macros that wrap functions for publish/subscribe operations and smart pointer types for handling ROS 2 messages. When Autoware is built using the default build command, Agnocast is not enabled. However, setting the environment variable ENABLE_AGNOCAST=1 enables Agnocast and results in a build that includes its integration. This design ensures backward compatibility for users who are unaware of Agnocast, minimizing disruption.

Two Integration Approaches

This package provides two approaches for integrating Agnocast. Both will coexist for the foreseeable future.

1. Node Wrapper (agnocast_wrapper::Node)

Use this when you want the entire node to transparently switch between rclcpp::Node and agnocast::Node at runtime. The node wrapper automatically selects the correct underlying implementation based on the ENABLE_AGNOCAST environment variable.

Currently supported APIs:

  • Publisher / Subscription / PollingSubscriber
  • Parameters
  • Logger, Clock
  • Callback groups
  • Node interfaces (partial: get_node_base_interface(), get_node_topics_interface(), get_node_parameters_interface())

Note: Timer (create_wall_timer, create_timer) is not yet supported and will be added in a future update.

#include <autoware/agnocast_wrapper/node.hpp>

class MyNode : public autoware::agnocast_wrapper::Node
{
public:
  explicit MyNode(const rclcpp::NodeOptions & options)
  : Node("my_node", options)
  {
    pub_ = create_publisher<std_msgs::msg::String>("output", 10);
    sub_ = create_subscription<std_msgs::msg::String>(
      "input", 10, [this](std::unique_ptr<const std_msgs::msg::String> msg) { /* ... */ });
  }

private:
  autoware::agnocast_wrapper::Publisher<std_msgs::msg::String>::SharedPtr pub_;
  autoware::agnocast_wrapper::Subscription<std_msgs::msg::String>::SharedPtr sub_;
};

To use the Node wrapper in your package, add the following to your CMakeLists.txt:

find_package(autoware_agnocast_wrapper REQUIRED)
ament_target_dependencies(my_node_component autoware_agnocast_wrapper)

Registering a Node with autoware_agnocast_wrapper_register_node

Instead of calling rclcpp_components_register_node directly, use the autoware_agnocast_wrapper_register_node macro to register your component node. This macro:

  1. Registers the component with rclcpp_components (for component container support)
  2. Creates a standalone executable that can switch between rclcpp::Node and agnocast::Node at runtime based on the ENABLE_AGNOCAST environment variable

When ENABLE_AGNOCAST is not set or set to 0, this macro falls back to standard rclcpp_components_register_node behavior.

find_package(autoware_agnocast_wrapper REQUIRED)

ament_auto_add_library(my_node_component SHARED src/my_node.cpp)
ament_target_dependencies(my_node_component autoware_agnocast_wrapper)

autoware_agnocast_wrapper_register_node(my_node_component
  PLUGIN "my_package::MyNode"
  EXECUTABLE my_node
)

Parameters:

Parameter Required Default Description
PLUGIN Yes - Fully qualified class name of the component
EXECUTABLE Yes - Executable name for the node
ROS2_EXECUTOR No SingleThreadedExecutor Executor to use when ENABLE_AGNOCAST=0 at runtime
AGNOCAST_EXECUTOR No SingleThreadedAgnocastExecutor Executor to use when ENABLE_AGNOCAST=1 at runtime

Valid executor values:

  • ROS2_EXECUTOR: SingleThreadedExecutor, MultiThreadedExecutor
  • AGNOCAST_EXECUTOR: SingleThreadedAgnocastExecutor, MultiThreadedAgnocastExecutor, CallbackIsolatedAgnocastExecutor, AgnocastOnlySingleThreadedExecutor, AgnocastOnlyMultiThreadedExecutor, AgnocastOnlyCallbackIsolatedExecutor

Node class requirements:

The required PLUGIN base class depends on the AGNOCAST_EXECUTOR type. The generated template enforces this via if constexpr at compile time:

AGNOCAST_EXECUTOR Required PLUGIN base class
AgnocastOnly* executors autoware::agnocast_wrapper::Node
Other agnocast executors Any rclcpp::Node-compatible class

Non-AgnocastOnly executors use NodeInstanceWrapper::get_node_base_interface() directly, which works with any node type (rclcpp::Node, agnocast_wrapper::Node, etc.) without requiring a cast. AgnocastOnly executors require get_agnocast_node(), which is only available on autoware::agnocast_wrapper::Node.

File truncated at 100 lines see the full file

CHANGELOG

Changelog for package autoware_agnocast_wrapper

1.8.0 (2026-05-01)

  • chore: align package versions to 1.7.0 and reset changelogs

  • Merge remote-tracking branch 'origin/main' into tmp/bot/bump_version_base

  • docs(autoware_agnocast_wrapper): use FindPackageShare and PathJoinSubstitution in Python launch examples (#999)

  • fix(autoware_agnocast_wrapper): support jazzy (rclcpp 28~) (#980) fix(autoware_agnocast_wrapper): fix Jazzy build by using version-conditional callback type alias

  • fix(autoware_agnocast_wrapper): fix false positive LD_PRELOAD warning in agnocast_env.launch.py (#973)

  • refactor(autoware_agnocast_wrapper): remove executor threading model consistency validation (#970)

    • refactor(autoware_agnocast_wrapper): remove executor threading model consistency validation
    • docs(autoware_agnocast_wrapper): clarify behavior reference tables in README

    - Reword introductory sentence to clarify that only ROS2_EXECUTOR matters when ENABLE_AGNOCAST=0

    - Use full CMake option strings (e.g. SingleThreadedExecutor) instead of abbreviations in both behavior reference tables

    • style(pre-commit): autofix

    * fix(autoware_agnocast_wrapper): fix forbidden word ROS2 to ROS 2 in README ---------Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>

  • feat(autoware_agnocast_wrapper): support message filter in agnocast wrapper (#951)

    * feat(autoware_agnocast_wrapper): add register_node macro for runtime rclcpp/agnocast switching Add [autoware_agnocast_wrapper_register_node]{.title-ref} CMake macro as a drop-in replacement for [rclcpp_components_register_node]{.title-ref}. When ENABLE_AGNOCAST=1, it generates a standalone executable that can switch between rclcpp::Node and agnocast::Node at runtime based on the ENABLE_AGNOCAST environment variable. When ENABLE_AGNOCAST is not set, it falls back to standard rclcpp_components_register_node behavior with zero overhead. Key features:

    • Configurable ROS2 and Agnocast executor types
    • Two-pass template generation (configure_file + file(GENERATE))
    • Support for both rclcpp::Node and agnocast_wrapper::Node plugins
    • Target existence validation at configure time
    • ABI consistency enforcement via autoware_agnocast_wrapper_setup()
    • Change agnocastlib from build_depend to depend
    • fix(autoware_agnocast_wrapper): add static_assert to enforce PLUGIN base class at compile time

    * fix(autoware_agnocast_wrapper): add runtime ROS2 fallback for AgnocastOnly executors When agnocast_only=true but ENABLE_AGNOCAST=0 at runtime, the node now falls back to the ROS2 executor instead of unconditionally using the AgnocastOnly executor.

    * fix(autoware_agnocast_wrapper): warn on mismatched executor threading models Emit a CMake WARNING when ROS2_EXECUTOR and AGNOCAST_EXECUTOR have different threading models (e.g., SingleThreadedExecutor with MultiThreadedAgnocastExecutor), as this silently changes behavior depending on the runtime ENABLE_AGNOCAST value.

    • docs(autoware_agnocast_wrapper): add executor behavior reference table to README
    • style(pre-commit): autofix
    • fix(autoware_agnocast_wrapper): replace forbidden word ROS2 with ROS 2
    • style(pre-commit): autofix

    * fix(autoware_agnocast_wrapper): remove static_assert that fails in non-template main() The static_assert inside if constexpr (agnocast_only) is always evaluated because main() is not a template function. Additionally, the component type header is not included in the generated source (loaded via class_loader at runtime), so the type cannot be resolved at compile time.

    • delete deprecated mark from publish(const MessageT&) API
    • support message_filter in agnocast_wrapper
    • style(pre-commit): autofix
    • fix cpplint
    • fix cpplint
    • add comments

File truncated at 100 lines see the full file

Launch files

Messages

No message files found.

Services

No service files found

Plugins

No plugins found.

Recent questions tagged autoware_agnocast_wrapper at Robotics Stack Exchange

No version for distro eloquent showing humble. Known supported distros are highlighted in the buttons above.
Package symbol

autoware_agnocast_wrapper package from autoware_core repo

autoware_adapi_adaptors autoware_adapi_specs autoware_core_api autoware_default_adapi autoware_core autoware_agnocast_wrapper autoware_component_interface_specs autoware_geography_utils autoware_global_parameter_loader autoware_interpolation autoware_kalman_filter autoware_lanelet2_utils autoware_marker_utils autoware_motion_utils autoware_node autoware_object_recognition_utils autoware_osqp_interface autoware_point_types autoware_qos_utils autoware_qp_interface autoware_signal_processing autoware_trajectory autoware_vehicle_info_utils autoware_core_control autoware_simple_pure_pursuit autoware_awsim_sensor_kit_description autoware_sample_sensor_kit_description autoware_sample_vehicle_description autoware_core_localization autoware_ekf_localizer autoware_gyro_odometer autoware_localization_util autoware_ndt_scan_matcher autoware_pose_initializer autoware_stop_filter autoware_twist2accel autoware_core_map autoware_lanelet2_map_visualizer autoware_map_height_fitter autoware_map_loader autoware_map_projection_loader autoware_core_perception autoware_euclidean_cluster_object_detector autoware_ground_filter autoware_perception_objects_converter autoware_core_planning autoware_mission_planner autoware_objects_of_interest_marker_interface autoware_path_generator autoware_planning_factor_interface autoware_planning_topic_converter autoware_route_handler autoware_velocity_smoother autoware_behavior_velocity_planner autoware_behavior_velocity_planner_common autoware_behavior_velocity_stop_line_module autoware_motion_velocity_obstacle_stop_module autoware_motion_velocity_planner autoware_motion_velocity_planner_common autoware_core_sensing autoware_crop_box_filter autoware_downsample_filters autoware_gnss_poser autoware_vehicle_velocity_converter autoware_planning_test_manager autoware_pyplot autoware_test_node autoware_test_utils autoware_testing autoware_core_vehicle

ROS Distro
humble

Package Summary

Version 1.8.0
License Apache License 2.0
Build type AMENT_CMAKE
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/autowarefoundation/autoware_core.git
VCS Type git
VCS Version main
Last Updated 2026-05-12
Dev Status DEVELOPED
Released RELEASED
Contributing Help Wanted (-)
Good First Issues (-)
Pull Requests to Review (-)

Package Description

Wrapper macros for Agnocast (true zero-copy communication library)

Maintainers

  • Takahiro Ishikawa-Aso
  • Koichi Imai
  • Atsushi Yano

Authors

No additional authors.

autoware_agnocast_wrapper

The purpose of this package is to integrate Agnocast, a zero-copy middleware, into each topic in Autoware with minimal side effects. Agnocast is a library designed to work alongside ROS 2, enabling true zero-copy publish/subscribe communication for all ROS 2 message types, including unsized message types.

This package provides macros that wrap functions for publish/subscribe operations and smart pointer types for handling ROS 2 messages. When Autoware is built using the default build command, Agnocast is not enabled. However, setting the environment variable ENABLE_AGNOCAST=1 enables Agnocast and results in a build that includes its integration. This design ensures backward compatibility for users who are unaware of Agnocast, minimizing disruption.

Two Integration Approaches

This package provides two approaches for integrating Agnocast. Both will coexist for the foreseeable future.

1. Node Wrapper (agnocast_wrapper::Node)

Use this when you want the entire node to transparently switch between rclcpp::Node and agnocast::Node at runtime. The node wrapper automatically selects the correct underlying implementation based on the ENABLE_AGNOCAST environment variable.

Currently supported APIs:

  • Publisher / Subscription / PollingSubscriber
  • Parameters
  • Logger, Clock
  • Callback groups
  • Node interfaces (partial: get_node_base_interface(), get_node_topics_interface(), get_node_parameters_interface())

Note: Timer (create_wall_timer, create_timer) is not yet supported and will be added in a future update.

#include <autoware/agnocast_wrapper/node.hpp>

class MyNode : public autoware::agnocast_wrapper::Node
{
public:
  explicit MyNode(const rclcpp::NodeOptions & options)
  : Node("my_node", options)
  {
    pub_ = create_publisher<std_msgs::msg::String>("output", 10);
    sub_ = create_subscription<std_msgs::msg::String>(
      "input", 10, [this](std::unique_ptr<const std_msgs::msg::String> msg) { /* ... */ });
  }

private:
  autoware::agnocast_wrapper::Publisher<std_msgs::msg::String>::SharedPtr pub_;
  autoware::agnocast_wrapper::Subscription<std_msgs::msg::String>::SharedPtr sub_;
};

To use the Node wrapper in your package, add the following to your CMakeLists.txt:

find_package(autoware_agnocast_wrapper REQUIRED)
ament_target_dependencies(my_node_component autoware_agnocast_wrapper)

Registering a Node with autoware_agnocast_wrapper_register_node

Instead of calling rclcpp_components_register_node directly, use the autoware_agnocast_wrapper_register_node macro to register your component node. This macro:

  1. Registers the component with rclcpp_components (for component container support)
  2. Creates a standalone executable that can switch between rclcpp::Node and agnocast::Node at runtime based on the ENABLE_AGNOCAST environment variable

When ENABLE_AGNOCAST is not set or set to 0, this macro falls back to standard rclcpp_components_register_node behavior.

find_package(autoware_agnocast_wrapper REQUIRED)

ament_auto_add_library(my_node_component SHARED src/my_node.cpp)
ament_target_dependencies(my_node_component autoware_agnocast_wrapper)

autoware_agnocast_wrapper_register_node(my_node_component
  PLUGIN "my_package::MyNode"
  EXECUTABLE my_node
)

Parameters:

Parameter Required Default Description
PLUGIN Yes - Fully qualified class name of the component
EXECUTABLE Yes - Executable name for the node
ROS2_EXECUTOR No SingleThreadedExecutor Executor to use when ENABLE_AGNOCAST=0 at runtime
AGNOCAST_EXECUTOR No SingleThreadedAgnocastExecutor Executor to use when ENABLE_AGNOCAST=1 at runtime

Valid executor values:

  • ROS2_EXECUTOR: SingleThreadedExecutor, MultiThreadedExecutor
  • AGNOCAST_EXECUTOR: SingleThreadedAgnocastExecutor, MultiThreadedAgnocastExecutor, CallbackIsolatedAgnocastExecutor, AgnocastOnlySingleThreadedExecutor, AgnocastOnlyMultiThreadedExecutor, AgnocastOnlyCallbackIsolatedExecutor

Node class requirements:

The required PLUGIN base class depends on the AGNOCAST_EXECUTOR type. The generated template enforces this via if constexpr at compile time:

AGNOCAST_EXECUTOR Required PLUGIN base class
AgnocastOnly* executors autoware::agnocast_wrapper::Node
Other agnocast executors Any rclcpp::Node-compatible class

Non-AgnocastOnly executors use NodeInstanceWrapper::get_node_base_interface() directly, which works with any node type (rclcpp::Node, agnocast_wrapper::Node, etc.) without requiring a cast. AgnocastOnly executors require get_agnocast_node(), which is only available on autoware::agnocast_wrapper::Node.

File truncated at 100 lines see the full file

CHANGELOG

Changelog for package autoware_agnocast_wrapper

1.8.0 (2026-05-01)

  • chore: align package versions to 1.7.0 and reset changelogs

  • Merge remote-tracking branch 'origin/main' into tmp/bot/bump_version_base

  • docs(autoware_agnocast_wrapper): use FindPackageShare and PathJoinSubstitution in Python launch examples (#999)

  • fix(autoware_agnocast_wrapper): support jazzy (rclcpp 28~) (#980) fix(autoware_agnocast_wrapper): fix Jazzy build by using version-conditional callback type alias

  • fix(autoware_agnocast_wrapper): fix false positive LD_PRELOAD warning in agnocast_env.launch.py (#973)

  • refactor(autoware_agnocast_wrapper): remove executor threading model consistency validation (#970)

    • refactor(autoware_agnocast_wrapper): remove executor threading model consistency validation
    • docs(autoware_agnocast_wrapper): clarify behavior reference tables in README

    - Reword introductory sentence to clarify that only ROS2_EXECUTOR matters when ENABLE_AGNOCAST=0

    - Use full CMake option strings (e.g. SingleThreadedExecutor) instead of abbreviations in both behavior reference tables

    • style(pre-commit): autofix

    * fix(autoware_agnocast_wrapper): fix forbidden word ROS2 to ROS 2 in README ---------Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>

  • feat(autoware_agnocast_wrapper): support message filter in agnocast wrapper (#951)

    * feat(autoware_agnocast_wrapper): add register_node macro for runtime rclcpp/agnocast switching Add [autoware_agnocast_wrapper_register_node]{.title-ref} CMake macro as a drop-in replacement for [rclcpp_components_register_node]{.title-ref}. When ENABLE_AGNOCAST=1, it generates a standalone executable that can switch between rclcpp::Node and agnocast::Node at runtime based on the ENABLE_AGNOCAST environment variable. When ENABLE_AGNOCAST is not set, it falls back to standard rclcpp_components_register_node behavior with zero overhead. Key features:

    • Configurable ROS2 and Agnocast executor types
    • Two-pass template generation (configure_file + file(GENERATE))
    • Support for both rclcpp::Node and agnocast_wrapper::Node plugins
    • Target existence validation at configure time
    • ABI consistency enforcement via autoware_agnocast_wrapper_setup()
    • Change agnocastlib from build_depend to depend
    • fix(autoware_agnocast_wrapper): add static_assert to enforce PLUGIN base class at compile time

    * fix(autoware_agnocast_wrapper): add runtime ROS2 fallback for AgnocastOnly executors When agnocast_only=true but ENABLE_AGNOCAST=0 at runtime, the node now falls back to the ROS2 executor instead of unconditionally using the AgnocastOnly executor.

    * fix(autoware_agnocast_wrapper): warn on mismatched executor threading models Emit a CMake WARNING when ROS2_EXECUTOR and AGNOCAST_EXECUTOR have different threading models (e.g., SingleThreadedExecutor with MultiThreadedAgnocastExecutor), as this silently changes behavior depending on the runtime ENABLE_AGNOCAST value.

    • docs(autoware_agnocast_wrapper): add executor behavior reference table to README
    • style(pre-commit): autofix
    • fix(autoware_agnocast_wrapper): replace forbidden word ROS2 with ROS 2
    • style(pre-commit): autofix

    * fix(autoware_agnocast_wrapper): remove static_assert that fails in non-template main() The static_assert inside if constexpr (agnocast_only) is always evaluated because main() is not a template function. Additionally, the component type header is not included in the generated source (loaded via class_loader at runtime), so the type cannot be resolved at compile time.

    • delete deprecated mark from publish(const MessageT&) API
    • support message_filter in agnocast_wrapper
    • style(pre-commit): autofix
    • fix cpplint
    • fix cpplint
    • add comments

File truncated at 100 lines see the full file

Launch files

Messages

No message files found.

Services

No service files found

Plugins

No plugins found.

Recent questions tagged autoware_agnocast_wrapper at Robotics Stack Exchange

No version for distro dashing showing humble. Known supported distros are highlighted in the buttons above.
Package symbol

autoware_agnocast_wrapper package from autoware_core repo

autoware_adapi_adaptors autoware_adapi_specs autoware_core_api autoware_default_adapi autoware_core autoware_agnocast_wrapper autoware_component_interface_specs autoware_geography_utils autoware_global_parameter_loader autoware_interpolation autoware_kalman_filter autoware_lanelet2_utils autoware_marker_utils autoware_motion_utils autoware_node autoware_object_recognition_utils autoware_osqp_interface autoware_point_types autoware_qos_utils autoware_qp_interface autoware_signal_processing autoware_trajectory autoware_vehicle_info_utils autoware_core_control autoware_simple_pure_pursuit autoware_awsim_sensor_kit_description autoware_sample_sensor_kit_description autoware_sample_vehicle_description autoware_core_localization autoware_ekf_localizer autoware_gyro_odometer autoware_localization_util autoware_ndt_scan_matcher autoware_pose_initializer autoware_stop_filter autoware_twist2accel autoware_core_map autoware_lanelet2_map_visualizer autoware_map_height_fitter autoware_map_loader autoware_map_projection_loader autoware_core_perception autoware_euclidean_cluster_object_detector autoware_ground_filter autoware_perception_objects_converter autoware_core_planning autoware_mission_planner autoware_objects_of_interest_marker_interface autoware_path_generator autoware_planning_factor_interface autoware_planning_topic_converter autoware_route_handler autoware_velocity_smoother autoware_behavior_velocity_planner autoware_behavior_velocity_planner_common autoware_behavior_velocity_stop_line_module autoware_motion_velocity_obstacle_stop_module autoware_motion_velocity_planner autoware_motion_velocity_planner_common autoware_core_sensing autoware_crop_box_filter autoware_downsample_filters autoware_gnss_poser autoware_vehicle_velocity_converter autoware_planning_test_manager autoware_pyplot autoware_test_node autoware_test_utils autoware_testing autoware_core_vehicle

ROS Distro
humble

Package Summary

Version 1.8.0
License Apache License 2.0
Build type AMENT_CMAKE
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/autowarefoundation/autoware_core.git
VCS Type git
VCS Version main
Last Updated 2026-05-12
Dev Status DEVELOPED
Released RELEASED
Contributing Help Wanted (-)
Good First Issues (-)
Pull Requests to Review (-)

Package Description

Wrapper macros for Agnocast (true zero-copy communication library)

Maintainers

  • Takahiro Ishikawa-Aso
  • Koichi Imai
  • Atsushi Yano

Authors

No additional authors.

autoware_agnocast_wrapper

The purpose of this package is to integrate Agnocast, a zero-copy middleware, into each topic in Autoware with minimal side effects. Agnocast is a library designed to work alongside ROS 2, enabling true zero-copy publish/subscribe communication for all ROS 2 message types, including unsized message types.

This package provides macros that wrap functions for publish/subscribe operations and smart pointer types for handling ROS 2 messages. When Autoware is built using the default build command, Agnocast is not enabled. However, setting the environment variable ENABLE_AGNOCAST=1 enables Agnocast and results in a build that includes its integration. This design ensures backward compatibility for users who are unaware of Agnocast, minimizing disruption.

Two Integration Approaches

This package provides two approaches for integrating Agnocast. Both will coexist for the foreseeable future.

1. Node Wrapper (agnocast_wrapper::Node)

Use this when you want the entire node to transparently switch between rclcpp::Node and agnocast::Node at runtime. The node wrapper automatically selects the correct underlying implementation based on the ENABLE_AGNOCAST environment variable.

Currently supported APIs:

  • Publisher / Subscription / PollingSubscriber
  • Parameters
  • Logger, Clock
  • Callback groups
  • Node interfaces (partial: get_node_base_interface(), get_node_topics_interface(), get_node_parameters_interface())

Note: Timer (create_wall_timer, create_timer) is not yet supported and will be added in a future update.

#include <autoware/agnocast_wrapper/node.hpp>

class MyNode : public autoware::agnocast_wrapper::Node
{
public:
  explicit MyNode(const rclcpp::NodeOptions & options)
  : Node("my_node", options)
  {
    pub_ = create_publisher<std_msgs::msg::String>("output", 10);
    sub_ = create_subscription<std_msgs::msg::String>(
      "input", 10, [this](std::unique_ptr<const std_msgs::msg::String> msg) { /* ... */ });
  }

private:
  autoware::agnocast_wrapper::Publisher<std_msgs::msg::String>::SharedPtr pub_;
  autoware::agnocast_wrapper::Subscription<std_msgs::msg::String>::SharedPtr sub_;
};

To use the Node wrapper in your package, add the following to your CMakeLists.txt:

find_package(autoware_agnocast_wrapper REQUIRED)
ament_target_dependencies(my_node_component autoware_agnocast_wrapper)

Registering a Node with autoware_agnocast_wrapper_register_node

Instead of calling rclcpp_components_register_node directly, use the autoware_agnocast_wrapper_register_node macro to register your component node. This macro:

  1. Registers the component with rclcpp_components (for component container support)
  2. Creates a standalone executable that can switch between rclcpp::Node and agnocast::Node at runtime based on the ENABLE_AGNOCAST environment variable

When ENABLE_AGNOCAST is not set or set to 0, this macro falls back to standard rclcpp_components_register_node behavior.

find_package(autoware_agnocast_wrapper REQUIRED)

ament_auto_add_library(my_node_component SHARED src/my_node.cpp)
ament_target_dependencies(my_node_component autoware_agnocast_wrapper)

autoware_agnocast_wrapper_register_node(my_node_component
  PLUGIN "my_package::MyNode"
  EXECUTABLE my_node
)

Parameters:

Parameter Required Default Description
PLUGIN Yes - Fully qualified class name of the component
EXECUTABLE Yes - Executable name for the node
ROS2_EXECUTOR No SingleThreadedExecutor Executor to use when ENABLE_AGNOCAST=0 at runtime
AGNOCAST_EXECUTOR No SingleThreadedAgnocastExecutor Executor to use when ENABLE_AGNOCAST=1 at runtime

Valid executor values:

  • ROS2_EXECUTOR: SingleThreadedExecutor, MultiThreadedExecutor
  • AGNOCAST_EXECUTOR: SingleThreadedAgnocastExecutor, MultiThreadedAgnocastExecutor, CallbackIsolatedAgnocastExecutor, AgnocastOnlySingleThreadedExecutor, AgnocastOnlyMultiThreadedExecutor, AgnocastOnlyCallbackIsolatedExecutor

Node class requirements:

The required PLUGIN base class depends on the AGNOCAST_EXECUTOR type. The generated template enforces this via if constexpr at compile time:

AGNOCAST_EXECUTOR Required PLUGIN base class
AgnocastOnly* executors autoware::agnocast_wrapper::Node
Other agnocast executors Any rclcpp::Node-compatible class

Non-AgnocastOnly executors use NodeInstanceWrapper::get_node_base_interface() directly, which works with any node type (rclcpp::Node, agnocast_wrapper::Node, etc.) without requiring a cast. AgnocastOnly executors require get_agnocast_node(), which is only available on autoware::agnocast_wrapper::Node.

File truncated at 100 lines see the full file

CHANGELOG

Changelog for package autoware_agnocast_wrapper

1.8.0 (2026-05-01)

  • chore: align package versions to 1.7.0 and reset changelogs

  • Merge remote-tracking branch 'origin/main' into tmp/bot/bump_version_base

  • docs(autoware_agnocast_wrapper): use FindPackageShare and PathJoinSubstitution in Python launch examples (#999)

  • fix(autoware_agnocast_wrapper): support jazzy (rclcpp 28~) (#980) fix(autoware_agnocast_wrapper): fix Jazzy build by using version-conditional callback type alias

  • fix(autoware_agnocast_wrapper): fix false positive LD_PRELOAD warning in agnocast_env.launch.py (#973)

  • refactor(autoware_agnocast_wrapper): remove executor threading model consistency validation (#970)

    • refactor(autoware_agnocast_wrapper): remove executor threading model consistency validation
    • docs(autoware_agnocast_wrapper): clarify behavior reference tables in README

    - Reword introductory sentence to clarify that only ROS2_EXECUTOR matters when ENABLE_AGNOCAST=0

    - Use full CMake option strings (e.g. SingleThreadedExecutor) instead of abbreviations in both behavior reference tables

    • style(pre-commit): autofix

    * fix(autoware_agnocast_wrapper): fix forbidden word ROS2 to ROS 2 in README ---------Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>

  • feat(autoware_agnocast_wrapper): support message filter in agnocast wrapper (#951)

    * feat(autoware_agnocast_wrapper): add register_node macro for runtime rclcpp/agnocast switching Add [autoware_agnocast_wrapper_register_node]{.title-ref} CMake macro as a drop-in replacement for [rclcpp_components_register_node]{.title-ref}. When ENABLE_AGNOCAST=1, it generates a standalone executable that can switch between rclcpp::Node and agnocast::Node at runtime based on the ENABLE_AGNOCAST environment variable. When ENABLE_AGNOCAST is not set, it falls back to standard rclcpp_components_register_node behavior with zero overhead. Key features:

    • Configurable ROS2 and Agnocast executor types
    • Two-pass template generation (configure_file + file(GENERATE))
    • Support for both rclcpp::Node and agnocast_wrapper::Node plugins
    • Target existence validation at configure time
    • ABI consistency enforcement via autoware_agnocast_wrapper_setup()
    • Change agnocastlib from build_depend to depend
    • fix(autoware_agnocast_wrapper): add static_assert to enforce PLUGIN base class at compile time

    * fix(autoware_agnocast_wrapper): add runtime ROS2 fallback for AgnocastOnly executors When agnocast_only=true but ENABLE_AGNOCAST=0 at runtime, the node now falls back to the ROS2 executor instead of unconditionally using the AgnocastOnly executor.

    * fix(autoware_agnocast_wrapper): warn on mismatched executor threading models Emit a CMake WARNING when ROS2_EXECUTOR and AGNOCAST_EXECUTOR have different threading models (e.g., SingleThreadedExecutor with MultiThreadedAgnocastExecutor), as this silently changes behavior depending on the runtime ENABLE_AGNOCAST value.

    • docs(autoware_agnocast_wrapper): add executor behavior reference table to README
    • style(pre-commit): autofix
    • fix(autoware_agnocast_wrapper): replace forbidden word ROS2 with ROS 2
    • style(pre-commit): autofix

    * fix(autoware_agnocast_wrapper): remove static_assert that fails in non-template main() The static_assert inside if constexpr (agnocast_only) is always evaluated because main() is not a template function. Additionally, the component type header is not included in the generated source (loaded via class_loader at runtime), so the type cannot be resolved at compile time.

    • delete deprecated mark from publish(const MessageT&) API
    • support message_filter in agnocast_wrapper
    • style(pre-commit): autofix
    • fix cpplint
    • fix cpplint
    • add comments

File truncated at 100 lines see the full file

Launch files

Messages

No message files found.

Services

No service files found

Plugins

No plugins found.

Recent questions tagged autoware_agnocast_wrapper at Robotics Stack Exchange

No version for distro galactic showing humble. Known supported distros are highlighted in the buttons above.
Package symbol

autoware_agnocast_wrapper package from autoware_core repo

autoware_adapi_adaptors autoware_adapi_specs autoware_core_api autoware_default_adapi autoware_core autoware_agnocast_wrapper autoware_component_interface_specs autoware_geography_utils autoware_global_parameter_loader autoware_interpolation autoware_kalman_filter autoware_lanelet2_utils autoware_marker_utils autoware_motion_utils autoware_node autoware_object_recognition_utils autoware_osqp_interface autoware_point_types autoware_qos_utils autoware_qp_interface autoware_signal_processing autoware_trajectory autoware_vehicle_info_utils autoware_core_control autoware_simple_pure_pursuit autoware_awsim_sensor_kit_description autoware_sample_sensor_kit_description autoware_sample_vehicle_description autoware_core_localization autoware_ekf_localizer autoware_gyro_odometer autoware_localization_util autoware_ndt_scan_matcher autoware_pose_initializer autoware_stop_filter autoware_twist2accel autoware_core_map autoware_lanelet2_map_visualizer autoware_map_height_fitter autoware_map_loader autoware_map_projection_loader autoware_core_perception autoware_euclidean_cluster_object_detector autoware_ground_filter autoware_perception_objects_converter autoware_core_planning autoware_mission_planner autoware_objects_of_interest_marker_interface autoware_path_generator autoware_planning_factor_interface autoware_planning_topic_converter autoware_route_handler autoware_velocity_smoother autoware_behavior_velocity_planner autoware_behavior_velocity_planner_common autoware_behavior_velocity_stop_line_module autoware_motion_velocity_obstacle_stop_module autoware_motion_velocity_planner autoware_motion_velocity_planner_common autoware_core_sensing autoware_crop_box_filter autoware_downsample_filters autoware_gnss_poser autoware_vehicle_velocity_converter autoware_planning_test_manager autoware_pyplot autoware_test_node autoware_test_utils autoware_testing autoware_core_vehicle

ROS Distro
humble

Package Summary

Version 1.8.0
License Apache License 2.0
Build type AMENT_CMAKE
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/autowarefoundation/autoware_core.git
VCS Type git
VCS Version main
Last Updated 2026-05-12
Dev Status DEVELOPED
Released RELEASED
Contributing Help Wanted (-)
Good First Issues (-)
Pull Requests to Review (-)

Package Description

Wrapper macros for Agnocast (true zero-copy communication library)

Maintainers

  • Takahiro Ishikawa-Aso
  • Koichi Imai
  • Atsushi Yano

Authors

No additional authors.

autoware_agnocast_wrapper

The purpose of this package is to integrate Agnocast, a zero-copy middleware, into each topic in Autoware with minimal side effects. Agnocast is a library designed to work alongside ROS 2, enabling true zero-copy publish/subscribe communication for all ROS 2 message types, including unsized message types.

This package provides macros that wrap functions for publish/subscribe operations and smart pointer types for handling ROS 2 messages. When Autoware is built using the default build command, Agnocast is not enabled. However, setting the environment variable ENABLE_AGNOCAST=1 enables Agnocast and results in a build that includes its integration. This design ensures backward compatibility for users who are unaware of Agnocast, minimizing disruption.

Two Integration Approaches

This package provides two approaches for integrating Agnocast. Both will coexist for the foreseeable future.

1. Node Wrapper (agnocast_wrapper::Node)

Use this when you want the entire node to transparently switch between rclcpp::Node and agnocast::Node at runtime. The node wrapper automatically selects the correct underlying implementation based on the ENABLE_AGNOCAST environment variable.

Currently supported APIs:

  • Publisher / Subscription / PollingSubscriber
  • Parameters
  • Logger, Clock
  • Callback groups
  • Node interfaces (partial: get_node_base_interface(), get_node_topics_interface(), get_node_parameters_interface())

Note: Timer (create_wall_timer, create_timer) is not yet supported and will be added in a future update.

#include <autoware/agnocast_wrapper/node.hpp>

class MyNode : public autoware::agnocast_wrapper::Node
{
public:
  explicit MyNode(const rclcpp::NodeOptions & options)
  : Node("my_node", options)
  {
    pub_ = create_publisher<std_msgs::msg::String>("output", 10);
    sub_ = create_subscription<std_msgs::msg::String>(
      "input", 10, [this](std::unique_ptr<const std_msgs::msg::String> msg) { /* ... */ });
  }

private:
  autoware::agnocast_wrapper::Publisher<std_msgs::msg::String>::SharedPtr pub_;
  autoware::agnocast_wrapper::Subscription<std_msgs::msg::String>::SharedPtr sub_;
};

To use the Node wrapper in your package, add the following to your CMakeLists.txt:

find_package(autoware_agnocast_wrapper REQUIRED)
ament_target_dependencies(my_node_component autoware_agnocast_wrapper)

Registering a Node with autoware_agnocast_wrapper_register_node

Instead of calling rclcpp_components_register_node directly, use the autoware_agnocast_wrapper_register_node macro to register your component node. This macro:

  1. Registers the component with rclcpp_components (for component container support)
  2. Creates a standalone executable that can switch between rclcpp::Node and agnocast::Node at runtime based on the ENABLE_AGNOCAST environment variable

When ENABLE_AGNOCAST is not set or set to 0, this macro falls back to standard rclcpp_components_register_node behavior.

find_package(autoware_agnocast_wrapper REQUIRED)

ament_auto_add_library(my_node_component SHARED src/my_node.cpp)
ament_target_dependencies(my_node_component autoware_agnocast_wrapper)

autoware_agnocast_wrapper_register_node(my_node_component
  PLUGIN "my_package::MyNode"
  EXECUTABLE my_node
)

Parameters:

Parameter Required Default Description
PLUGIN Yes - Fully qualified class name of the component
EXECUTABLE Yes - Executable name for the node
ROS2_EXECUTOR No SingleThreadedExecutor Executor to use when ENABLE_AGNOCAST=0 at runtime
AGNOCAST_EXECUTOR No SingleThreadedAgnocastExecutor Executor to use when ENABLE_AGNOCAST=1 at runtime

Valid executor values:

  • ROS2_EXECUTOR: SingleThreadedExecutor, MultiThreadedExecutor
  • AGNOCAST_EXECUTOR: SingleThreadedAgnocastExecutor, MultiThreadedAgnocastExecutor, CallbackIsolatedAgnocastExecutor, AgnocastOnlySingleThreadedExecutor, AgnocastOnlyMultiThreadedExecutor, AgnocastOnlyCallbackIsolatedExecutor

Node class requirements:

The required PLUGIN base class depends on the AGNOCAST_EXECUTOR type. The generated template enforces this via if constexpr at compile time:

AGNOCAST_EXECUTOR Required PLUGIN base class
AgnocastOnly* executors autoware::agnocast_wrapper::Node
Other agnocast executors Any rclcpp::Node-compatible class

Non-AgnocastOnly executors use NodeInstanceWrapper::get_node_base_interface() directly, which works with any node type (rclcpp::Node, agnocast_wrapper::Node, etc.) without requiring a cast. AgnocastOnly executors require get_agnocast_node(), which is only available on autoware::agnocast_wrapper::Node.

File truncated at 100 lines see the full file

CHANGELOG

Changelog for package autoware_agnocast_wrapper

1.8.0 (2026-05-01)

  • chore: align package versions to 1.7.0 and reset changelogs

  • Merge remote-tracking branch 'origin/main' into tmp/bot/bump_version_base

  • docs(autoware_agnocast_wrapper): use FindPackageShare and PathJoinSubstitution in Python launch examples (#999)

  • fix(autoware_agnocast_wrapper): support jazzy (rclcpp 28~) (#980) fix(autoware_agnocast_wrapper): fix Jazzy build by using version-conditional callback type alias

  • fix(autoware_agnocast_wrapper): fix false positive LD_PRELOAD warning in agnocast_env.launch.py (#973)

  • refactor(autoware_agnocast_wrapper): remove executor threading model consistency validation (#970)

    • refactor(autoware_agnocast_wrapper): remove executor threading model consistency validation
    • docs(autoware_agnocast_wrapper): clarify behavior reference tables in README

    - Reword introductory sentence to clarify that only ROS2_EXECUTOR matters when ENABLE_AGNOCAST=0

    - Use full CMake option strings (e.g. SingleThreadedExecutor) instead of abbreviations in both behavior reference tables

    • style(pre-commit): autofix

    * fix(autoware_agnocast_wrapper): fix forbidden word ROS2 to ROS 2 in README ---------Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>

  • feat(autoware_agnocast_wrapper): support message filter in agnocast wrapper (#951)

    * feat(autoware_agnocast_wrapper): add register_node macro for runtime rclcpp/agnocast switching Add [autoware_agnocast_wrapper_register_node]{.title-ref} CMake macro as a drop-in replacement for [rclcpp_components_register_node]{.title-ref}. When ENABLE_AGNOCAST=1, it generates a standalone executable that can switch between rclcpp::Node and agnocast::Node at runtime based on the ENABLE_AGNOCAST environment variable. When ENABLE_AGNOCAST is not set, it falls back to standard rclcpp_components_register_node behavior with zero overhead. Key features:

    • Configurable ROS2 and Agnocast executor types
    • Two-pass template generation (configure_file + file(GENERATE))
    • Support for both rclcpp::Node and agnocast_wrapper::Node plugins
    • Target existence validation at configure time
    • ABI consistency enforcement via autoware_agnocast_wrapper_setup()
    • Change agnocastlib from build_depend to depend
    • fix(autoware_agnocast_wrapper): add static_assert to enforce PLUGIN base class at compile time

    * fix(autoware_agnocast_wrapper): add runtime ROS2 fallback for AgnocastOnly executors When agnocast_only=true but ENABLE_AGNOCAST=0 at runtime, the node now falls back to the ROS2 executor instead of unconditionally using the AgnocastOnly executor.

    * fix(autoware_agnocast_wrapper): warn on mismatched executor threading models Emit a CMake WARNING when ROS2_EXECUTOR and AGNOCAST_EXECUTOR have different threading models (e.g., SingleThreadedExecutor with MultiThreadedAgnocastExecutor), as this silently changes behavior depending on the runtime ENABLE_AGNOCAST value.

    • docs(autoware_agnocast_wrapper): add executor behavior reference table to README
    • style(pre-commit): autofix
    • fix(autoware_agnocast_wrapper): replace forbidden word ROS2 with ROS 2
    • style(pre-commit): autofix

    * fix(autoware_agnocast_wrapper): remove static_assert that fails in non-template main() The static_assert inside if constexpr (agnocast_only) is always evaluated because main() is not a template function. Additionally, the component type header is not included in the generated source (loaded via class_loader at runtime), so the type cannot be resolved at compile time.

    • delete deprecated mark from publish(const MessageT&) API
    • support message_filter in agnocast_wrapper
    • style(pre-commit): autofix
    • fix cpplint
    • fix cpplint
    • add comments

File truncated at 100 lines see the full file

Launch files

Messages

No message files found.

Services

No service files found

Plugins

No plugins found.

Recent questions tagged autoware_agnocast_wrapper at Robotics Stack Exchange

No version for distro foxy showing humble. Known supported distros are highlighted in the buttons above.
Package symbol

autoware_agnocast_wrapper package from autoware_core repo

autoware_adapi_adaptors autoware_adapi_specs autoware_core_api autoware_default_adapi autoware_core autoware_agnocast_wrapper autoware_component_interface_specs autoware_geography_utils autoware_global_parameter_loader autoware_interpolation autoware_kalman_filter autoware_lanelet2_utils autoware_marker_utils autoware_motion_utils autoware_node autoware_object_recognition_utils autoware_osqp_interface autoware_point_types autoware_qos_utils autoware_qp_interface autoware_signal_processing autoware_trajectory autoware_vehicle_info_utils autoware_core_control autoware_simple_pure_pursuit autoware_awsim_sensor_kit_description autoware_sample_sensor_kit_description autoware_sample_vehicle_description autoware_core_localization autoware_ekf_localizer autoware_gyro_odometer autoware_localization_util autoware_ndt_scan_matcher autoware_pose_initializer autoware_stop_filter autoware_twist2accel autoware_core_map autoware_lanelet2_map_visualizer autoware_map_height_fitter autoware_map_loader autoware_map_projection_loader autoware_core_perception autoware_euclidean_cluster_object_detector autoware_ground_filter autoware_perception_objects_converter autoware_core_planning autoware_mission_planner autoware_objects_of_interest_marker_interface autoware_path_generator autoware_planning_factor_interface autoware_planning_topic_converter autoware_route_handler autoware_velocity_smoother autoware_behavior_velocity_planner autoware_behavior_velocity_planner_common autoware_behavior_velocity_stop_line_module autoware_motion_velocity_obstacle_stop_module autoware_motion_velocity_planner autoware_motion_velocity_planner_common autoware_core_sensing autoware_crop_box_filter autoware_downsample_filters autoware_gnss_poser autoware_vehicle_velocity_converter autoware_planning_test_manager autoware_pyplot autoware_test_node autoware_test_utils autoware_testing autoware_core_vehicle

ROS Distro
humble

Package Summary

Version 1.8.0
License Apache License 2.0
Build type AMENT_CMAKE
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/autowarefoundation/autoware_core.git
VCS Type git
VCS Version main
Last Updated 2026-05-12
Dev Status DEVELOPED
Released RELEASED
Contributing Help Wanted (-)
Good First Issues (-)
Pull Requests to Review (-)

Package Description

Wrapper macros for Agnocast (true zero-copy communication library)

Maintainers

  • Takahiro Ishikawa-Aso
  • Koichi Imai
  • Atsushi Yano

Authors

No additional authors.

autoware_agnocast_wrapper

The purpose of this package is to integrate Agnocast, a zero-copy middleware, into each topic in Autoware with minimal side effects. Agnocast is a library designed to work alongside ROS 2, enabling true zero-copy publish/subscribe communication for all ROS 2 message types, including unsized message types.

This package provides macros that wrap functions for publish/subscribe operations and smart pointer types for handling ROS 2 messages. When Autoware is built using the default build command, Agnocast is not enabled. However, setting the environment variable ENABLE_AGNOCAST=1 enables Agnocast and results in a build that includes its integration. This design ensures backward compatibility for users who are unaware of Agnocast, minimizing disruption.

Two Integration Approaches

This package provides two approaches for integrating Agnocast. Both will coexist for the foreseeable future.

1. Node Wrapper (agnocast_wrapper::Node)

Use this when you want the entire node to transparently switch between rclcpp::Node and agnocast::Node at runtime. The node wrapper automatically selects the correct underlying implementation based on the ENABLE_AGNOCAST environment variable.

Currently supported APIs:

  • Publisher / Subscription / PollingSubscriber
  • Parameters
  • Logger, Clock
  • Callback groups
  • Node interfaces (partial: get_node_base_interface(), get_node_topics_interface(), get_node_parameters_interface())

Note: Timer (create_wall_timer, create_timer) is not yet supported and will be added in a future update.

#include <autoware/agnocast_wrapper/node.hpp>

class MyNode : public autoware::agnocast_wrapper::Node
{
public:
  explicit MyNode(const rclcpp::NodeOptions & options)
  : Node("my_node", options)
  {
    pub_ = create_publisher<std_msgs::msg::String>("output", 10);
    sub_ = create_subscription<std_msgs::msg::String>(
      "input", 10, [this](std::unique_ptr<const std_msgs::msg::String> msg) { /* ... */ });
  }

private:
  autoware::agnocast_wrapper::Publisher<std_msgs::msg::String>::SharedPtr pub_;
  autoware::agnocast_wrapper::Subscription<std_msgs::msg::String>::SharedPtr sub_;
};

To use the Node wrapper in your package, add the following to your CMakeLists.txt:

find_package(autoware_agnocast_wrapper REQUIRED)
ament_target_dependencies(my_node_component autoware_agnocast_wrapper)

Registering a Node with autoware_agnocast_wrapper_register_node

Instead of calling rclcpp_components_register_node directly, use the autoware_agnocast_wrapper_register_node macro to register your component node. This macro:

  1. Registers the component with rclcpp_components (for component container support)
  2. Creates a standalone executable that can switch between rclcpp::Node and agnocast::Node at runtime based on the ENABLE_AGNOCAST environment variable

When ENABLE_AGNOCAST is not set or set to 0, this macro falls back to standard rclcpp_components_register_node behavior.

find_package(autoware_agnocast_wrapper REQUIRED)

ament_auto_add_library(my_node_component SHARED src/my_node.cpp)
ament_target_dependencies(my_node_component autoware_agnocast_wrapper)

autoware_agnocast_wrapper_register_node(my_node_component
  PLUGIN "my_package::MyNode"
  EXECUTABLE my_node
)

Parameters:

Parameter Required Default Description
PLUGIN Yes - Fully qualified class name of the component
EXECUTABLE Yes - Executable name for the node
ROS2_EXECUTOR No SingleThreadedExecutor Executor to use when ENABLE_AGNOCAST=0 at runtime
AGNOCAST_EXECUTOR No SingleThreadedAgnocastExecutor Executor to use when ENABLE_AGNOCAST=1 at runtime

Valid executor values:

  • ROS2_EXECUTOR: SingleThreadedExecutor, MultiThreadedExecutor
  • AGNOCAST_EXECUTOR: SingleThreadedAgnocastExecutor, MultiThreadedAgnocastExecutor, CallbackIsolatedAgnocastExecutor, AgnocastOnlySingleThreadedExecutor, AgnocastOnlyMultiThreadedExecutor, AgnocastOnlyCallbackIsolatedExecutor

Node class requirements:

The required PLUGIN base class depends on the AGNOCAST_EXECUTOR type. The generated template enforces this via if constexpr at compile time:

AGNOCAST_EXECUTOR Required PLUGIN base class
AgnocastOnly* executors autoware::agnocast_wrapper::Node
Other agnocast executors Any rclcpp::Node-compatible class

Non-AgnocastOnly executors use NodeInstanceWrapper::get_node_base_interface() directly, which works with any node type (rclcpp::Node, agnocast_wrapper::Node, etc.) without requiring a cast. AgnocastOnly executors require get_agnocast_node(), which is only available on autoware::agnocast_wrapper::Node.

File truncated at 100 lines see the full file

CHANGELOG

Changelog for package autoware_agnocast_wrapper

1.8.0 (2026-05-01)

  • chore: align package versions to 1.7.0 and reset changelogs

  • Merge remote-tracking branch 'origin/main' into tmp/bot/bump_version_base

  • docs(autoware_agnocast_wrapper): use FindPackageShare and PathJoinSubstitution in Python launch examples (#999)

  • fix(autoware_agnocast_wrapper): support jazzy (rclcpp 28~) (#980) fix(autoware_agnocast_wrapper): fix Jazzy build by using version-conditional callback type alias

  • fix(autoware_agnocast_wrapper): fix false positive LD_PRELOAD warning in agnocast_env.launch.py (#973)

  • refactor(autoware_agnocast_wrapper): remove executor threading model consistency validation (#970)

    • refactor(autoware_agnocast_wrapper): remove executor threading model consistency validation
    • docs(autoware_agnocast_wrapper): clarify behavior reference tables in README

    - Reword introductory sentence to clarify that only ROS2_EXECUTOR matters when ENABLE_AGNOCAST=0

    - Use full CMake option strings (e.g. SingleThreadedExecutor) instead of abbreviations in both behavior reference tables

    • style(pre-commit): autofix

    * fix(autoware_agnocast_wrapper): fix forbidden word ROS2 to ROS 2 in README ---------Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>

  • feat(autoware_agnocast_wrapper): support message filter in agnocast wrapper (#951)

    * feat(autoware_agnocast_wrapper): add register_node macro for runtime rclcpp/agnocast switching Add [autoware_agnocast_wrapper_register_node]{.title-ref} CMake macro as a drop-in replacement for [rclcpp_components_register_node]{.title-ref}. When ENABLE_AGNOCAST=1, it generates a standalone executable that can switch between rclcpp::Node and agnocast::Node at runtime based on the ENABLE_AGNOCAST environment variable. When ENABLE_AGNOCAST is not set, it falls back to standard rclcpp_components_register_node behavior with zero overhead. Key features:

    • Configurable ROS2 and Agnocast executor types
    • Two-pass template generation (configure_file + file(GENERATE))
    • Support for both rclcpp::Node and agnocast_wrapper::Node plugins
    • Target existence validation at configure time
    • ABI consistency enforcement via autoware_agnocast_wrapper_setup()
    • Change agnocastlib from build_depend to depend
    • fix(autoware_agnocast_wrapper): add static_assert to enforce PLUGIN base class at compile time

    * fix(autoware_agnocast_wrapper): add runtime ROS2 fallback for AgnocastOnly executors When agnocast_only=true but ENABLE_AGNOCAST=0 at runtime, the node now falls back to the ROS2 executor instead of unconditionally using the AgnocastOnly executor.

    * fix(autoware_agnocast_wrapper): warn on mismatched executor threading models Emit a CMake WARNING when ROS2_EXECUTOR and AGNOCAST_EXECUTOR have different threading models (e.g., SingleThreadedExecutor with MultiThreadedAgnocastExecutor), as this silently changes behavior depending on the runtime ENABLE_AGNOCAST value.

    • docs(autoware_agnocast_wrapper): add executor behavior reference table to README
    • style(pre-commit): autofix
    • fix(autoware_agnocast_wrapper): replace forbidden word ROS2 with ROS 2
    • style(pre-commit): autofix

    * fix(autoware_agnocast_wrapper): remove static_assert that fails in non-template main() The static_assert inside if constexpr (agnocast_only) is always evaluated because main() is not a template function. Additionally, the component type header is not included in the generated source (loaded via class_loader at runtime), so the type cannot be resolved at compile time.

    • delete deprecated mark from publish(const MessageT&) API
    • support message_filter in agnocast_wrapper
    • style(pre-commit): autofix
    • fix cpplint
    • fix cpplint
    • add comments

File truncated at 100 lines see the full file

Launch files

Messages

No message files found.

Services

No service files found

Plugins

No plugins found.

Recent questions tagged autoware_agnocast_wrapper at Robotics Stack Exchange

No version for distro iron showing humble. Known supported distros are highlighted in the buttons above.
Package symbol

autoware_agnocast_wrapper package from autoware_core repo

autoware_adapi_adaptors autoware_adapi_specs autoware_core_api autoware_default_adapi autoware_core autoware_agnocast_wrapper autoware_component_interface_specs autoware_geography_utils autoware_global_parameter_loader autoware_interpolation autoware_kalman_filter autoware_lanelet2_utils autoware_marker_utils autoware_motion_utils autoware_node autoware_object_recognition_utils autoware_osqp_interface autoware_point_types autoware_qos_utils autoware_qp_interface autoware_signal_processing autoware_trajectory autoware_vehicle_info_utils autoware_core_control autoware_simple_pure_pursuit autoware_awsim_sensor_kit_description autoware_sample_sensor_kit_description autoware_sample_vehicle_description autoware_core_localization autoware_ekf_localizer autoware_gyro_odometer autoware_localization_util autoware_ndt_scan_matcher autoware_pose_initializer autoware_stop_filter autoware_twist2accel autoware_core_map autoware_lanelet2_map_visualizer autoware_map_height_fitter autoware_map_loader autoware_map_projection_loader autoware_core_perception autoware_euclidean_cluster_object_detector autoware_ground_filter autoware_perception_objects_converter autoware_core_planning autoware_mission_planner autoware_objects_of_interest_marker_interface autoware_path_generator autoware_planning_factor_interface autoware_planning_topic_converter autoware_route_handler autoware_velocity_smoother autoware_behavior_velocity_planner autoware_behavior_velocity_planner_common autoware_behavior_velocity_stop_line_module autoware_motion_velocity_obstacle_stop_module autoware_motion_velocity_planner autoware_motion_velocity_planner_common autoware_core_sensing autoware_crop_box_filter autoware_downsample_filters autoware_gnss_poser autoware_vehicle_velocity_converter autoware_planning_test_manager autoware_pyplot autoware_test_node autoware_test_utils autoware_testing autoware_core_vehicle

ROS Distro
humble

Package Summary

Version 1.8.0
License Apache License 2.0
Build type AMENT_CMAKE
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/autowarefoundation/autoware_core.git
VCS Type git
VCS Version main
Last Updated 2026-05-12
Dev Status DEVELOPED
Released RELEASED
Contributing Help Wanted (-)
Good First Issues (-)
Pull Requests to Review (-)

Package Description

Wrapper macros for Agnocast (true zero-copy communication library)

Maintainers

  • Takahiro Ishikawa-Aso
  • Koichi Imai
  • Atsushi Yano

Authors

No additional authors.

autoware_agnocast_wrapper

The purpose of this package is to integrate Agnocast, a zero-copy middleware, into each topic in Autoware with minimal side effects. Agnocast is a library designed to work alongside ROS 2, enabling true zero-copy publish/subscribe communication for all ROS 2 message types, including unsized message types.

This package provides macros that wrap functions for publish/subscribe operations and smart pointer types for handling ROS 2 messages. When Autoware is built using the default build command, Agnocast is not enabled. However, setting the environment variable ENABLE_AGNOCAST=1 enables Agnocast and results in a build that includes its integration. This design ensures backward compatibility for users who are unaware of Agnocast, minimizing disruption.

Two Integration Approaches

This package provides two approaches for integrating Agnocast. Both will coexist for the foreseeable future.

1. Node Wrapper (agnocast_wrapper::Node)

Use this when you want the entire node to transparently switch between rclcpp::Node and agnocast::Node at runtime. The node wrapper automatically selects the correct underlying implementation based on the ENABLE_AGNOCAST environment variable.

Currently supported APIs:

  • Publisher / Subscription / PollingSubscriber
  • Parameters
  • Logger, Clock
  • Callback groups
  • Node interfaces (partial: get_node_base_interface(), get_node_topics_interface(), get_node_parameters_interface())

Note: Timer (create_wall_timer, create_timer) is not yet supported and will be added in a future update.

#include <autoware/agnocast_wrapper/node.hpp>

class MyNode : public autoware::agnocast_wrapper::Node
{
public:
  explicit MyNode(const rclcpp::NodeOptions & options)
  : Node("my_node", options)
  {
    pub_ = create_publisher<std_msgs::msg::String>("output", 10);
    sub_ = create_subscription<std_msgs::msg::String>(
      "input", 10, [this](std::unique_ptr<const std_msgs::msg::String> msg) { /* ... */ });
  }

private:
  autoware::agnocast_wrapper::Publisher<std_msgs::msg::String>::SharedPtr pub_;
  autoware::agnocast_wrapper::Subscription<std_msgs::msg::String>::SharedPtr sub_;
};

To use the Node wrapper in your package, add the following to your CMakeLists.txt:

find_package(autoware_agnocast_wrapper REQUIRED)
ament_target_dependencies(my_node_component autoware_agnocast_wrapper)

Registering a Node with autoware_agnocast_wrapper_register_node

Instead of calling rclcpp_components_register_node directly, use the autoware_agnocast_wrapper_register_node macro to register your component node. This macro:

  1. Registers the component with rclcpp_components (for component container support)
  2. Creates a standalone executable that can switch between rclcpp::Node and agnocast::Node at runtime based on the ENABLE_AGNOCAST environment variable

When ENABLE_AGNOCAST is not set or set to 0, this macro falls back to standard rclcpp_components_register_node behavior.

find_package(autoware_agnocast_wrapper REQUIRED)

ament_auto_add_library(my_node_component SHARED src/my_node.cpp)
ament_target_dependencies(my_node_component autoware_agnocast_wrapper)

autoware_agnocast_wrapper_register_node(my_node_component
  PLUGIN "my_package::MyNode"
  EXECUTABLE my_node
)

Parameters:

Parameter Required Default Description
PLUGIN Yes - Fully qualified class name of the component
EXECUTABLE Yes - Executable name for the node
ROS2_EXECUTOR No SingleThreadedExecutor Executor to use when ENABLE_AGNOCAST=0 at runtime
AGNOCAST_EXECUTOR No SingleThreadedAgnocastExecutor Executor to use when ENABLE_AGNOCAST=1 at runtime

Valid executor values:

  • ROS2_EXECUTOR: SingleThreadedExecutor, MultiThreadedExecutor
  • AGNOCAST_EXECUTOR: SingleThreadedAgnocastExecutor, MultiThreadedAgnocastExecutor, CallbackIsolatedAgnocastExecutor, AgnocastOnlySingleThreadedExecutor, AgnocastOnlyMultiThreadedExecutor, AgnocastOnlyCallbackIsolatedExecutor

Node class requirements:

The required PLUGIN base class depends on the AGNOCAST_EXECUTOR type. The generated template enforces this via if constexpr at compile time:

AGNOCAST_EXECUTOR Required PLUGIN base class
AgnocastOnly* executors autoware::agnocast_wrapper::Node
Other agnocast executors Any rclcpp::Node-compatible class

Non-AgnocastOnly executors use NodeInstanceWrapper::get_node_base_interface() directly, which works with any node type (rclcpp::Node, agnocast_wrapper::Node, etc.) without requiring a cast. AgnocastOnly executors require get_agnocast_node(), which is only available on autoware::agnocast_wrapper::Node.

File truncated at 100 lines see the full file

CHANGELOG

Changelog for package autoware_agnocast_wrapper

1.8.0 (2026-05-01)

  • chore: align package versions to 1.7.0 and reset changelogs

  • Merge remote-tracking branch 'origin/main' into tmp/bot/bump_version_base

  • docs(autoware_agnocast_wrapper): use FindPackageShare and PathJoinSubstitution in Python launch examples (#999)

  • fix(autoware_agnocast_wrapper): support jazzy (rclcpp 28~) (#980) fix(autoware_agnocast_wrapper): fix Jazzy build by using version-conditional callback type alias

  • fix(autoware_agnocast_wrapper): fix false positive LD_PRELOAD warning in agnocast_env.launch.py (#973)

  • refactor(autoware_agnocast_wrapper): remove executor threading model consistency validation (#970)

    • refactor(autoware_agnocast_wrapper): remove executor threading model consistency validation
    • docs(autoware_agnocast_wrapper): clarify behavior reference tables in README

    - Reword introductory sentence to clarify that only ROS2_EXECUTOR matters when ENABLE_AGNOCAST=0

    - Use full CMake option strings (e.g. SingleThreadedExecutor) instead of abbreviations in both behavior reference tables

    • style(pre-commit): autofix

    * fix(autoware_agnocast_wrapper): fix forbidden word ROS2 to ROS 2 in README ---------Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>

  • feat(autoware_agnocast_wrapper): support message filter in agnocast wrapper (#951)

    * feat(autoware_agnocast_wrapper): add register_node macro for runtime rclcpp/agnocast switching Add [autoware_agnocast_wrapper_register_node]{.title-ref} CMake macro as a drop-in replacement for [rclcpp_components_register_node]{.title-ref}. When ENABLE_AGNOCAST=1, it generates a standalone executable that can switch between rclcpp::Node and agnocast::Node at runtime based on the ENABLE_AGNOCAST environment variable. When ENABLE_AGNOCAST is not set, it falls back to standard rclcpp_components_register_node behavior with zero overhead. Key features:

    • Configurable ROS2 and Agnocast executor types
    • Two-pass template generation (configure_file + file(GENERATE))
    • Support for both rclcpp::Node and agnocast_wrapper::Node plugins
    • Target existence validation at configure time
    • ABI consistency enforcement via autoware_agnocast_wrapper_setup()
    • Change agnocastlib from build_depend to depend
    • fix(autoware_agnocast_wrapper): add static_assert to enforce PLUGIN base class at compile time

    * fix(autoware_agnocast_wrapper): add runtime ROS2 fallback for AgnocastOnly executors When agnocast_only=true but ENABLE_AGNOCAST=0 at runtime, the node now falls back to the ROS2 executor instead of unconditionally using the AgnocastOnly executor.

    * fix(autoware_agnocast_wrapper): warn on mismatched executor threading models Emit a CMake WARNING when ROS2_EXECUTOR and AGNOCAST_EXECUTOR have different threading models (e.g., SingleThreadedExecutor with MultiThreadedAgnocastExecutor), as this silently changes behavior depending on the runtime ENABLE_AGNOCAST value.

    • docs(autoware_agnocast_wrapper): add executor behavior reference table to README
    • style(pre-commit): autofix
    • fix(autoware_agnocast_wrapper): replace forbidden word ROS2 with ROS 2
    • style(pre-commit): autofix

    * fix(autoware_agnocast_wrapper): remove static_assert that fails in non-template main() The static_assert inside if constexpr (agnocast_only) is always evaluated because main() is not a template function. Additionally, the component type header is not included in the generated source (loaded via class_loader at runtime), so the type cannot be resolved at compile time.

    • delete deprecated mark from publish(const MessageT&) API
    • support message_filter in agnocast_wrapper
    • style(pre-commit): autofix
    • fix cpplint
    • fix cpplint
    • add comments

File truncated at 100 lines see the full file

Launch files

Messages

No message files found.

Services

No service files found

Plugins

No plugins found.

Recent questions tagged autoware_agnocast_wrapper at Robotics Stack Exchange

No version for distro lunar showing humble. Known supported distros are highlighted in the buttons above.
Package symbol

autoware_agnocast_wrapper package from autoware_core repo

autoware_adapi_adaptors autoware_adapi_specs autoware_core_api autoware_default_adapi autoware_core autoware_agnocast_wrapper autoware_component_interface_specs autoware_geography_utils autoware_global_parameter_loader autoware_interpolation autoware_kalman_filter autoware_lanelet2_utils autoware_marker_utils autoware_motion_utils autoware_node autoware_object_recognition_utils autoware_osqp_interface autoware_point_types autoware_qos_utils autoware_qp_interface autoware_signal_processing autoware_trajectory autoware_vehicle_info_utils autoware_core_control autoware_simple_pure_pursuit autoware_awsim_sensor_kit_description autoware_sample_sensor_kit_description autoware_sample_vehicle_description autoware_core_localization autoware_ekf_localizer autoware_gyro_odometer autoware_localization_util autoware_ndt_scan_matcher autoware_pose_initializer autoware_stop_filter autoware_twist2accel autoware_core_map autoware_lanelet2_map_visualizer autoware_map_height_fitter autoware_map_loader autoware_map_projection_loader autoware_core_perception autoware_euclidean_cluster_object_detector autoware_ground_filter autoware_perception_objects_converter autoware_core_planning autoware_mission_planner autoware_objects_of_interest_marker_interface autoware_path_generator autoware_planning_factor_interface autoware_planning_topic_converter autoware_route_handler autoware_velocity_smoother autoware_behavior_velocity_planner autoware_behavior_velocity_planner_common autoware_behavior_velocity_stop_line_module autoware_motion_velocity_obstacle_stop_module autoware_motion_velocity_planner autoware_motion_velocity_planner_common autoware_core_sensing autoware_crop_box_filter autoware_downsample_filters autoware_gnss_poser autoware_vehicle_velocity_converter autoware_planning_test_manager autoware_pyplot autoware_test_node autoware_test_utils autoware_testing autoware_core_vehicle

ROS Distro
humble

Package Summary

Version 1.8.0
License Apache License 2.0
Build type AMENT_CMAKE
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/autowarefoundation/autoware_core.git
VCS Type git
VCS Version main
Last Updated 2026-05-12
Dev Status DEVELOPED
Released RELEASED
Contributing Help Wanted (-)
Good First Issues (-)
Pull Requests to Review (-)

Package Description

Wrapper macros for Agnocast (true zero-copy communication library)

Maintainers

  • Takahiro Ishikawa-Aso
  • Koichi Imai
  • Atsushi Yano

Authors

No additional authors.

autoware_agnocast_wrapper

The purpose of this package is to integrate Agnocast, a zero-copy middleware, into each topic in Autoware with minimal side effects. Agnocast is a library designed to work alongside ROS 2, enabling true zero-copy publish/subscribe communication for all ROS 2 message types, including unsized message types.

This package provides macros that wrap functions for publish/subscribe operations and smart pointer types for handling ROS 2 messages. When Autoware is built using the default build command, Agnocast is not enabled. However, setting the environment variable ENABLE_AGNOCAST=1 enables Agnocast and results in a build that includes its integration. This design ensures backward compatibility for users who are unaware of Agnocast, minimizing disruption.

Two Integration Approaches

This package provides two approaches for integrating Agnocast. Both will coexist for the foreseeable future.

1. Node Wrapper (agnocast_wrapper::Node)

Use this when you want the entire node to transparently switch between rclcpp::Node and agnocast::Node at runtime. The node wrapper automatically selects the correct underlying implementation based on the ENABLE_AGNOCAST environment variable.

Currently supported APIs:

  • Publisher / Subscription / PollingSubscriber
  • Parameters
  • Logger, Clock
  • Callback groups
  • Node interfaces (partial: get_node_base_interface(), get_node_topics_interface(), get_node_parameters_interface())

Note: Timer (create_wall_timer, create_timer) is not yet supported and will be added in a future update.

#include <autoware/agnocast_wrapper/node.hpp>

class MyNode : public autoware::agnocast_wrapper::Node
{
public:
  explicit MyNode(const rclcpp::NodeOptions & options)
  : Node("my_node", options)
  {
    pub_ = create_publisher<std_msgs::msg::String>("output", 10);
    sub_ = create_subscription<std_msgs::msg::String>(
      "input", 10, [this](std::unique_ptr<const std_msgs::msg::String> msg) { /* ... */ });
  }

private:
  autoware::agnocast_wrapper::Publisher<std_msgs::msg::String>::SharedPtr pub_;
  autoware::agnocast_wrapper::Subscription<std_msgs::msg::String>::SharedPtr sub_;
};

To use the Node wrapper in your package, add the following to your CMakeLists.txt:

find_package(autoware_agnocast_wrapper REQUIRED)
ament_target_dependencies(my_node_component autoware_agnocast_wrapper)

Registering a Node with autoware_agnocast_wrapper_register_node

Instead of calling rclcpp_components_register_node directly, use the autoware_agnocast_wrapper_register_node macro to register your component node. This macro:

  1. Registers the component with rclcpp_components (for component container support)
  2. Creates a standalone executable that can switch between rclcpp::Node and agnocast::Node at runtime based on the ENABLE_AGNOCAST environment variable

When ENABLE_AGNOCAST is not set or set to 0, this macro falls back to standard rclcpp_components_register_node behavior.

find_package(autoware_agnocast_wrapper REQUIRED)

ament_auto_add_library(my_node_component SHARED src/my_node.cpp)
ament_target_dependencies(my_node_component autoware_agnocast_wrapper)

autoware_agnocast_wrapper_register_node(my_node_component
  PLUGIN "my_package::MyNode"
  EXECUTABLE my_node
)

Parameters:

Parameter Required Default Description
PLUGIN Yes - Fully qualified class name of the component
EXECUTABLE Yes - Executable name for the node
ROS2_EXECUTOR No SingleThreadedExecutor Executor to use when ENABLE_AGNOCAST=0 at runtime
AGNOCAST_EXECUTOR No SingleThreadedAgnocastExecutor Executor to use when ENABLE_AGNOCAST=1 at runtime

Valid executor values:

  • ROS2_EXECUTOR: SingleThreadedExecutor, MultiThreadedExecutor
  • AGNOCAST_EXECUTOR: SingleThreadedAgnocastExecutor, MultiThreadedAgnocastExecutor, CallbackIsolatedAgnocastExecutor, AgnocastOnlySingleThreadedExecutor, AgnocastOnlyMultiThreadedExecutor, AgnocastOnlyCallbackIsolatedExecutor

Node class requirements:

The required PLUGIN base class depends on the AGNOCAST_EXECUTOR type. The generated template enforces this via if constexpr at compile time:

AGNOCAST_EXECUTOR Required PLUGIN base class
AgnocastOnly* executors autoware::agnocast_wrapper::Node
Other agnocast executors Any rclcpp::Node-compatible class

Non-AgnocastOnly executors use NodeInstanceWrapper::get_node_base_interface() directly, which works with any node type (rclcpp::Node, agnocast_wrapper::Node, etc.) without requiring a cast. AgnocastOnly executors require get_agnocast_node(), which is only available on autoware::agnocast_wrapper::Node.

File truncated at 100 lines see the full file

CHANGELOG

Changelog for package autoware_agnocast_wrapper

1.8.0 (2026-05-01)

  • chore: align package versions to 1.7.0 and reset changelogs

  • Merge remote-tracking branch 'origin/main' into tmp/bot/bump_version_base

  • docs(autoware_agnocast_wrapper): use FindPackageShare and PathJoinSubstitution in Python launch examples (#999)

  • fix(autoware_agnocast_wrapper): support jazzy (rclcpp 28~) (#980) fix(autoware_agnocast_wrapper): fix Jazzy build by using version-conditional callback type alias

  • fix(autoware_agnocast_wrapper): fix false positive LD_PRELOAD warning in agnocast_env.launch.py (#973)

  • refactor(autoware_agnocast_wrapper): remove executor threading model consistency validation (#970)

    • refactor(autoware_agnocast_wrapper): remove executor threading model consistency validation
    • docs(autoware_agnocast_wrapper): clarify behavior reference tables in README

    - Reword introductory sentence to clarify that only ROS2_EXECUTOR matters when ENABLE_AGNOCAST=0

    - Use full CMake option strings (e.g. SingleThreadedExecutor) instead of abbreviations in both behavior reference tables

    • style(pre-commit): autofix

    * fix(autoware_agnocast_wrapper): fix forbidden word ROS2 to ROS 2 in README ---------Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>

  • feat(autoware_agnocast_wrapper): support message filter in agnocast wrapper (#951)

    * feat(autoware_agnocast_wrapper): add register_node macro for runtime rclcpp/agnocast switching Add [autoware_agnocast_wrapper_register_node]{.title-ref} CMake macro as a drop-in replacement for [rclcpp_components_register_node]{.title-ref}. When ENABLE_AGNOCAST=1, it generates a standalone executable that can switch between rclcpp::Node and agnocast::Node at runtime based on the ENABLE_AGNOCAST environment variable. When ENABLE_AGNOCAST is not set, it falls back to standard rclcpp_components_register_node behavior with zero overhead. Key features:

    • Configurable ROS2 and Agnocast executor types
    • Two-pass template generation (configure_file + file(GENERATE))
    • Support for both rclcpp::Node and agnocast_wrapper::Node plugins
    • Target existence validation at configure time
    • ABI consistency enforcement via autoware_agnocast_wrapper_setup()
    • Change agnocastlib from build_depend to depend
    • fix(autoware_agnocast_wrapper): add static_assert to enforce PLUGIN base class at compile time

    * fix(autoware_agnocast_wrapper): add runtime ROS2 fallback for AgnocastOnly executors When agnocast_only=true but ENABLE_AGNOCAST=0 at runtime, the node now falls back to the ROS2 executor instead of unconditionally using the AgnocastOnly executor.

    * fix(autoware_agnocast_wrapper): warn on mismatched executor threading models Emit a CMake WARNING when ROS2_EXECUTOR and AGNOCAST_EXECUTOR have different threading models (e.g., SingleThreadedExecutor with MultiThreadedAgnocastExecutor), as this silently changes behavior depending on the runtime ENABLE_AGNOCAST value.

    • docs(autoware_agnocast_wrapper): add executor behavior reference table to README
    • style(pre-commit): autofix
    • fix(autoware_agnocast_wrapper): replace forbidden word ROS2 with ROS 2
    • style(pre-commit): autofix

    * fix(autoware_agnocast_wrapper): remove static_assert that fails in non-template main() The static_assert inside if constexpr (agnocast_only) is always evaluated because main() is not a template function. Additionally, the component type header is not included in the generated source (loaded via class_loader at runtime), so the type cannot be resolved at compile time.

    • delete deprecated mark from publish(const MessageT&) API
    • support message_filter in agnocast_wrapper
    • style(pre-commit): autofix
    • fix cpplint
    • fix cpplint
    • add comments

File truncated at 100 lines see the full file

Launch files

Messages

No message files found.

Services

No service files found

Plugins

No plugins found.

Recent questions tagged autoware_agnocast_wrapper at Robotics Stack Exchange

No version for distro jade showing humble. Known supported distros are highlighted in the buttons above.
Package symbol

autoware_agnocast_wrapper package from autoware_core repo

autoware_adapi_adaptors autoware_adapi_specs autoware_core_api autoware_default_adapi autoware_core autoware_agnocast_wrapper autoware_component_interface_specs autoware_geography_utils autoware_global_parameter_loader autoware_interpolation autoware_kalman_filter autoware_lanelet2_utils autoware_marker_utils autoware_motion_utils autoware_node autoware_object_recognition_utils autoware_osqp_interface autoware_point_types autoware_qos_utils autoware_qp_interface autoware_signal_processing autoware_trajectory autoware_vehicle_info_utils autoware_core_control autoware_simple_pure_pursuit autoware_awsim_sensor_kit_description autoware_sample_sensor_kit_description autoware_sample_vehicle_description autoware_core_localization autoware_ekf_localizer autoware_gyro_odometer autoware_localization_util autoware_ndt_scan_matcher autoware_pose_initializer autoware_stop_filter autoware_twist2accel autoware_core_map autoware_lanelet2_map_visualizer autoware_map_height_fitter autoware_map_loader autoware_map_projection_loader autoware_core_perception autoware_euclidean_cluster_object_detector autoware_ground_filter autoware_perception_objects_converter autoware_core_planning autoware_mission_planner autoware_objects_of_interest_marker_interface autoware_path_generator autoware_planning_factor_interface autoware_planning_topic_converter autoware_route_handler autoware_velocity_smoother autoware_behavior_velocity_planner autoware_behavior_velocity_planner_common autoware_behavior_velocity_stop_line_module autoware_motion_velocity_obstacle_stop_module autoware_motion_velocity_planner autoware_motion_velocity_planner_common autoware_core_sensing autoware_crop_box_filter autoware_downsample_filters autoware_gnss_poser autoware_vehicle_velocity_converter autoware_planning_test_manager autoware_pyplot autoware_test_node autoware_test_utils autoware_testing autoware_core_vehicle

ROS Distro
humble

Package Summary

Version 1.8.0
License Apache License 2.0
Build type AMENT_CMAKE
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/autowarefoundation/autoware_core.git
VCS Type git
VCS Version main
Last Updated 2026-05-12
Dev Status DEVELOPED
Released RELEASED
Contributing Help Wanted (-)
Good First Issues (-)
Pull Requests to Review (-)

Package Description

Wrapper macros for Agnocast (true zero-copy communication library)

Maintainers

  • Takahiro Ishikawa-Aso
  • Koichi Imai
  • Atsushi Yano

Authors

No additional authors.

autoware_agnocast_wrapper

The purpose of this package is to integrate Agnocast, a zero-copy middleware, into each topic in Autoware with minimal side effects. Agnocast is a library designed to work alongside ROS 2, enabling true zero-copy publish/subscribe communication for all ROS 2 message types, including unsized message types.

This package provides macros that wrap functions for publish/subscribe operations and smart pointer types for handling ROS 2 messages. When Autoware is built using the default build command, Agnocast is not enabled. However, setting the environment variable ENABLE_AGNOCAST=1 enables Agnocast and results in a build that includes its integration. This design ensures backward compatibility for users who are unaware of Agnocast, minimizing disruption.

Two Integration Approaches

This package provides two approaches for integrating Agnocast. Both will coexist for the foreseeable future.

1. Node Wrapper (agnocast_wrapper::Node)

Use this when you want the entire node to transparently switch between rclcpp::Node and agnocast::Node at runtime. The node wrapper automatically selects the correct underlying implementation based on the ENABLE_AGNOCAST environment variable.

Currently supported APIs:

  • Publisher / Subscription / PollingSubscriber
  • Parameters
  • Logger, Clock
  • Callback groups
  • Node interfaces (partial: get_node_base_interface(), get_node_topics_interface(), get_node_parameters_interface())

Note: Timer (create_wall_timer, create_timer) is not yet supported and will be added in a future update.

#include <autoware/agnocast_wrapper/node.hpp>

class MyNode : public autoware::agnocast_wrapper::Node
{
public:
  explicit MyNode(const rclcpp::NodeOptions & options)
  : Node("my_node", options)
  {
    pub_ = create_publisher<std_msgs::msg::String>("output", 10);
    sub_ = create_subscription<std_msgs::msg::String>(
      "input", 10, [this](std::unique_ptr<const std_msgs::msg::String> msg) { /* ... */ });
  }

private:
  autoware::agnocast_wrapper::Publisher<std_msgs::msg::String>::SharedPtr pub_;
  autoware::agnocast_wrapper::Subscription<std_msgs::msg::String>::SharedPtr sub_;
};

To use the Node wrapper in your package, add the following to your CMakeLists.txt:

find_package(autoware_agnocast_wrapper REQUIRED)
ament_target_dependencies(my_node_component autoware_agnocast_wrapper)

Registering a Node with autoware_agnocast_wrapper_register_node

Instead of calling rclcpp_components_register_node directly, use the autoware_agnocast_wrapper_register_node macro to register your component node. This macro:

  1. Registers the component with rclcpp_components (for component container support)
  2. Creates a standalone executable that can switch between rclcpp::Node and agnocast::Node at runtime based on the ENABLE_AGNOCAST environment variable

When ENABLE_AGNOCAST is not set or set to 0, this macro falls back to standard rclcpp_components_register_node behavior.

find_package(autoware_agnocast_wrapper REQUIRED)

ament_auto_add_library(my_node_component SHARED src/my_node.cpp)
ament_target_dependencies(my_node_component autoware_agnocast_wrapper)

autoware_agnocast_wrapper_register_node(my_node_component
  PLUGIN "my_package::MyNode"
  EXECUTABLE my_node
)

Parameters:

Parameter Required Default Description
PLUGIN Yes - Fully qualified class name of the component
EXECUTABLE Yes - Executable name for the node
ROS2_EXECUTOR No SingleThreadedExecutor Executor to use when ENABLE_AGNOCAST=0 at runtime
AGNOCAST_EXECUTOR No SingleThreadedAgnocastExecutor Executor to use when ENABLE_AGNOCAST=1 at runtime

Valid executor values:

  • ROS2_EXECUTOR: SingleThreadedExecutor, MultiThreadedExecutor
  • AGNOCAST_EXECUTOR: SingleThreadedAgnocastExecutor, MultiThreadedAgnocastExecutor, CallbackIsolatedAgnocastExecutor, AgnocastOnlySingleThreadedExecutor, AgnocastOnlyMultiThreadedExecutor, AgnocastOnlyCallbackIsolatedExecutor

Node class requirements:

The required PLUGIN base class depends on the AGNOCAST_EXECUTOR type. The generated template enforces this via if constexpr at compile time:

AGNOCAST_EXECUTOR Required PLUGIN base class
AgnocastOnly* executors autoware::agnocast_wrapper::Node
Other agnocast executors Any rclcpp::Node-compatible class

Non-AgnocastOnly executors use NodeInstanceWrapper::get_node_base_interface() directly, which works with any node type (rclcpp::Node, agnocast_wrapper::Node, etc.) without requiring a cast. AgnocastOnly executors require get_agnocast_node(), which is only available on autoware::agnocast_wrapper::Node.

File truncated at 100 lines see the full file

CHANGELOG

Changelog for package autoware_agnocast_wrapper

1.8.0 (2026-05-01)

  • chore: align package versions to 1.7.0 and reset changelogs

  • Merge remote-tracking branch 'origin/main' into tmp/bot/bump_version_base

  • docs(autoware_agnocast_wrapper): use FindPackageShare and PathJoinSubstitution in Python launch examples (#999)

  • fix(autoware_agnocast_wrapper): support jazzy (rclcpp 28~) (#980) fix(autoware_agnocast_wrapper): fix Jazzy build by using version-conditional callback type alias

  • fix(autoware_agnocast_wrapper): fix false positive LD_PRELOAD warning in agnocast_env.launch.py (#973)

  • refactor(autoware_agnocast_wrapper): remove executor threading model consistency validation (#970)

    • refactor(autoware_agnocast_wrapper): remove executor threading model consistency validation
    • docs(autoware_agnocast_wrapper): clarify behavior reference tables in README

    - Reword introductory sentence to clarify that only ROS2_EXECUTOR matters when ENABLE_AGNOCAST=0

    - Use full CMake option strings (e.g. SingleThreadedExecutor) instead of abbreviations in both behavior reference tables

    • style(pre-commit): autofix

    * fix(autoware_agnocast_wrapper): fix forbidden word ROS2 to ROS 2 in README ---------Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>

  • feat(autoware_agnocast_wrapper): support message filter in agnocast wrapper (#951)

    * feat(autoware_agnocast_wrapper): add register_node macro for runtime rclcpp/agnocast switching Add [autoware_agnocast_wrapper_register_node]{.title-ref} CMake macro as a drop-in replacement for [rclcpp_components_register_node]{.title-ref}. When ENABLE_AGNOCAST=1, it generates a standalone executable that can switch between rclcpp::Node and agnocast::Node at runtime based on the ENABLE_AGNOCAST environment variable. When ENABLE_AGNOCAST is not set, it falls back to standard rclcpp_components_register_node behavior with zero overhead. Key features:

    • Configurable ROS2 and Agnocast executor types
    • Two-pass template generation (configure_file + file(GENERATE))
    • Support for both rclcpp::Node and agnocast_wrapper::Node plugins
    • Target existence validation at configure time
    • ABI consistency enforcement via autoware_agnocast_wrapper_setup()
    • Change agnocastlib from build_depend to depend
    • fix(autoware_agnocast_wrapper): add static_assert to enforce PLUGIN base class at compile time

    * fix(autoware_agnocast_wrapper): add runtime ROS2 fallback for AgnocastOnly executors When agnocast_only=true but ENABLE_AGNOCAST=0 at runtime, the node now falls back to the ROS2 executor instead of unconditionally using the AgnocastOnly executor.

    * fix(autoware_agnocast_wrapper): warn on mismatched executor threading models Emit a CMake WARNING when ROS2_EXECUTOR and AGNOCAST_EXECUTOR have different threading models (e.g., SingleThreadedExecutor with MultiThreadedAgnocastExecutor), as this silently changes behavior depending on the runtime ENABLE_AGNOCAST value.

    • docs(autoware_agnocast_wrapper): add executor behavior reference table to README
    • style(pre-commit): autofix
    • fix(autoware_agnocast_wrapper): replace forbidden word ROS2 with ROS 2
    • style(pre-commit): autofix

    * fix(autoware_agnocast_wrapper): remove static_assert that fails in non-template main() The static_assert inside if constexpr (agnocast_only) is always evaluated because main() is not a template function. Additionally, the component type header is not included in the generated source (loaded via class_loader at runtime), so the type cannot be resolved at compile time.

    • delete deprecated mark from publish(const MessageT&) API
    • support message_filter in agnocast_wrapper
    • style(pre-commit): autofix
    • fix cpplint
    • fix cpplint
    • add comments

File truncated at 100 lines see the full file

Launch files

Messages

No message files found.

Services

No service files found

Plugins

No plugins found.

Recent questions tagged autoware_agnocast_wrapper at Robotics Stack Exchange

No version for distro indigo showing humble. Known supported distros are highlighted in the buttons above.
Package symbol

autoware_agnocast_wrapper package from autoware_core repo

autoware_adapi_adaptors autoware_adapi_specs autoware_core_api autoware_default_adapi autoware_core autoware_agnocast_wrapper autoware_component_interface_specs autoware_geography_utils autoware_global_parameter_loader autoware_interpolation autoware_kalman_filter autoware_lanelet2_utils autoware_marker_utils autoware_motion_utils autoware_node autoware_object_recognition_utils autoware_osqp_interface autoware_point_types autoware_qos_utils autoware_qp_interface autoware_signal_processing autoware_trajectory autoware_vehicle_info_utils autoware_core_control autoware_simple_pure_pursuit autoware_awsim_sensor_kit_description autoware_sample_sensor_kit_description autoware_sample_vehicle_description autoware_core_localization autoware_ekf_localizer autoware_gyro_odometer autoware_localization_util autoware_ndt_scan_matcher autoware_pose_initializer autoware_stop_filter autoware_twist2accel autoware_core_map autoware_lanelet2_map_visualizer autoware_map_height_fitter autoware_map_loader autoware_map_projection_loader autoware_core_perception autoware_euclidean_cluster_object_detector autoware_ground_filter autoware_perception_objects_converter autoware_core_planning autoware_mission_planner autoware_objects_of_interest_marker_interface autoware_path_generator autoware_planning_factor_interface autoware_planning_topic_converter autoware_route_handler autoware_velocity_smoother autoware_behavior_velocity_planner autoware_behavior_velocity_planner_common autoware_behavior_velocity_stop_line_module autoware_motion_velocity_obstacle_stop_module autoware_motion_velocity_planner autoware_motion_velocity_planner_common autoware_core_sensing autoware_crop_box_filter autoware_downsample_filters autoware_gnss_poser autoware_vehicle_velocity_converter autoware_planning_test_manager autoware_pyplot autoware_test_node autoware_test_utils autoware_testing autoware_core_vehicle

ROS Distro
humble

Package Summary

Version 1.8.0
License Apache License 2.0
Build type AMENT_CMAKE
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/autowarefoundation/autoware_core.git
VCS Type git
VCS Version main
Last Updated 2026-05-12
Dev Status DEVELOPED
Released RELEASED
Contributing Help Wanted (-)
Good First Issues (-)
Pull Requests to Review (-)

Package Description

Wrapper macros for Agnocast (true zero-copy communication library)

Maintainers

  • Takahiro Ishikawa-Aso
  • Koichi Imai
  • Atsushi Yano

Authors

No additional authors.

autoware_agnocast_wrapper

The purpose of this package is to integrate Agnocast, a zero-copy middleware, into each topic in Autoware with minimal side effects. Agnocast is a library designed to work alongside ROS 2, enabling true zero-copy publish/subscribe communication for all ROS 2 message types, including unsized message types.

This package provides macros that wrap functions for publish/subscribe operations and smart pointer types for handling ROS 2 messages. When Autoware is built using the default build command, Agnocast is not enabled. However, setting the environment variable ENABLE_AGNOCAST=1 enables Agnocast and results in a build that includes its integration. This design ensures backward compatibility for users who are unaware of Agnocast, minimizing disruption.

Two Integration Approaches

This package provides two approaches for integrating Agnocast. Both will coexist for the foreseeable future.

1. Node Wrapper (agnocast_wrapper::Node)

Use this when you want the entire node to transparently switch between rclcpp::Node and agnocast::Node at runtime. The node wrapper automatically selects the correct underlying implementation based on the ENABLE_AGNOCAST environment variable.

Currently supported APIs:

  • Publisher / Subscription / PollingSubscriber
  • Parameters
  • Logger, Clock
  • Callback groups
  • Node interfaces (partial: get_node_base_interface(), get_node_topics_interface(), get_node_parameters_interface())

Note: Timer (create_wall_timer, create_timer) is not yet supported and will be added in a future update.

#include <autoware/agnocast_wrapper/node.hpp>

class MyNode : public autoware::agnocast_wrapper::Node
{
public:
  explicit MyNode(const rclcpp::NodeOptions & options)
  : Node("my_node", options)
  {
    pub_ = create_publisher<std_msgs::msg::String>("output", 10);
    sub_ = create_subscription<std_msgs::msg::String>(
      "input", 10, [this](std::unique_ptr<const std_msgs::msg::String> msg) { /* ... */ });
  }

private:
  autoware::agnocast_wrapper::Publisher<std_msgs::msg::String>::SharedPtr pub_;
  autoware::agnocast_wrapper::Subscription<std_msgs::msg::String>::SharedPtr sub_;
};

To use the Node wrapper in your package, add the following to your CMakeLists.txt:

find_package(autoware_agnocast_wrapper REQUIRED)
ament_target_dependencies(my_node_component autoware_agnocast_wrapper)

Registering a Node with autoware_agnocast_wrapper_register_node

Instead of calling rclcpp_components_register_node directly, use the autoware_agnocast_wrapper_register_node macro to register your component node. This macro:

  1. Registers the component with rclcpp_components (for component container support)
  2. Creates a standalone executable that can switch between rclcpp::Node and agnocast::Node at runtime based on the ENABLE_AGNOCAST environment variable

When ENABLE_AGNOCAST is not set or set to 0, this macro falls back to standard rclcpp_components_register_node behavior.

find_package(autoware_agnocast_wrapper REQUIRED)

ament_auto_add_library(my_node_component SHARED src/my_node.cpp)
ament_target_dependencies(my_node_component autoware_agnocast_wrapper)

autoware_agnocast_wrapper_register_node(my_node_component
  PLUGIN "my_package::MyNode"
  EXECUTABLE my_node
)

Parameters:

Parameter Required Default Description
PLUGIN Yes - Fully qualified class name of the component
EXECUTABLE Yes - Executable name for the node
ROS2_EXECUTOR No SingleThreadedExecutor Executor to use when ENABLE_AGNOCAST=0 at runtime
AGNOCAST_EXECUTOR No SingleThreadedAgnocastExecutor Executor to use when ENABLE_AGNOCAST=1 at runtime

Valid executor values:

  • ROS2_EXECUTOR: SingleThreadedExecutor, MultiThreadedExecutor
  • AGNOCAST_EXECUTOR: SingleThreadedAgnocastExecutor, MultiThreadedAgnocastExecutor, CallbackIsolatedAgnocastExecutor, AgnocastOnlySingleThreadedExecutor, AgnocastOnlyMultiThreadedExecutor, AgnocastOnlyCallbackIsolatedExecutor

Node class requirements:

The required PLUGIN base class depends on the AGNOCAST_EXECUTOR type. The generated template enforces this via if constexpr at compile time:

AGNOCAST_EXECUTOR Required PLUGIN base class
AgnocastOnly* executors autoware::agnocast_wrapper::Node
Other agnocast executors Any rclcpp::Node-compatible class

Non-AgnocastOnly executors use NodeInstanceWrapper::get_node_base_interface() directly, which works with any node type (rclcpp::Node, agnocast_wrapper::Node, etc.) without requiring a cast. AgnocastOnly executors require get_agnocast_node(), which is only available on autoware::agnocast_wrapper::Node.

File truncated at 100 lines see the full file

CHANGELOG

Changelog for package autoware_agnocast_wrapper

1.8.0 (2026-05-01)

  • chore: align package versions to 1.7.0 and reset changelogs

  • Merge remote-tracking branch 'origin/main' into tmp/bot/bump_version_base

  • docs(autoware_agnocast_wrapper): use FindPackageShare and PathJoinSubstitution in Python launch examples (#999)

  • fix(autoware_agnocast_wrapper): support jazzy (rclcpp 28~) (#980) fix(autoware_agnocast_wrapper): fix Jazzy build by using version-conditional callback type alias

  • fix(autoware_agnocast_wrapper): fix false positive LD_PRELOAD warning in agnocast_env.launch.py (#973)

  • refactor(autoware_agnocast_wrapper): remove executor threading model consistency validation (#970)

    • refactor(autoware_agnocast_wrapper): remove executor threading model consistency validation
    • docs(autoware_agnocast_wrapper): clarify behavior reference tables in README

    - Reword introductory sentence to clarify that only ROS2_EXECUTOR matters when ENABLE_AGNOCAST=0

    - Use full CMake option strings (e.g. SingleThreadedExecutor) instead of abbreviations in both behavior reference tables

    • style(pre-commit): autofix

    * fix(autoware_agnocast_wrapper): fix forbidden word ROS2 to ROS 2 in README ---------Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>

  • feat(autoware_agnocast_wrapper): support message filter in agnocast wrapper (#951)

    * feat(autoware_agnocast_wrapper): add register_node macro for runtime rclcpp/agnocast switching Add [autoware_agnocast_wrapper_register_node]{.title-ref} CMake macro as a drop-in replacement for [rclcpp_components_register_node]{.title-ref}. When ENABLE_AGNOCAST=1, it generates a standalone executable that can switch between rclcpp::Node and agnocast::Node at runtime based on the ENABLE_AGNOCAST environment variable. When ENABLE_AGNOCAST is not set, it falls back to standard rclcpp_components_register_node behavior with zero overhead. Key features:

    • Configurable ROS2 and Agnocast executor types
    • Two-pass template generation (configure_file + file(GENERATE))
    • Support for both rclcpp::Node and agnocast_wrapper::Node plugins
    • Target existence validation at configure time
    • ABI consistency enforcement via autoware_agnocast_wrapper_setup()
    • Change agnocastlib from build_depend to depend
    • fix(autoware_agnocast_wrapper): add static_assert to enforce PLUGIN base class at compile time

    * fix(autoware_agnocast_wrapper): add runtime ROS2 fallback for AgnocastOnly executors When agnocast_only=true but ENABLE_AGNOCAST=0 at runtime, the node now falls back to the ROS2 executor instead of unconditionally using the AgnocastOnly executor.

    * fix(autoware_agnocast_wrapper): warn on mismatched executor threading models Emit a CMake WARNING when ROS2_EXECUTOR and AGNOCAST_EXECUTOR have different threading models (e.g., SingleThreadedExecutor with MultiThreadedAgnocastExecutor), as this silently changes behavior depending on the runtime ENABLE_AGNOCAST value.

    • docs(autoware_agnocast_wrapper): add executor behavior reference table to README
    • style(pre-commit): autofix
    • fix(autoware_agnocast_wrapper): replace forbidden word ROS2 with ROS 2
    • style(pre-commit): autofix

    * fix(autoware_agnocast_wrapper): remove static_assert that fails in non-template main() The static_assert inside if constexpr (agnocast_only) is always evaluated because main() is not a template function. Additionally, the component type header is not included in the generated source (loaded via class_loader at runtime), so the type cannot be resolved at compile time.

    • delete deprecated mark from publish(const MessageT&) API
    • support message_filter in agnocast_wrapper
    • style(pre-commit): autofix
    • fix cpplint
    • fix cpplint
    • add comments

File truncated at 100 lines see the full file

Launch files

Messages

No message files found.

Services

No service files found

Plugins

No plugins found.

Recent questions tagged autoware_agnocast_wrapper at Robotics Stack Exchange

No version for distro hydro showing humble. Known supported distros are highlighted in the buttons above.
Package symbol

autoware_agnocast_wrapper package from autoware_core repo

autoware_adapi_adaptors autoware_adapi_specs autoware_core_api autoware_default_adapi autoware_core autoware_agnocast_wrapper autoware_component_interface_specs autoware_geography_utils autoware_global_parameter_loader autoware_interpolation autoware_kalman_filter autoware_lanelet2_utils autoware_marker_utils autoware_motion_utils autoware_node autoware_object_recognition_utils autoware_osqp_interface autoware_point_types autoware_qos_utils autoware_qp_interface autoware_signal_processing autoware_trajectory autoware_vehicle_info_utils autoware_core_control autoware_simple_pure_pursuit autoware_awsim_sensor_kit_description autoware_sample_sensor_kit_description autoware_sample_vehicle_description autoware_core_localization autoware_ekf_localizer autoware_gyro_odometer autoware_localization_util autoware_ndt_scan_matcher autoware_pose_initializer autoware_stop_filter autoware_twist2accel autoware_core_map autoware_lanelet2_map_visualizer autoware_map_height_fitter autoware_map_loader autoware_map_projection_loader autoware_core_perception autoware_euclidean_cluster_object_detector autoware_ground_filter autoware_perception_objects_converter autoware_core_planning autoware_mission_planner autoware_objects_of_interest_marker_interface autoware_path_generator autoware_planning_factor_interface autoware_planning_topic_converter autoware_route_handler autoware_velocity_smoother autoware_behavior_velocity_planner autoware_behavior_velocity_planner_common autoware_behavior_velocity_stop_line_module autoware_motion_velocity_obstacle_stop_module autoware_motion_velocity_planner autoware_motion_velocity_planner_common autoware_core_sensing autoware_crop_box_filter autoware_downsample_filters autoware_gnss_poser autoware_vehicle_velocity_converter autoware_planning_test_manager autoware_pyplot autoware_test_node autoware_test_utils autoware_testing autoware_core_vehicle

ROS Distro
humble

Package Summary

Version 1.8.0
License Apache License 2.0
Build type AMENT_CMAKE
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/autowarefoundation/autoware_core.git
VCS Type git
VCS Version main
Last Updated 2026-05-12
Dev Status DEVELOPED
Released RELEASED
Contributing Help Wanted (-)
Good First Issues (-)
Pull Requests to Review (-)

Package Description

Wrapper macros for Agnocast (true zero-copy communication library)

Maintainers

  • Takahiro Ishikawa-Aso
  • Koichi Imai
  • Atsushi Yano

Authors

No additional authors.

autoware_agnocast_wrapper

The purpose of this package is to integrate Agnocast, a zero-copy middleware, into each topic in Autoware with minimal side effects. Agnocast is a library designed to work alongside ROS 2, enabling true zero-copy publish/subscribe communication for all ROS 2 message types, including unsized message types.

This package provides macros that wrap functions for publish/subscribe operations and smart pointer types for handling ROS 2 messages. When Autoware is built using the default build command, Agnocast is not enabled. However, setting the environment variable ENABLE_AGNOCAST=1 enables Agnocast and results in a build that includes its integration. This design ensures backward compatibility for users who are unaware of Agnocast, minimizing disruption.

Two Integration Approaches

This package provides two approaches for integrating Agnocast. Both will coexist for the foreseeable future.

1. Node Wrapper (agnocast_wrapper::Node)

Use this when you want the entire node to transparently switch between rclcpp::Node and agnocast::Node at runtime. The node wrapper automatically selects the correct underlying implementation based on the ENABLE_AGNOCAST environment variable.

Currently supported APIs:

  • Publisher / Subscription / PollingSubscriber
  • Parameters
  • Logger, Clock
  • Callback groups
  • Node interfaces (partial: get_node_base_interface(), get_node_topics_interface(), get_node_parameters_interface())

Note: Timer (create_wall_timer, create_timer) is not yet supported and will be added in a future update.

#include <autoware/agnocast_wrapper/node.hpp>

class MyNode : public autoware::agnocast_wrapper::Node
{
public:
  explicit MyNode(const rclcpp::NodeOptions & options)
  : Node("my_node", options)
  {
    pub_ = create_publisher<std_msgs::msg::String>("output", 10);
    sub_ = create_subscription<std_msgs::msg::String>(
      "input", 10, [this](std::unique_ptr<const std_msgs::msg::String> msg) { /* ... */ });
  }

private:
  autoware::agnocast_wrapper::Publisher<std_msgs::msg::String>::SharedPtr pub_;
  autoware::agnocast_wrapper::Subscription<std_msgs::msg::String>::SharedPtr sub_;
};

To use the Node wrapper in your package, add the following to your CMakeLists.txt:

find_package(autoware_agnocast_wrapper REQUIRED)
ament_target_dependencies(my_node_component autoware_agnocast_wrapper)

Registering a Node with autoware_agnocast_wrapper_register_node

Instead of calling rclcpp_components_register_node directly, use the autoware_agnocast_wrapper_register_node macro to register your component node. This macro:

  1. Registers the component with rclcpp_components (for component container support)
  2. Creates a standalone executable that can switch between rclcpp::Node and agnocast::Node at runtime based on the ENABLE_AGNOCAST environment variable

When ENABLE_AGNOCAST is not set or set to 0, this macro falls back to standard rclcpp_components_register_node behavior.

find_package(autoware_agnocast_wrapper REQUIRED)

ament_auto_add_library(my_node_component SHARED src/my_node.cpp)
ament_target_dependencies(my_node_component autoware_agnocast_wrapper)

autoware_agnocast_wrapper_register_node(my_node_component
  PLUGIN "my_package::MyNode"
  EXECUTABLE my_node
)

Parameters:

Parameter Required Default Description
PLUGIN Yes - Fully qualified class name of the component
EXECUTABLE Yes - Executable name for the node
ROS2_EXECUTOR No SingleThreadedExecutor Executor to use when ENABLE_AGNOCAST=0 at runtime
AGNOCAST_EXECUTOR No SingleThreadedAgnocastExecutor Executor to use when ENABLE_AGNOCAST=1 at runtime

Valid executor values:

  • ROS2_EXECUTOR: SingleThreadedExecutor, MultiThreadedExecutor
  • AGNOCAST_EXECUTOR: SingleThreadedAgnocastExecutor, MultiThreadedAgnocastExecutor, CallbackIsolatedAgnocastExecutor, AgnocastOnlySingleThreadedExecutor, AgnocastOnlyMultiThreadedExecutor, AgnocastOnlyCallbackIsolatedExecutor

Node class requirements:

The required PLUGIN base class depends on the AGNOCAST_EXECUTOR type. The generated template enforces this via if constexpr at compile time:

AGNOCAST_EXECUTOR Required PLUGIN base class
AgnocastOnly* executors autoware::agnocast_wrapper::Node
Other agnocast executors Any rclcpp::Node-compatible class

Non-AgnocastOnly executors use NodeInstanceWrapper::get_node_base_interface() directly, which works with any node type (rclcpp::Node, agnocast_wrapper::Node, etc.) without requiring a cast. AgnocastOnly executors require get_agnocast_node(), which is only available on autoware::agnocast_wrapper::Node.

File truncated at 100 lines see the full file

CHANGELOG

Changelog for package autoware_agnocast_wrapper

1.8.0 (2026-05-01)

  • chore: align package versions to 1.7.0 and reset changelogs

  • Merge remote-tracking branch 'origin/main' into tmp/bot/bump_version_base

  • docs(autoware_agnocast_wrapper): use FindPackageShare and PathJoinSubstitution in Python launch examples (#999)

  • fix(autoware_agnocast_wrapper): support jazzy (rclcpp 28~) (#980) fix(autoware_agnocast_wrapper): fix Jazzy build by using version-conditional callback type alias

  • fix(autoware_agnocast_wrapper): fix false positive LD_PRELOAD warning in agnocast_env.launch.py (#973)

  • refactor(autoware_agnocast_wrapper): remove executor threading model consistency validation (#970)

    • refactor(autoware_agnocast_wrapper): remove executor threading model consistency validation
    • docs(autoware_agnocast_wrapper): clarify behavior reference tables in README

    - Reword introductory sentence to clarify that only ROS2_EXECUTOR matters when ENABLE_AGNOCAST=0

    - Use full CMake option strings (e.g. SingleThreadedExecutor) instead of abbreviations in both behavior reference tables

    • style(pre-commit): autofix

    * fix(autoware_agnocast_wrapper): fix forbidden word ROS2 to ROS 2 in README ---------Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>

  • feat(autoware_agnocast_wrapper): support message filter in agnocast wrapper (#951)

    * feat(autoware_agnocast_wrapper): add register_node macro for runtime rclcpp/agnocast switching Add [autoware_agnocast_wrapper_register_node]{.title-ref} CMake macro as a drop-in replacement for [rclcpp_components_register_node]{.title-ref}. When ENABLE_AGNOCAST=1, it generates a standalone executable that can switch between rclcpp::Node and agnocast::Node at runtime based on the ENABLE_AGNOCAST environment variable. When ENABLE_AGNOCAST is not set, it falls back to standard rclcpp_components_register_node behavior with zero overhead. Key features:

    • Configurable ROS2 and Agnocast executor types
    • Two-pass template generation (configure_file + file(GENERATE))
    • Support for both rclcpp::Node and agnocast_wrapper::Node plugins
    • Target existence validation at configure time
    • ABI consistency enforcement via autoware_agnocast_wrapper_setup()
    • Change agnocastlib from build_depend to depend
    • fix(autoware_agnocast_wrapper): add static_assert to enforce PLUGIN base class at compile time

    * fix(autoware_agnocast_wrapper): add runtime ROS2 fallback for AgnocastOnly executors When agnocast_only=true but ENABLE_AGNOCAST=0 at runtime, the node now falls back to the ROS2 executor instead of unconditionally using the AgnocastOnly executor.

    * fix(autoware_agnocast_wrapper): warn on mismatched executor threading models Emit a CMake WARNING when ROS2_EXECUTOR and AGNOCAST_EXECUTOR have different threading models (e.g., SingleThreadedExecutor with MultiThreadedAgnocastExecutor), as this silently changes behavior depending on the runtime ENABLE_AGNOCAST value.

    • docs(autoware_agnocast_wrapper): add executor behavior reference table to README
    • style(pre-commit): autofix
    • fix(autoware_agnocast_wrapper): replace forbidden word ROS2 with ROS 2
    • style(pre-commit): autofix

    * fix(autoware_agnocast_wrapper): remove static_assert that fails in non-template main() The static_assert inside if constexpr (agnocast_only) is always evaluated because main() is not a template function. Additionally, the component type header is not included in the generated source (loaded via class_loader at runtime), so the type cannot be resolved at compile time.

    • delete deprecated mark from publish(const MessageT&) API
    • support message_filter in agnocast_wrapper
    • style(pre-commit): autofix
    • fix cpplint
    • fix cpplint
    • add comments

File truncated at 100 lines see the full file

Launch files

Messages

No message files found.

Services

No service files found

Plugins

No plugins found.

Recent questions tagged autoware_agnocast_wrapper at Robotics Stack Exchange

No version for distro kinetic showing humble. Known supported distros are highlighted in the buttons above.
Package symbol

autoware_agnocast_wrapper package from autoware_core repo

autoware_adapi_adaptors autoware_adapi_specs autoware_core_api autoware_default_adapi autoware_core autoware_agnocast_wrapper autoware_component_interface_specs autoware_geography_utils autoware_global_parameter_loader autoware_interpolation autoware_kalman_filter autoware_lanelet2_utils autoware_marker_utils autoware_motion_utils autoware_node autoware_object_recognition_utils autoware_osqp_interface autoware_point_types autoware_qos_utils autoware_qp_interface autoware_signal_processing autoware_trajectory autoware_vehicle_info_utils autoware_core_control autoware_simple_pure_pursuit autoware_awsim_sensor_kit_description autoware_sample_sensor_kit_description autoware_sample_vehicle_description autoware_core_localization autoware_ekf_localizer autoware_gyro_odometer autoware_localization_util autoware_ndt_scan_matcher autoware_pose_initializer autoware_stop_filter autoware_twist2accel autoware_core_map autoware_lanelet2_map_visualizer autoware_map_height_fitter autoware_map_loader autoware_map_projection_loader autoware_core_perception autoware_euclidean_cluster_object_detector autoware_ground_filter autoware_perception_objects_converter autoware_core_planning autoware_mission_planner autoware_objects_of_interest_marker_interface autoware_path_generator autoware_planning_factor_interface autoware_planning_topic_converter autoware_route_handler autoware_velocity_smoother autoware_behavior_velocity_planner autoware_behavior_velocity_planner_common autoware_behavior_velocity_stop_line_module autoware_motion_velocity_obstacle_stop_module autoware_motion_velocity_planner autoware_motion_velocity_planner_common autoware_core_sensing autoware_crop_box_filter autoware_downsample_filters autoware_gnss_poser autoware_vehicle_velocity_converter autoware_planning_test_manager autoware_pyplot autoware_test_node autoware_test_utils autoware_testing autoware_core_vehicle

ROS Distro
humble

Package Summary

Version 1.8.0
License Apache License 2.0
Build type AMENT_CMAKE
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/autowarefoundation/autoware_core.git
VCS Type git
VCS Version main
Last Updated 2026-05-12
Dev Status DEVELOPED
Released RELEASED
Contributing Help Wanted (-)
Good First Issues (-)
Pull Requests to Review (-)

Package Description

Wrapper macros for Agnocast (true zero-copy communication library)

Maintainers

  • Takahiro Ishikawa-Aso
  • Koichi Imai
  • Atsushi Yano

Authors

No additional authors.

autoware_agnocast_wrapper

The purpose of this package is to integrate Agnocast, a zero-copy middleware, into each topic in Autoware with minimal side effects. Agnocast is a library designed to work alongside ROS 2, enabling true zero-copy publish/subscribe communication for all ROS 2 message types, including unsized message types.

This package provides macros that wrap functions for publish/subscribe operations and smart pointer types for handling ROS 2 messages. When Autoware is built using the default build command, Agnocast is not enabled. However, setting the environment variable ENABLE_AGNOCAST=1 enables Agnocast and results in a build that includes its integration. This design ensures backward compatibility for users who are unaware of Agnocast, minimizing disruption.

Two Integration Approaches

This package provides two approaches for integrating Agnocast. Both will coexist for the foreseeable future.

1. Node Wrapper (agnocast_wrapper::Node)

Use this when you want the entire node to transparently switch between rclcpp::Node and agnocast::Node at runtime. The node wrapper automatically selects the correct underlying implementation based on the ENABLE_AGNOCAST environment variable.

Currently supported APIs:

  • Publisher / Subscription / PollingSubscriber
  • Parameters
  • Logger, Clock
  • Callback groups
  • Node interfaces (partial: get_node_base_interface(), get_node_topics_interface(), get_node_parameters_interface())

Note: Timer (create_wall_timer, create_timer) is not yet supported and will be added in a future update.

#include <autoware/agnocast_wrapper/node.hpp>

class MyNode : public autoware::agnocast_wrapper::Node
{
public:
  explicit MyNode(const rclcpp::NodeOptions & options)
  : Node("my_node", options)
  {
    pub_ = create_publisher<std_msgs::msg::String>("output", 10);
    sub_ = create_subscription<std_msgs::msg::String>(
      "input", 10, [this](std::unique_ptr<const std_msgs::msg::String> msg) { /* ... */ });
  }

private:
  autoware::agnocast_wrapper::Publisher<std_msgs::msg::String>::SharedPtr pub_;
  autoware::agnocast_wrapper::Subscription<std_msgs::msg::String>::SharedPtr sub_;
};

To use the Node wrapper in your package, add the following to your CMakeLists.txt:

find_package(autoware_agnocast_wrapper REQUIRED)
ament_target_dependencies(my_node_component autoware_agnocast_wrapper)

Registering a Node with autoware_agnocast_wrapper_register_node

Instead of calling rclcpp_components_register_node directly, use the autoware_agnocast_wrapper_register_node macro to register your component node. This macro:

  1. Registers the component with rclcpp_components (for component container support)
  2. Creates a standalone executable that can switch between rclcpp::Node and agnocast::Node at runtime based on the ENABLE_AGNOCAST environment variable

When ENABLE_AGNOCAST is not set or set to 0, this macro falls back to standard rclcpp_components_register_node behavior.

find_package(autoware_agnocast_wrapper REQUIRED)

ament_auto_add_library(my_node_component SHARED src/my_node.cpp)
ament_target_dependencies(my_node_component autoware_agnocast_wrapper)

autoware_agnocast_wrapper_register_node(my_node_component
  PLUGIN "my_package::MyNode"
  EXECUTABLE my_node
)

Parameters:

Parameter Required Default Description
PLUGIN Yes - Fully qualified class name of the component
EXECUTABLE Yes - Executable name for the node
ROS2_EXECUTOR No SingleThreadedExecutor Executor to use when ENABLE_AGNOCAST=0 at runtime
AGNOCAST_EXECUTOR No SingleThreadedAgnocastExecutor Executor to use when ENABLE_AGNOCAST=1 at runtime

Valid executor values:

  • ROS2_EXECUTOR: SingleThreadedExecutor, MultiThreadedExecutor
  • AGNOCAST_EXECUTOR: SingleThreadedAgnocastExecutor, MultiThreadedAgnocastExecutor, CallbackIsolatedAgnocastExecutor, AgnocastOnlySingleThreadedExecutor, AgnocastOnlyMultiThreadedExecutor, AgnocastOnlyCallbackIsolatedExecutor

Node class requirements:

The required PLUGIN base class depends on the AGNOCAST_EXECUTOR type. The generated template enforces this via if constexpr at compile time:

AGNOCAST_EXECUTOR Required PLUGIN base class
AgnocastOnly* executors autoware::agnocast_wrapper::Node
Other agnocast executors Any rclcpp::Node-compatible class

Non-AgnocastOnly executors use NodeInstanceWrapper::get_node_base_interface() directly, which works with any node type (rclcpp::Node, agnocast_wrapper::Node, etc.) without requiring a cast. AgnocastOnly executors require get_agnocast_node(), which is only available on autoware::agnocast_wrapper::Node.

File truncated at 100 lines see the full file

CHANGELOG

Changelog for package autoware_agnocast_wrapper

1.8.0 (2026-05-01)

  • chore: align package versions to 1.7.0 and reset changelogs

  • Merge remote-tracking branch 'origin/main' into tmp/bot/bump_version_base

  • docs(autoware_agnocast_wrapper): use FindPackageShare and PathJoinSubstitution in Python launch examples (#999)

  • fix(autoware_agnocast_wrapper): support jazzy (rclcpp 28~) (#980) fix(autoware_agnocast_wrapper): fix Jazzy build by using version-conditional callback type alias

  • fix(autoware_agnocast_wrapper): fix false positive LD_PRELOAD warning in agnocast_env.launch.py (#973)

  • refactor(autoware_agnocast_wrapper): remove executor threading model consistency validation (#970)

    • refactor(autoware_agnocast_wrapper): remove executor threading model consistency validation
    • docs(autoware_agnocast_wrapper): clarify behavior reference tables in README

    - Reword introductory sentence to clarify that only ROS2_EXECUTOR matters when ENABLE_AGNOCAST=0

    - Use full CMake option strings (e.g. SingleThreadedExecutor) instead of abbreviations in both behavior reference tables

    • style(pre-commit): autofix

    * fix(autoware_agnocast_wrapper): fix forbidden word ROS2 to ROS 2 in README ---------Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>

  • feat(autoware_agnocast_wrapper): support message filter in agnocast wrapper (#951)

    * feat(autoware_agnocast_wrapper): add register_node macro for runtime rclcpp/agnocast switching Add [autoware_agnocast_wrapper_register_node]{.title-ref} CMake macro as a drop-in replacement for [rclcpp_components_register_node]{.title-ref}. When ENABLE_AGNOCAST=1, it generates a standalone executable that can switch between rclcpp::Node and agnocast::Node at runtime based on the ENABLE_AGNOCAST environment variable. When ENABLE_AGNOCAST is not set, it falls back to standard rclcpp_components_register_node behavior with zero overhead. Key features:

    • Configurable ROS2 and Agnocast executor types
    • Two-pass template generation (configure_file + file(GENERATE))
    • Support for both rclcpp::Node and agnocast_wrapper::Node plugins
    • Target existence validation at configure time
    • ABI consistency enforcement via autoware_agnocast_wrapper_setup()
    • Change agnocastlib from build_depend to depend
    • fix(autoware_agnocast_wrapper): add static_assert to enforce PLUGIN base class at compile time

    * fix(autoware_agnocast_wrapper): add runtime ROS2 fallback for AgnocastOnly executors When agnocast_only=true but ENABLE_AGNOCAST=0 at runtime, the node now falls back to the ROS2 executor instead of unconditionally using the AgnocastOnly executor.

    * fix(autoware_agnocast_wrapper): warn on mismatched executor threading models Emit a CMake WARNING when ROS2_EXECUTOR and AGNOCAST_EXECUTOR have different threading models (e.g., SingleThreadedExecutor with MultiThreadedAgnocastExecutor), as this silently changes behavior depending on the runtime ENABLE_AGNOCAST value.

    • docs(autoware_agnocast_wrapper): add executor behavior reference table to README
    • style(pre-commit): autofix
    • fix(autoware_agnocast_wrapper): replace forbidden word ROS2 with ROS 2
    • style(pre-commit): autofix

    * fix(autoware_agnocast_wrapper): remove static_assert that fails in non-template main() The static_assert inside if constexpr (agnocast_only) is always evaluated because main() is not a template function. Additionally, the component type header is not included in the generated source (loaded via class_loader at runtime), so the type cannot be resolved at compile time.

    • delete deprecated mark from publish(const MessageT&) API
    • support message_filter in agnocast_wrapper
    • style(pre-commit): autofix
    • fix cpplint
    • fix cpplint
    • add comments

File truncated at 100 lines see the full file

Launch files

Messages

No message files found.

Services

No service files found

Plugins

No plugins found.

Recent questions tagged autoware_agnocast_wrapper at Robotics Stack Exchange

No version for distro melodic showing humble. Known supported distros are highlighted in the buttons above.
Package symbol

autoware_agnocast_wrapper package from autoware_core repo

autoware_adapi_adaptors autoware_adapi_specs autoware_core_api autoware_default_adapi autoware_core autoware_agnocast_wrapper autoware_component_interface_specs autoware_geography_utils autoware_global_parameter_loader autoware_interpolation autoware_kalman_filter autoware_lanelet2_utils autoware_marker_utils autoware_motion_utils autoware_node autoware_object_recognition_utils autoware_osqp_interface autoware_point_types autoware_qos_utils autoware_qp_interface autoware_signal_processing autoware_trajectory autoware_vehicle_info_utils autoware_core_control autoware_simple_pure_pursuit autoware_awsim_sensor_kit_description autoware_sample_sensor_kit_description autoware_sample_vehicle_description autoware_core_localization autoware_ekf_localizer autoware_gyro_odometer autoware_localization_util autoware_ndt_scan_matcher autoware_pose_initializer autoware_stop_filter autoware_twist2accel autoware_core_map autoware_lanelet2_map_visualizer autoware_map_height_fitter autoware_map_loader autoware_map_projection_loader autoware_core_perception autoware_euclidean_cluster_object_detector autoware_ground_filter autoware_perception_objects_converter autoware_core_planning autoware_mission_planner autoware_objects_of_interest_marker_interface autoware_path_generator autoware_planning_factor_interface autoware_planning_topic_converter autoware_route_handler autoware_velocity_smoother autoware_behavior_velocity_planner autoware_behavior_velocity_planner_common autoware_behavior_velocity_stop_line_module autoware_motion_velocity_obstacle_stop_module autoware_motion_velocity_planner autoware_motion_velocity_planner_common autoware_core_sensing autoware_crop_box_filter autoware_downsample_filters autoware_gnss_poser autoware_vehicle_velocity_converter autoware_planning_test_manager autoware_pyplot autoware_test_node autoware_test_utils autoware_testing autoware_core_vehicle

ROS Distro
humble

Package Summary

Version 1.8.0
License Apache License 2.0
Build type AMENT_CMAKE
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/autowarefoundation/autoware_core.git
VCS Type git
VCS Version main
Last Updated 2026-05-12
Dev Status DEVELOPED
Released RELEASED
Contributing Help Wanted (-)
Good First Issues (-)
Pull Requests to Review (-)

Package Description

Wrapper macros for Agnocast (true zero-copy communication library)

Maintainers

  • Takahiro Ishikawa-Aso
  • Koichi Imai
  • Atsushi Yano

Authors

No additional authors.

autoware_agnocast_wrapper

The purpose of this package is to integrate Agnocast, a zero-copy middleware, into each topic in Autoware with minimal side effects. Agnocast is a library designed to work alongside ROS 2, enabling true zero-copy publish/subscribe communication for all ROS 2 message types, including unsized message types.

This package provides macros that wrap functions for publish/subscribe operations and smart pointer types for handling ROS 2 messages. When Autoware is built using the default build command, Agnocast is not enabled. However, setting the environment variable ENABLE_AGNOCAST=1 enables Agnocast and results in a build that includes its integration. This design ensures backward compatibility for users who are unaware of Agnocast, minimizing disruption.

Two Integration Approaches

This package provides two approaches for integrating Agnocast. Both will coexist for the foreseeable future.

1. Node Wrapper (agnocast_wrapper::Node)

Use this when you want the entire node to transparently switch between rclcpp::Node and agnocast::Node at runtime. The node wrapper automatically selects the correct underlying implementation based on the ENABLE_AGNOCAST environment variable.

Currently supported APIs:

  • Publisher / Subscription / PollingSubscriber
  • Parameters
  • Logger, Clock
  • Callback groups
  • Node interfaces (partial: get_node_base_interface(), get_node_topics_interface(), get_node_parameters_interface())

Note: Timer (create_wall_timer, create_timer) is not yet supported and will be added in a future update.

#include <autoware/agnocast_wrapper/node.hpp>

class MyNode : public autoware::agnocast_wrapper::Node
{
public:
  explicit MyNode(const rclcpp::NodeOptions & options)
  : Node("my_node", options)
  {
    pub_ = create_publisher<std_msgs::msg::String>("output", 10);
    sub_ = create_subscription<std_msgs::msg::String>(
      "input", 10, [this](std::unique_ptr<const std_msgs::msg::String> msg) { /* ... */ });
  }

private:
  autoware::agnocast_wrapper::Publisher<std_msgs::msg::String>::SharedPtr pub_;
  autoware::agnocast_wrapper::Subscription<std_msgs::msg::String>::SharedPtr sub_;
};

To use the Node wrapper in your package, add the following to your CMakeLists.txt:

find_package(autoware_agnocast_wrapper REQUIRED)
ament_target_dependencies(my_node_component autoware_agnocast_wrapper)

Registering a Node with autoware_agnocast_wrapper_register_node

Instead of calling rclcpp_components_register_node directly, use the autoware_agnocast_wrapper_register_node macro to register your component node. This macro:

  1. Registers the component with rclcpp_components (for component container support)
  2. Creates a standalone executable that can switch between rclcpp::Node and agnocast::Node at runtime based on the ENABLE_AGNOCAST environment variable

When ENABLE_AGNOCAST is not set or set to 0, this macro falls back to standard rclcpp_components_register_node behavior.

find_package(autoware_agnocast_wrapper REQUIRED)

ament_auto_add_library(my_node_component SHARED src/my_node.cpp)
ament_target_dependencies(my_node_component autoware_agnocast_wrapper)

autoware_agnocast_wrapper_register_node(my_node_component
  PLUGIN "my_package::MyNode"
  EXECUTABLE my_node
)

Parameters:

Parameter Required Default Description
PLUGIN Yes - Fully qualified class name of the component
EXECUTABLE Yes - Executable name for the node
ROS2_EXECUTOR No SingleThreadedExecutor Executor to use when ENABLE_AGNOCAST=0 at runtime
AGNOCAST_EXECUTOR No SingleThreadedAgnocastExecutor Executor to use when ENABLE_AGNOCAST=1 at runtime

Valid executor values:

  • ROS2_EXECUTOR: SingleThreadedExecutor, MultiThreadedExecutor
  • AGNOCAST_EXECUTOR: SingleThreadedAgnocastExecutor, MultiThreadedAgnocastExecutor, CallbackIsolatedAgnocastExecutor, AgnocastOnlySingleThreadedExecutor, AgnocastOnlyMultiThreadedExecutor, AgnocastOnlyCallbackIsolatedExecutor

Node class requirements:

The required PLUGIN base class depends on the AGNOCAST_EXECUTOR type. The generated template enforces this via if constexpr at compile time:

AGNOCAST_EXECUTOR Required PLUGIN base class
AgnocastOnly* executors autoware::agnocast_wrapper::Node
Other agnocast executors Any rclcpp::Node-compatible class

Non-AgnocastOnly executors use NodeInstanceWrapper::get_node_base_interface() directly, which works with any node type (rclcpp::Node, agnocast_wrapper::Node, etc.) without requiring a cast. AgnocastOnly executors require get_agnocast_node(), which is only available on autoware::agnocast_wrapper::Node.

File truncated at 100 lines see the full file

CHANGELOG

Changelog for package autoware_agnocast_wrapper

1.8.0 (2026-05-01)

  • chore: align package versions to 1.7.0 and reset changelogs

  • Merge remote-tracking branch 'origin/main' into tmp/bot/bump_version_base

  • docs(autoware_agnocast_wrapper): use FindPackageShare and PathJoinSubstitution in Python launch examples (#999)

  • fix(autoware_agnocast_wrapper): support jazzy (rclcpp 28~) (#980) fix(autoware_agnocast_wrapper): fix Jazzy build by using version-conditional callback type alias

  • fix(autoware_agnocast_wrapper): fix false positive LD_PRELOAD warning in agnocast_env.launch.py (#973)

  • refactor(autoware_agnocast_wrapper): remove executor threading model consistency validation (#970)

    • refactor(autoware_agnocast_wrapper): remove executor threading model consistency validation
    • docs(autoware_agnocast_wrapper): clarify behavior reference tables in README

    - Reword introductory sentence to clarify that only ROS2_EXECUTOR matters when ENABLE_AGNOCAST=0

    - Use full CMake option strings (e.g. SingleThreadedExecutor) instead of abbreviations in both behavior reference tables

    • style(pre-commit): autofix

    * fix(autoware_agnocast_wrapper): fix forbidden word ROS2 to ROS 2 in README ---------Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>

  • feat(autoware_agnocast_wrapper): support message filter in agnocast wrapper (#951)

    * feat(autoware_agnocast_wrapper): add register_node macro for runtime rclcpp/agnocast switching Add [autoware_agnocast_wrapper_register_node]{.title-ref} CMake macro as a drop-in replacement for [rclcpp_components_register_node]{.title-ref}. When ENABLE_AGNOCAST=1, it generates a standalone executable that can switch between rclcpp::Node and agnocast::Node at runtime based on the ENABLE_AGNOCAST environment variable. When ENABLE_AGNOCAST is not set, it falls back to standard rclcpp_components_register_node behavior with zero overhead. Key features:

    • Configurable ROS2 and Agnocast executor types
    • Two-pass template generation (configure_file + file(GENERATE))
    • Support for both rclcpp::Node and agnocast_wrapper::Node plugins
    • Target existence validation at configure time
    • ABI consistency enforcement via autoware_agnocast_wrapper_setup()
    • Change agnocastlib from build_depend to depend
    • fix(autoware_agnocast_wrapper): add static_assert to enforce PLUGIN base class at compile time

    * fix(autoware_agnocast_wrapper): add runtime ROS2 fallback for AgnocastOnly executors When agnocast_only=true but ENABLE_AGNOCAST=0 at runtime, the node now falls back to the ROS2 executor instead of unconditionally using the AgnocastOnly executor.

    * fix(autoware_agnocast_wrapper): warn on mismatched executor threading models Emit a CMake WARNING when ROS2_EXECUTOR and AGNOCAST_EXECUTOR have different threading models (e.g., SingleThreadedExecutor with MultiThreadedAgnocastExecutor), as this silently changes behavior depending on the runtime ENABLE_AGNOCAST value.

    • docs(autoware_agnocast_wrapper): add executor behavior reference table to README
    • style(pre-commit): autofix
    • fix(autoware_agnocast_wrapper): replace forbidden word ROS2 with ROS 2
    • style(pre-commit): autofix

    * fix(autoware_agnocast_wrapper): remove static_assert that fails in non-template main() The static_assert inside if constexpr (agnocast_only) is always evaluated because main() is not a template function. Additionally, the component type header is not included in the generated source (loaded via class_loader at runtime), so the type cannot be resolved at compile time.

    • delete deprecated mark from publish(const MessageT&) API
    • support message_filter in agnocast_wrapper
    • style(pre-commit): autofix
    • fix cpplint
    • fix cpplint
    • add comments

File truncated at 100 lines see the full file

Launch files

Messages

No message files found.

Services

No service files found

Plugins

No plugins found.

Recent questions tagged autoware_agnocast_wrapper at Robotics Stack Exchange

No version for distro noetic showing humble. Known supported distros are highlighted in the buttons above.
Package symbol

autoware_agnocast_wrapper package from autoware_core repo

autoware_adapi_adaptors autoware_adapi_specs autoware_core_api autoware_default_adapi autoware_core autoware_agnocast_wrapper autoware_component_interface_specs autoware_geography_utils autoware_global_parameter_loader autoware_interpolation autoware_kalman_filter autoware_lanelet2_utils autoware_marker_utils autoware_motion_utils autoware_node autoware_object_recognition_utils autoware_osqp_interface autoware_point_types autoware_qos_utils autoware_qp_interface autoware_signal_processing autoware_trajectory autoware_vehicle_info_utils autoware_core_control autoware_simple_pure_pursuit autoware_awsim_sensor_kit_description autoware_sample_sensor_kit_description autoware_sample_vehicle_description autoware_core_localization autoware_ekf_localizer autoware_gyro_odometer autoware_localization_util autoware_ndt_scan_matcher autoware_pose_initializer autoware_stop_filter autoware_twist2accel autoware_core_map autoware_lanelet2_map_visualizer autoware_map_height_fitter autoware_map_loader autoware_map_projection_loader autoware_core_perception autoware_euclidean_cluster_object_detector autoware_ground_filter autoware_perception_objects_converter autoware_core_planning autoware_mission_planner autoware_objects_of_interest_marker_interface autoware_path_generator autoware_planning_factor_interface autoware_planning_topic_converter autoware_route_handler autoware_velocity_smoother autoware_behavior_velocity_planner autoware_behavior_velocity_planner_common autoware_behavior_velocity_stop_line_module autoware_motion_velocity_obstacle_stop_module autoware_motion_velocity_planner autoware_motion_velocity_planner_common autoware_core_sensing autoware_crop_box_filter autoware_downsample_filters autoware_gnss_poser autoware_vehicle_velocity_converter autoware_planning_test_manager autoware_pyplot autoware_test_node autoware_test_utils autoware_testing autoware_core_vehicle

ROS Distro
humble

Package Summary

Version 1.8.0
License Apache License 2.0
Build type AMENT_CMAKE
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/autowarefoundation/autoware_core.git
VCS Type git
VCS Version main
Last Updated 2026-05-12
Dev Status DEVELOPED
Released RELEASED
Contributing Help Wanted (-)
Good First Issues (-)
Pull Requests to Review (-)

Package Description

Wrapper macros for Agnocast (true zero-copy communication library)

Maintainers

  • Takahiro Ishikawa-Aso
  • Koichi Imai
  • Atsushi Yano

Authors

No additional authors.

autoware_agnocast_wrapper

The purpose of this package is to integrate Agnocast, a zero-copy middleware, into each topic in Autoware with minimal side effects. Agnocast is a library designed to work alongside ROS 2, enabling true zero-copy publish/subscribe communication for all ROS 2 message types, including unsized message types.

This package provides macros that wrap functions for publish/subscribe operations and smart pointer types for handling ROS 2 messages. When Autoware is built using the default build command, Agnocast is not enabled. However, setting the environment variable ENABLE_AGNOCAST=1 enables Agnocast and results in a build that includes its integration. This design ensures backward compatibility for users who are unaware of Agnocast, minimizing disruption.

Two Integration Approaches

This package provides two approaches for integrating Agnocast. Both will coexist for the foreseeable future.

1. Node Wrapper (agnocast_wrapper::Node)

Use this when you want the entire node to transparently switch between rclcpp::Node and agnocast::Node at runtime. The node wrapper automatically selects the correct underlying implementation based on the ENABLE_AGNOCAST environment variable.

Currently supported APIs:

  • Publisher / Subscription / PollingSubscriber
  • Parameters
  • Logger, Clock
  • Callback groups
  • Node interfaces (partial: get_node_base_interface(), get_node_topics_interface(), get_node_parameters_interface())

Note: Timer (create_wall_timer, create_timer) is not yet supported and will be added in a future update.

#include <autoware/agnocast_wrapper/node.hpp>

class MyNode : public autoware::agnocast_wrapper::Node
{
public:
  explicit MyNode(const rclcpp::NodeOptions & options)
  : Node("my_node", options)
  {
    pub_ = create_publisher<std_msgs::msg::String>("output", 10);
    sub_ = create_subscription<std_msgs::msg::String>(
      "input", 10, [this](std::unique_ptr<const std_msgs::msg::String> msg) { /* ... */ });
  }

private:
  autoware::agnocast_wrapper::Publisher<std_msgs::msg::String>::SharedPtr pub_;
  autoware::agnocast_wrapper::Subscription<std_msgs::msg::String>::SharedPtr sub_;
};

To use the Node wrapper in your package, add the following to your CMakeLists.txt:

find_package(autoware_agnocast_wrapper REQUIRED)
ament_target_dependencies(my_node_component autoware_agnocast_wrapper)

Registering a Node with autoware_agnocast_wrapper_register_node

Instead of calling rclcpp_components_register_node directly, use the autoware_agnocast_wrapper_register_node macro to register your component node. This macro:

  1. Registers the component with rclcpp_components (for component container support)
  2. Creates a standalone executable that can switch between rclcpp::Node and agnocast::Node at runtime based on the ENABLE_AGNOCAST environment variable

When ENABLE_AGNOCAST is not set or set to 0, this macro falls back to standard rclcpp_components_register_node behavior.

find_package(autoware_agnocast_wrapper REQUIRED)

ament_auto_add_library(my_node_component SHARED src/my_node.cpp)
ament_target_dependencies(my_node_component autoware_agnocast_wrapper)

autoware_agnocast_wrapper_register_node(my_node_component
  PLUGIN "my_package::MyNode"
  EXECUTABLE my_node
)

Parameters:

Parameter Required Default Description
PLUGIN Yes - Fully qualified class name of the component
EXECUTABLE Yes - Executable name for the node
ROS2_EXECUTOR No SingleThreadedExecutor Executor to use when ENABLE_AGNOCAST=0 at runtime
AGNOCAST_EXECUTOR No SingleThreadedAgnocastExecutor Executor to use when ENABLE_AGNOCAST=1 at runtime

Valid executor values:

  • ROS2_EXECUTOR: SingleThreadedExecutor, MultiThreadedExecutor
  • AGNOCAST_EXECUTOR: SingleThreadedAgnocastExecutor, MultiThreadedAgnocastExecutor, CallbackIsolatedAgnocastExecutor, AgnocastOnlySingleThreadedExecutor, AgnocastOnlyMultiThreadedExecutor, AgnocastOnlyCallbackIsolatedExecutor

Node class requirements:

The required PLUGIN base class depends on the AGNOCAST_EXECUTOR type. The generated template enforces this via if constexpr at compile time:

AGNOCAST_EXECUTOR Required PLUGIN base class
AgnocastOnly* executors autoware::agnocast_wrapper::Node
Other agnocast executors Any rclcpp::Node-compatible class

Non-AgnocastOnly executors use NodeInstanceWrapper::get_node_base_interface() directly, which works with any node type (rclcpp::Node, agnocast_wrapper::Node, etc.) without requiring a cast. AgnocastOnly executors require get_agnocast_node(), which is only available on autoware::agnocast_wrapper::Node.

File truncated at 100 lines see the full file

CHANGELOG

Changelog for package autoware_agnocast_wrapper

1.8.0 (2026-05-01)

  • chore: align package versions to 1.7.0 and reset changelogs

  • Merge remote-tracking branch 'origin/main' into tmp/bot/bump_version_base

  • docs(autoware_agnocast_wrapper): use FindPackageShare and PathJoinSubstitution in Python launch examples (#999)

  • fix(autoware_agnocast_wrapper): support jazzy (rclcpp 28~) (#980) fix(autoware_agnocast_wrapper): fix Jazzy build by using version-conditional callback type alias

  • fix(autoware_agnocast_wrapper): fix false positive LD_PRELOAD warning in agnocast_env.launch.py (#973)

  • refactor(autoware_agnocast_wrapper): remove executor threading model consistency validation (#970)

    • refactor(autoware_agnocast_wrapper): remove executor threading model consistency validation
    • docs(autoware_agnocast_wrapper): clarify behavior reference tables in README

    - Reword introductory sentence to clarify that only ROS2_EXECUTOR matters when ENABLE_AGNOCAST=0

    - Use full CMake option strings (e.g. SingleThreadedExecutor) instead of abbreviations in both behavior reference tables

    • style(pre-commit): autofix

    * fix(autoware_agnocast_wrapper): fix forbidden word ROS2 to ROS 2 in README ---------Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>

  • feat(autoware_agnocast_wrapper): support message filter in agnocast wrapper (#951)

    * feat(autoware_agnocast_wrapper): add register_node macro for runtime rclcpp/agnocast switching Add [autoware_agnocast_wrapper_register_node]{.title-ref} CMake macro as a drop-in replacement for [rclcpp_components_register_node]{.title-ref}. When ENABLE_AGNOCAST=1, it generates a standalone executable that can switch between rclcpp::Node and agnocast::Node at runtime based on the ENABLE_AGNOCAST environment variable. When ENABLE_AGNOCAST is not set, it falls back to standard rclcpp_components_register_node behavior with zero overhead. Key features:

    • Configurable ROS2 and Agnocast executor types
    • Two-pass template generation (configure_file + file(GENERATE))
    • Support for both rclcpp::Node and agnocast_wrapper::Node plugins
    • Target existence validation at configure time
    • ABI consistency enforcement via autoware_agnocast_wrapper_setup()
    • Change agnocastlib from build_depend to depend
    • fix(autoware_agnocast_wrapper): add static_assert to enforce PLUGIN base class at compile time

    * fix(autoware_agnocast_wrapper): add runtime ROS2 fallback for AgnocastOnly executors When agnocast_only=true but ENABLE_AGNOCAST=0 at runtime, the node now falls back to the ROS2 executor instead of unconditionally using the AgnocastOnly executor.

    * fix(autoware_agnocast_wrapper): warn on mismatched executor threading models Emit a CMake WARNING when ROS2_EXECUTOR and AGNOCAST_EXECUTOR have different threading models (e.g., SingleThreadedExecutor with MultiThreadedAgnocastExecutor), as this silently changes behavior depending on the runtime ENABLE_AGNOCAST value.

    • docs(autoware_agnocast_wrapper): add executor behavior reference table to README
    • style(pre-commit): autofix
    • fix(autoware_agnocast_wrapper): replace forbidden word ROS2 with ROS 2
    • style(pre-commit): autofix

    * fix(autoware_agnocast_wrapper): remove static_assert that fails in non-template main() The static_assert inside if constexpr (agnocast_only) is always evaluated because main() is not a template function. Additionally, the component type header is not included in the generated source (loaded via class_loader at runtime), so the type cannot be resolved at compile time.

    • delete deprecated mark from publish(const MessageT&) API
    • support message_filter in agnocast_wrapper
    • style(pre-commit): autofix
    • fix cpplint
    • fix cpplint
    • add comments

File truncated at 100 lines see the full file

Launch files

Messages

No message files found.

Services

No service files found

Plugins

No plugins found.

Recent questions tagged autoware_agnocast_wrapper at Robotics Stack Exchange