zoukankan      html  css  js  c++  java
  • ros学习之消息和服务

    1 msg和srv简介

    • msg:msg文件是描述ROS消息字段的简单文本文件。它们用于为不同语言(c++或者python等)的消息生成源代码。

    • srv:srv文件用来描述服务。它由两部分组成:请求(request)和响应(response)。

    msg文件存储在msg目录中,而srv文件存储在srv目录中。

    msg只是简单的文本文件,每行有一个字段类型和字段名称。您可以使用的字段类型有(如同c++定义变量int x 中的int):

    • int8,int16,int32,int64(plus uint *)
    • float32,float64
    • string
    • time,duration
    • 其他msg文件
    • 可变长度数组array[]和固定长度数组array[C]

    在ROS中还有一种特殊类型:Header,它包含在ROS中常用的时间戳和坐标系信息。你会经常看到一个msg文件中的第一行有Header header

    下面是一个使用Header,字符串基元和另外两个msg的msg示例:

    Header header
    string child_frame_id
    geometry_msgs/PoseWithCovariance pose
    geometry_msgs/TwistWithCovariance twist

    srv文件和msg文件相似,除了它包含两个部分:请求和响应。这两部分用“---”线分隔。下面是一个srv文件的示例:

    int64 A
    int64 B
    ---
    int64 Sum

    在上面的例子中,AB是请求,Sum是响应。

    2 使用msg

    2.1创建msg

    让我们在上一个教程中创建的包中定义一个新的msg。

    $ roscd beginner_tutorials
    $ mkdir msg
    $ echo "int64 num" > msg/Num.msg

    上面的.msg文件示例只包含1行。当然,您可以通过添加多个元素(每行一个)来创建更复杂的文件,如下所示:

    string first_name
    string last_name
    uint8 age
    uint32 score

    还有一步,我们要保证msg文件转换成c++、python或其它语言的源文件。

    打开package.xml,并确保这两行都在其中并取消注释

      <build_depend> message_generation </ build_depend>
      <run_depend> message_runtime </ run_depend>

    注意,在构建时,我们需要“message_generation”,而在运行时,我们只需要“message_runtime”。

    用你喜欢的文本编辑器打开CMakeLists.txt(前面教程中的rosed是一个不错的选择)。

    CMakeLists.txt中添加message_generation依赖于find_package中,这样就可以生成消息。您可以通过简单地增加做message_generation到列表组件,使得它看起来是这样的:

    find_package(catkin REQUIRED COMPONENTS
       roscpp
       rospy
       std_msgs
       message_generation
    )

    您可能会注意到,有时您的项目构建良好,即使您没有调用find_package所有依赖项。这是因为catkin将所有的项目合并为一个,所以如果一个早期的项目调用find_package,你的配置使用相同的值。但是忘记调用意味着你的项目可以在孤立构建时轻松打破。

    还要确保导出消息运行时依赖关系。

    catkin_package(
      ...
      CATKIN_DEPENDS message_runtime ...
      ...)

    找到以下代码块:

    # add_message_files(
    #   FILES
    #   Message1.msg
    #   Message2.msg
    # )

    通过删除取消它符号,替换为你的消息文件,使得它看起来是这样的:

    add_message_files(
      FILES
      Num.msg
    )
    

    通过手动添加.msg文件,我们确保CMake知道在添加其他.msg文件后它必须重新配置项目。

    现在我们必须确保generate_messages()函数被调用。

    对于ROS Hydro及更高版本,您需要取消注释以下行:

    # generate_messages(
    #   DEPENDENCIES
    #   std_msgs
    # )
    • 所以它看起来像:
      generate_messages(
        DEPENDENCIES
        std_msgs
      )

    在早期版本中,您可能只需要取消注释一行:

    generate_messages()

    现在你可以从你的msg定义生成源文件。如果你现在想这样做,跳过msg和srv的通用步骤的下一节

    3 使用rosmsg

    这是所有你需要做的创建一个msg。让我们确保ROS可以使用rosmsg show命令看到它

    用法:

    $ rosmsg show [message type]

    例如:

    $ rosmsg show beginner_tutorials/Num

    你会看见:

    • int64 num

    在上一个示例中,消息类型由两部分组成:

    • beginner_tutorials - 定义消息的包

    • Num - msg的名称Num

    如果你不记得msg所在的包,你可以省略包名。尝试:

     $ rosmsg show Num

    你会看见:

    • [beginner_tutorials / Num]:
      int64 num

    4 使用srv

    创建srv

    让我们使用刚创建的包来创建srv:

    $ roscd beginner_tutorials
    $ mkdir srv

    我们不会手动创建新的srv定义,而是从另一个包中复制现有的srv定义。

    为此,roscp是一个有用的命令行工具,用于将文件从一个包复制到另一个。

    用法:

    $ roscp [package_name] [file_to_copy_path] [copy_path]

    现在我们可以从rospy_tutorials复制一个服务

    $ roscp rospy_tutorials AddTwoInts.srv srv / AddTwoInts.srv

    还有一步。我们需要确保srv文件转换为C ++,Python和其他语言的源代码。

    除非你已经这样做,打开package.xml,并确保这两行在其中并取消注释

      <build_depend> message_generation </ build_depend>
      <run_depend> message_runtime </ run_depend>

    和前面一样,注意在构建时,我们需要“message_generation”,而在运行时,我们只需要“message_runtime”。

    除非已对上一步中的消息执行此操作,否则添加message_generation依赖关系以在CMakeLists.txt中生成消息

    find_package(catkin REQUIRED COMPONENTS
      roscpp
      rospy
      std_msgs
     message_generation
    )

    (尽管它这样的名字,但是message_generation适用于msgsrv。)

    此外,您需要对消息的服务的package.xml进行相同的更改,因此请查看上面所需的其他依赖项。

    移除以取消以下行的注释:

    #add_service_files(
    #FILES
    #Service1.srv
    #Service2.srv
    #)

    并替换您的服务文件的占位符Service * .srv文件:

    add_service_files(
      FILES
      AddTwoInts.srv
    

    现在,您可以从服务定义生成源文件。如果你现在想这样做,跳过msg和srv的通用步骤的下一节

    4.2 使用rossrv

    这就是创建srv所需要做的。让我们确保ROS可以使用rossrv show命令查看它

    用法: 

    $ rossrv show <service type>

    例:

    $ rossrv show beginner_tutorials / AddTwoInts

    你会看见:

    • int64 a
      int64 b
      --- ---
      int64 sum

    类似于rosmsg,你可以找到像这样的服务文件,而不指定包名:

    $ rossrv show AddTwoInts
    [beginner_tutorials / AddTwoInts]:
    int64 a
    int64 b
    --- ---
    int64 sum
    [rospy_tutorials / AddTwoInts]:
    int64 a
    int64 b
    --- ---
    int64 sum

    这里,示出了两个服务。第一个是你刚刚在beginner_tutorials包中创建的,第二个是从rospy_tutorials包中预先存在的一个。

     

    5 msg和srv的常见步骤 

    除非您已在之前的步骤中完成此操作,请更改CMakeLists.txt

    #generate_messages(
    #依赖
    ##std_msgs#或其他包含msgs的软件包
    #)

    取消注释它并添加您依赖的任何包含您的消息使用的.msg文件(在本例中为std_msgs)的包,如下所示:

    generate_messages(
      相关性
      std_msgs
    

    现在我们已经做了一些新的消息,我们需要再次使我们的包:

    #在您的catkin工作区中
    $ roscd beginner_tutorials
    $ cd ../ ..
    $ catkin_make install
    $ cd  - 

    msg目录中的任何.msg文件将生成用于所有受支持语言的代码。C ++消息头文件将在〜/ catkin_ws / devel / include / beginner_tutorials /中生成Python脚本将在〜/ catkin_ws / devel / lib / python2.7 / dist-packages / beginner_tutorials / msg中创建lisp文件出现在〜/ catkin_ws / devel / share / common-lisp / ros / beginner_tutorials / msg /中

    类似地,srv目录中的任何.srv文件都将生成支持的语言的代码。对于C ++,这将生成与消息头文件在同一目录中的头文件。对于Python和Lisp,在'msg'文件夹旁边将有一个'srv'文件夹。

    消息格式的完整规范在消息描述语言页面提供。

    如果您正在构建使用新消息的C ++节点,则还需要声明节点和消息之间的依赖关系,如catkin msg / srv构建文档中所述

     获得帮助

    我们已经看到了很多ROS工具。可能难以跟踪每个命令需要的参数。幸运的是,大多数ROS工具提供自己的帮助。

    尝试:

    $ rosmsg -h
    • 您应该看到不同的rosmsg 命令的列表

      命令:
        rosmsg show显示消息的描述
        rosmsg list列出所有消息
        rosmsg md5显示消息md5sum
        rosmsg package列出包中的消息
        rosmsg软件包列出包含消息的软件包

    您还可以获取有关子命令的帮助

    $ rosmsg show -h
    • 这显示了rosmsg显示所需的参数:
      用法:rosmsg show [options] <message type>
      
      选项:
        -h,--help显示此帮助消息并退出
        -r,--raw显示原始消息文本,包括注释

    评论

    让我们只列出一些我们目前使用的命令:

    • rospack = ros + pack(age):提供与ROS包相关的信息
    • roscd = ROS + CD:Changes lirectory到ROS包或堆

    • rosls = ROS + LS:LIST 文件在ROS文件包

    • roscp = ROS + CP:copy文件从/到一个ROS包

    • rosmsg = ros + msg:提供与ROS消息定义相关的信息
    • rossrv = ros + srv:提供与ROS服务定义相关的信息
    • catkin_make:make(编译)一个ROS包
      • rosmake = ros + make:make(编译)一个ROS包(如果你不使用catkin工作区)

    总结:

    消息与服务

    Header header
    string child_frame_id geometry_msgs/PoseWithCovariance pose
    geometry_msgs
    /TwistWithCovariance twist
    int64 A
    int64 B
    ---
    int64 Sum

    创建消息:

    1 包中建立msg文件夹,在文件夹中创建*.msg

    2 编辑.msg,定义类型和域名

    3 package.xml中添加

      <build_depend>message_generation</build_depend>
      <run_depend>message_runtime</run_depend>

    4 CMakeLists.txt中添加

    find_package(catkin REQUIRED COMPONENTS
       roscpp
       rospy
       std_msgs
       message_generation
    )
    catkin_package(
      ...
      CATKIN_DEPENDS message_runtime ...
      ...)
    add_message_files(
      FILES
      Num.msg
    )
    generate_messages(
      DEPENDENCIES
      std_msgs
    )

    5 编译

    创建服务:

    1 创建srv文件夹,创建.srv文件

    2 编辑.srv文件

    3 .xml文件

    <build_depend>message_generation</build_depend>
    <run_depend>message_runtime</run_depend>

    4  CMakeLists.txt中添加

    find_package(catkin REQUIRED COMPONENTS
      roscpp
      rospy
      std_msgs
     message_generation
    )
    
    add_service_files(
      FILES
      AddTwoInts.srv
    )

    5 编译

    注意:.xml中的内容必须填写,否则编译有错误

  • 相关阅读:
    词云
    结巴分词
    重复值处理
    异常值判断
    MySQL基本使用
    缺失值处理
    fit_transform和transform的区别
    sklearn学习笔记之简单线性回归
    图解机器学习
    Unity---UNet学习(1)----基本方法介绍
  • 原文地址:https://www.cnblogs.com/qixianyu/p/6596845.html
Copyright © 2011-2022 走看看