使用Protobuf来定义ROS消息格式[C++/Python]

一般我们自定义ROS消息使用ros_msgs来定义的,但是考虑到proto在传输消息优于ros自定义的消息格式,我们这里使用proto来定义ros消息
问题来源:之前看apollo的代码,就发现里面的消息使用proto来传输的,那我们我们自己用如何定义和使用呢,主要参考代码https://github.com/ApolloAuto/apollo-platform仓库里面的ros下面的pb_msgs里面的代码
下面的内容也都是里面的代码粘贴复制,感兴趣的直接看源代码就可以

1.生成自定义的proto_msg

https://github.com/ApolloAuto/apollo-platform/blob/master/ros/pb_msgs

1.1 代码结构

代码结构

1.2 代码
1.2.1 msg
__init__.py
 import pkgutil 

__path__ = pkgutil.extend_path(__path__, "modules")
for importer, modname, ispkg in pkgutil.walk_packages(path=__path__, prefix=__name__+'.'):
    if modname.endswith("pb2"):
        try:
            exec("from %s import *" % modname)
        except:
            pass
1.2.2 proto
time.proto
syntax = "proto2";

package pb_msgs;

message Time {
    required int64 sec = 1;
    required int64 nsec = 2;
}
1.2.3 src/pb_msgs
__init__.py
#空
1.2.4 CMakeLists.txt
cmake_minimum_required(VERSION 2.8.3)
project(pb_msgs)

find_package(catkin REQUIRED COMPONENTS genmsg gencpp genpy)

# catkin_python_setup()

add_proto_files(
    DIRECTORY proto
    FILES
    time.proto
)
generate_messages()

catkin_package(
#   INCLUDE_DIRS include
  LIBRARIES pb_msgs_proto
#  CATKIN_DEPENDS other_catkin_pkg
  DEPENDS genmsg gencpp genpy
)

if(NOT EXISTS msg)
  file(MAKE_DIRECTORY msg)
endif()

install(DIRECTORY proto msg
  DESTINATION ${CATKIN_PACKAGE_SHARE_DESTINATION})
1.2.4 package.xml
<package>
<name>pb_msgs</name>
  <version>1.0.0</version>
  <description>
    Protobuf messages for adu common proto.
  </description>
  <maintainer email="info@apollo.auto">Apollo Authors</maintainer>
  <license>BSD</license>
  <buildtool_depend>catkin</buildtool_depend>
  <build_depend>roscpp</build_depend>
  <build_depend>gencpp</build_depend>
  <build_depend>genmsg</build_depend>
  <build_depend>genpy</build_depend>
  <run_depend>roscpp</run_depend>
  <run_depend>gencpp</run_depend>
  <run_depend>genmsg</run_depend>
  <run_depend>genpy</run_depend>

</package>
1.2.5 setup.py
#!/usr/bin/env python

from distutils.core import setup
from catkin_pkg.python_setup import generate_distutils_setup

d = generate_distutils_setup(
    packages=['pb_msgs'],
    package_dir={'': 'src'},
)

setup(**d)
  • 3
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
protobufProtocol Buffers)是一种用于序列化结构化数据的语言无关、平台无关、可扩展的机制。它可以用于网络消息协议的设计。下面将介绍protobuf作为网络消息协议的优点。 首先,protobuf具有良好的性能。相比于其他序列化机制,protobuf具有更高的效率和更小的数据体积。因为protobuf使用二进制编码,并且采用紧凑的数据格式,所以在网络传输过程能够更快地进行数据传输,减少带宽占用和网络资源消耗。 其次,protobuf具有良好的跨语言支持。因为protobuf使用IDL(Interface Definition Language)来定义消息结构,它能够生成多种语言的代码,包括C++, Java, Python等。这样,不同语言的服务端和客户端可以通过protobuf定义消息结构进行通信,实现跨平台、跨语言的消息传递。 此外,protobuf还具有可扩展性。当需求变化时,可以很方便地通过更新消息结构来支持新的数据类型或字段,而无需改变底层的网络通信协议。 protobuf支持向后和向前兼容,可以确保客户端和服务端的平滑升级。 另外,protobuf还支持消息的压缩和加密,以提高数据传输的安全性和效率。通过使用压缩算法和加密算法,可以减少消息的大小,并保护数据的机密性。 综上所述,protobuf作为网络消息协议具有较高的性能、良好的跨语言支持、可扩展性和安全性等优点。因此,使用protobuf作为网络消息协议可以提高数据传输的效率和安全性,并实现跨平台、跨语言的消息通信。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值