Add a custom ROS message#
Overview#
During the Autoware development, you will probably need to define your own messages. Read the following instructions before adding a custom message.
- 
Message in autoware_msgs define interfaces of Autoware Core.- If a contributor wishes to make changes or add new messages to autoware_msgs, they should first create a new discussion post under the Design category.
 
- If a contributor wishes to make changes or add new messages to 
- 
Any other minor or proposal messages used for internal communication within a component(such as planning) should be defined in another repository. - tier4_autoware_msgs is an example of that.
 
The following is a simple tutorial of adding a message package to autoware_msgs. For the general ROS 2 tutorial, see Create custom msg and srv files.
How to create custom message#
Make sure you are in the Autoware workspace, and then run the following command to create a new package. As an example, let's create a package to define sensor messages.
- 
Create a package cd ./src/core/autoware_msgs ros2 pkg create --build-type ament_cmake autoware_sensing_msgs
- 
Create custom messages You should create .msgfiles and place them in themsgdirectory.NOTE: The initial letters of the .msgand.srvfiles must be capitalized.As an example, let's make .msgfilesGnssInsOrientation.msgandGnssInsOrientationStamped.msgto define GNSS/INS orientation messages:mkdir msg cd msg touch GnssInsOrientation.msg touch GnssInsOrientationStamped.msgEdit GnssInsOrientation.msgwith your editor to be the following content:geometry_msgs/Quaternion orientation float32 rmse_rotation_x float32 rmse_rotation_y float32 rmse_rotation_zIn this case, the custom message uses a message from another message package geometry_msgs/Quaternion.Edit GnssInsOrientationStamped.msgwith your editor to be the following content:std_msgs/Header header GnssInsOrientation orientationIn this case, the custom message uses a message from another message package std_msgs/Header.
- 
Edit CMakeLists.txt In order to use this custom message in C++orPythonlanguages, we need to add the following lines toCMakeList.txt:rosidl_generate_interfaces(${PROJECT_NAME} "msg/GnssInsOrientation.msg" "msg/GnssInsOrientationStamped.msg" DEPENDENCIES geometry_msgs std_msgs ADD_LINTER_TESTS )The ament_cmake_autotool is very useful and is more widely used in Autoware, so we recommend usingament_cmake_autoinstead ofament_cmake.We need to replace find_package(ament_cmake REQUIRED) ament_package()with find_package(ament_cmake_auto REQUIRED) ament_auto_package()
- 
Edit package.xml We need to declare relevant dependencies in package.xml. For the above example we need to add the following content:<buildtool_depend>rosidl_default_generators</buildtool_depend> <exec_depend>rosidl_default_runtime</exec_depend> <depend>geometry_msgs</depend> <depend>std_msgs</depend> <member_of_group>rosidl_interface_packages</member_of_group>We need to replace <buildtool_depend>ament_cmake</buildtool_depend>with<buildtool_depend>ament_cmake_auto</buildtool_depend>in thepackage.xmlfile.
- 
Build the custom message package You can build the package in the root of your workspace, for example by running the following command: colcon build --packages-select autoware_sensing_msgsNow the GnssInsOrientationStampedmessage will be discoverable by other packages in Autoware.
How to use custom messages in Autoware#
You can use the custom messages in Autoware by following these steps:
- Add dependency in package.xml.- For example, <depend>autoware_sensing_msgs</depend>.
 
- For example, 
- Include the .hppfile of the relevant message in the code.- For example, #include <autoware_sensing_msgs/msg/gnss_ins_orientation_stamped.hpp>.
 
- For example,