ros2学习笔记-CLI工具,记录命令对应操作。

目录

  • 环境变量
  • turtlesim和rqt
    • 以初始状态打开rqt
  • node
    • 启动节点
    • 查看节点列表
    • 查看节点更多信息
    • 命令行参数 --ros-args
  • topic
    • 话题列表
    • 话题类型
    • 话题列表,附加话题类型
    • 根据类型查找话题名
    • 查看话题发布的数据
    • 查看话题的详细信息
    • 查看类型的详细信息
    • 给话题发布消息(在命令行)
    • 带有时间戳的消息
    • 查看话题发布的频率Hz
  • service
    • 服务列表
    • 服务类型
    • 服务列表,附加服务类型
    • 根据类型查找服务名
    • 服务类型结构
    • 调用服务
  • parameters
    • 参数列表
    • 获取参数值
    • 设置参数值
    • 获取节点所有参数
    • 为节点加载参数
    • 启动时指定节点参数
  • action
    • 通信方式
    • 动作列表
    • 动作列表,附加类型
    • 动作更多信息
    • 动作类型结构
    • 发送动作目标
    • 发送动作目标,要求有稳定的反馈
  • topic,service,action的区别
  • 使用 rqt_console 查看特定日志消息
    • 启动
    • 过滤某些级别的消息
  • 启动节点(Launching nodes)
  • 记录和播放数据
    • 记录单个topic
    • 记录多个topic
    • 查看记录信息
    • 记录回放

环境变量

启动前要检查环境变量:ROS_DOMAIN_IDROS_LOCALHOST_ONLY。如果通信时PIN不同,应该首先考虑是不是环境变量设置错误。 Configuring environment

记得source一下ros2。

echo "source /opt/ros/humble/setup.bash" >> ~/.bashrc

turtlesim和rqt

Turtlesim 是一款用于学习 ROS2 的轻量级模拟器。 它说明了 ROS 2 在最基本的层面上做了什么,让您了解以后将如何处理真实机器人或机器人模拟。
ros2 工具是用户管理、内省和与 ROS 系统交互的方式。 它支持针对系统及其操作的不同方面的多个命令。 人们可能会使用它来启动节点、设置参数、收听话题等等。 ros2工具是核心 ROS2 安装的一部分。
rqt 是 ROS2 的图形用户界面 (GUI)工具。 在 rqt 中完成的所有操作都可以在命令行上完成,但 rqt 提供了一种更用户友好的方式来操作 ROS2 元素。

以初始状态打开rqt

rqt每次启动都会以上次关闭时的状态打开,如果rqt界面出现了什么异常卡顿(比如某个页面无法点击,或者无法滑动),可以通过下面命令像第一次打开rqt一样。

rqt --clear-config

node

启动节点

ros2 run <package_name> <executable_name>

查看节点列表

ros2 node list

查看节点更多信息

可以看到节点的话题信息(subscribers and publishers),服务信息(services), 动作信息(action servers and action clients)。

ros2 node info <node_name>    "一般是/node_name"

命令行参数 --ros-args

ROS的命令行参数

--remap
ros2 run some_package some_ros_executable --ros-args --remap foo:=bar
ros2 run some_package some_ros_executable --ros-args -r foo:=bar
ros2 run some_package some_ros_executable --ros-args -r some_node:foo:=bar

--param
ros2 run some_package some_ros_executable --ros-args --param string_param:=test
ros2 run some_package some_ros_executable --ros-args -p string_param:=test
ros2 run some_package some_ros_executable --ros-args -p some_node:string_param:=test

--params-file
ros2 run some_package some_ros_executable --ros-args --params-file params_file.yaml

<params_file.yaml>

node0_name:
  ros__parameters:
     param0_name: param0_value
     ...
     paramN_name: paramN_value
...
nodeM_name:
  ros__parameters:
     ...

* 匹配由斜线划分的单个令牌。** 匹配由斜线划分的零或更多令牌。不允许部分匹配(例如foo*)
例如:

/**:
  ros__parameters:
    string_param: foo
将在所有节点上设置参数string_param.

/**/some_node:
    ros__parameters:
      string_param: foo
将在任何名称空间中的some_node上设置parameter string_param.

/foo/*:
    ros__parameters:
      string_param: foo
将在名称空间 /foo下的任何节点上设置参数string_param(例如只匹配到foo/foo1 而不会匹配到foo/foo1/foo11).

topic

话题可以理解为是ROS中节点交换消息的总线。

在图中查看节点和话题之间的结构:

rqt_graph

圆的是节点,方的是话题。
在这里插入图片描述

话题列表

ros2 topic list

话题类型

ros2 topic type <topic_name>

话题列表,附加话题类型

类型其实就是消息结构(消息属于哪个类)。

ros2 topic list -t

根据类型查找话题名

ros2 topic find <type_name>

查看话题发布的数据

ros2 topic echo <topic_name>

注意:数据只有在发布时终端才可以看到。
此命令会发布一个新话题,话题名字类似于/_ros2cli_26646,在rqt_graph中取消选中Debug即可看见。

查看话题的详细信息

可以查看话题的消息类型,以及其被多少个节点发布消息和被多少个节点订阅。

ros2 topic info <topic_name>

查看类型的详细信息

这里的类型不只是话题的类型可以被查看,其他类型也可以使用此方法看到具体的结构信息。

ros2 interface show <msg type>

查看所有类型的列表

ros2 interface list

ros2 interface show geometry_msgs/msg/Twist为例,显示的类型如下:

# This expresses velocity in free space broken into its linear and angular parts.
Vector3  linear
        float64 x
        float64 y
        float64 z
Vector3  angular
        float64 x
        float64 y
        float64 z

其中,linearangular可以理解为一个变量,Vector3 是变量的类型,x,y,zlinear/angular的成员,也是变量。

给话题发布消息(在命令行)

'<args>'参数需要以yaml语法作为输入。

ros2 topic pub <topic_name> <msg_type> '<args>'

'<args>'使用单引号和双引号是等价的,都可以使用。
例如:ros2 topic pub --once /turtle1/cmd_vel geometry_msgs/msg/Twist "{linear: {x: 2.0, y: 0.0, z: 0.0}, angular: {x: 0.0, y: 0.0, z: 1.8}}"(格式和echo显示的结果是一样的)

  • --once是一个可选的参数,意为“发布一条消息然后退出”。
  • --rate 1 :以1Hz的频率持续发布消息(为默认参数设置)。
  • <args>是yaml格式的,每一个冒号后面的空格都不可以省略。

在rqt-graph中显示如下:
在这里插入图片描述

带有时间戳的消息

如果消息的header为完整的标题类型std_msgs/msg/Header(有没有可以通过interface show 查看),设置为auto会自动填充为当前时间。

ros2 topic pub /pose geometry_msgs/msg/PoseStamped '{header: "auto", pose: {position: {x: 1.0, y: 2.0, z: 3.0}}}'

如果消息中的类型为builtin_interfaces/msg/Time,可以设置now

ros2 topic pub /reference sensor_msgs/msg/TimeReference '{header: "auto", time_ref: "now", source: "dumy"}'

sensor_msgs/msg/TimeReference 结构如下:
在这里插入图片描述

查看话题发布的频率Hz

ros2 topic hz <topic_name>

service

服务是节点的另一种通信方法,基于呼叫和响应(call-and-response)模型,话题是publisher-subscriber模型。服务只有在客户端专门调用时才提供数据。

服务列表

ros2 service list

服务类型

服务类型的定义与话题类型类似,但是服务类型有两个部分:一条是请求的消息,另一条是响应的消息。

ros2 service type <service_name>

服务列表,附加服务类型

ros2 service list -t

根据类型查找服务名

ros2 service find <type_name>

服务类型结构

查看方法:

ros2 interface show <type_name>

结构:

request structure 
---
response structure
  • ---是request structure 和 response structure 的分隔符。

调用服务

ros2 service call <service_name> <service_type> <arguments>

例如:ros2 service call /spawn turtlesim/srv/Spawn "{x: 2, y: 2, theta: 0.2, name: ''}"
会返回:

requester: making request: turtlesim.srv.Spawn_Request(x=2.0, y=2.0, theta=0.2, name='')

response:
turtlesim.srv.Spawn_Response(name='turtle2')

parameters

参数是节点(node)的配置值,每个节点都维护自己的参数,也有共享参数(和C++很像,有私有成员,也有静态成员)。

参数列表

ros2 param list

获取参数值

ros2 param get <node_name> <parameter_name>

设置参数值

ros2 param set <node_name> <parameter_name> <value>

获取节点所有参数

ros2 param dump <node_name>

如果想将参数存入到文件中,可以使用linux中的>运算符:

ros2 param dump /turtlesim > turtlesim.yaml 

导出为yaml结构,以后使用时可以直接导入。

为节点加载参数

ros2 param load <node_name> <parameter_file>

例如:ros2 param load /turtlesim turtlesim.yaml
需要注意的是只读的参数只能在启动时进行修改,所以那些参数将不会被修改。

启动时指定节点参数

ros2 run <package_name> <executable_name> --ros-args --params-file <file_name>

例如:ros2 run turtlesim turtlesim_node --ros-args --params-file turtlesim.yaml
这将使得所有参数根据给定的文件更新,具体细节见ROS的命令行参数。

action

action基于topic和service。它的功能类似于service。但是action的特点是:动作不仅可以被取消,还提供了稳定的反馈(service只能返回一个单独的回复response)。
action由三个部分组成:目标,反馈和结果。
操作使用client-server模型,类似于Publisher-Subscriber模型。 “action client”节点将目标发送到“action server”节点,该节点确认目标并返回反馈和结果。

当调用:

 ros2 run turtlesim turtle_teleop_key

终端会显示:

Reading from keyboard
---------------------------
Use arrow keys to move the turtle.
Use G|B|V|C|D|E|R|T keys to rotate to absolute orientations. 'F' to cancel a rotation.'Q' to quit.

Use arrow keys to move the turtle.对应topic,
Use G|B|V|C|D|E|R|T keys to rotate to absolute orientations. ‘F’ to cancel a rotation. ‘Q’ to quit.对应action。

每次按下这些按键时,都会将目标发送到/turtlesim节点的action服务器上。一旦乌龟旋转完成,乌龟节点会返回一个信息,比如:[INFO] [turtlesim]: Rotation goal completed successfully ,实际上不同的动作对应不同的反馈信息和结果。

对于动作而言,client可以取消目标(按下F),server也可以取消目标(连续按下D G,server会自动放弃第一个目标,但不是所有的server都是这样处理)。

通信方式

执行ros2 node info /turtlesim可以看到最下方关于action的信息:

  Action Servers:
    /turtle1/rotate_absolute: turtlesim/action/RotateAbsolute
  Action Clients:

这说明/turtlesim节点会接受/turtle1/rotate_absolute提供的目标并且给它提供反馈。

执行ros2 node info /teleop_turtle可以看到最下方关于action的信息:

  Action Servers:

  Action Clients:
    /turtle1/rotate_absolute: turtlesim/action/RotateAbsolute

这说明/teleop_turtle节点会发送目标给/turtle1/rotate_absolute

动作列表

ros2 action list

动作列表,附加类型

ros2 action list -t

动作更多信息

会返回动作的客户端和服务端节点。

ros2 action info /turtle1/rotate_absolute

动作类型结构

turtlesim/action/RotateAbsolute类型为例:

ros2 interface show turtlesim/action/RotateAbsolute

返回:

# The desired heading in radians
float32 theta
---
# The angular displacement in radians to the starting position
float32 delta
---
# The remaining rotation in radians
float32 remaining

分成了部分,其中---是分隔符,第一部分是目标,第二部分是结果,第三部分是反馈信息。

发送动作目标

ros2 action send_goal <action_name> <action_type> '<values>'

<values>需要采用YAML格式。
例如:ros2 action send_goal /turtle1/rotate_absolute turtlesim/action/RotateAbsolute "{theta: 1.57}"

发送动作目标,要求有稳定的反馈

ros2 action send_goal /turtle1/rotate_absolute turtlesim/action/RotateAbsolute "{theta: -1.57}" --feedback

会返回:

Sending goal:
   theta: -1.57

Goal accepted with ID: e6092c831f994afda92f0086f220da27

Feedback:
  remaining: -3.1268222332000732

Feedback:
  remaining: -3.1108222007751465

…

Result:
  delta: 3.1200008392333984

Goal finished with status: SUCCEEDED

其中Feedback会持续提供反馈信息,直到目标达到。

topic,service,action的区别

通信机制描述使用场景
Topic一种异步消息队列,分为publisher(发送信息)和subscriber(接受消息)处理连续数据流,多对多的形式
Service一种同步请求/响应交互模式(发送一次,反馈/响应一次)一部分定义请求部分,一部分定义回应部分
Action一种异步请求/响应交互模式,带有反馈机制(发送一个目标,执行过程中连续反馈,直到达到目标)需要反馈/状态跟踪,需要花费大量时间,可以被中断

使用 rqt_console 查看特定日志消息

启动

ros2 run rqt_console rqt_console

过滤某些级别的消息

只查看级别大于等于WARN的日志消息。

ros2 run turtlesim turtlesim_node --ros-args --log-level WARN  #大小写都可以

ROS2的日志级别按严重性排序:

Fatal
Error
Warn
Info
Debug

默认级别是Info,因此看不到级别为Debug的消息。
如果设置显示的消息级别是Warn,那么InfoDebug级别的消息都会被显示。

启动节点(Launching nodes)

使用命令行工具一次启动多个节点。

ros2 launch turtlesim multisim.launch.py

这会启动两个turtlesim node,使用ros2 topic list可以看到两个node分别为turtlesim1turtlesim2

/parameter_events
/rosout
/turtlesim1/turtle1/cmd_vel
/turtlesim1/turtle1/color_sensor
/turtlesim1/turtle1/pose
/turtlesim2/turtle1/cmd_vel
/turtlesim2/turtle1/color_sensor
/turtlesim2/turtle1/pose

因此我们可以开两个终端来分别控制两个节点:

  1. ros2 topic pub /turtlesim1/turtle1/cmd_vel geometry_msgs/msg/Twist "{linear: {x: 2.0, y: 0.0, z: 0.0}, angular: {x: 0.0, y: 0.0, z: 1.8}}"
  2. ros2 topic pub /turtlesim2/turtle1/cmd_vel geometry_msgs/msg/Twist "{linear: {x: 2.0, y: 0.0, z: 0.0}, angular: {x: 0.0, y: 0.0, z: -1.8}}"

注意:
也可以使用XML和YAML来创建启动文件。 具体细节可以查看Using Python, XML, and YAML for ROS 2 Launch Files

对于launch的更多信息可以查看ROS2 launch tutorials

记录和播放数据

记录有关topic的数据,因此可以随时重播和检查。

记录单个topic

ros2 bag record <topic_name>

例如:ros2 bag record /turtle1/cmd_vel
这会根据时间戳来创建bag文件的名称,想要指定文件名称可以用-o来指定。

记录多个topic

记录多个topic时直接输入多个topic名称,用空格隔开。

ros2 bag record -o subset <topic1_name> <topic2_name> 

-o选项允许为bag文件选择一个唯一的名称。这里的subset就是要创建的文件目录名称。
例如:ros2 bag record -o subset /turtle1/cmd_vel /turtle1/pose

查看记录信息

ros2 bag info <bag_file_name>

例如:ros2 bag info subset

记录回放

ros2 bag play <bag_file_name>

有关ros bag更详细的信息在这里找到:https://github.com/ros2/rosbag2。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/335658.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

线程状态转换

&#x1f4dd;个人主页&#xff1a;五敷有你 &#x1f525;系列专栏&#xff1a;并发编程⛺️稳中求进&#xff0c;晒太阳 程状态转换 假设有线程Thread t 情况1 new-->RUNNABLE 当调用t.start()方法时&#xff0c;由new ->RUNNABLE 情况2 RUNNABLE WAITING t…

无/自监督去噪(1)——一个变迁:N2N→N2V→HQ-SSL

目录 1. 前沿2. N2N3. N2V——盲点网络&#xff08;BSNs&#xff0c;Blind Spot Networks&#xff09;开创者3.1. N2V实际是如何训练的&#xff1f; 4. HQ-SSL——认为N2V效率不够高4.1. HQ-SSL的理论架构4.1.1. 对卷积的改进4.1.2. 对下采样的改进4.1.3. 比N2V好在哪&#xff…

c++基础2

一、c的引用 引用和指针的的区别&#xff1f; 引用是一种更安全的指针&#xff1a; 1. 引用必须初始化&#xff0c;指针可以不用初始化 int a 10; int *p; // 指针可能是野指针 int &b a;//引用赋值"&#xff0c;通常指的是直接修改引用所引用的对象的值&#xff0…

Three.JS教程1 环境搭建、场景与相机

Three.JS教程1 环境搭建、场景与相机 一、Three.JS简介二、环境搭建1. 开发准备2. 安装 three.js3. 新建文件index.htmlmain.js 4. 关于附加组件5. 启动 三、创建场景1. 场景的概念2. 相机的概念3. 相机的几个相关概念&#xff08;1&#xff09;视点&#xff08;Position&#…

信息登记小程序怎么做_重塑用户互动,开启全新营销篇章

信息登记小程序&#xff1a;重塑用户互动&#xff0c;开启全新营销篇章 在数字化浪潮中&#xff0c;小程序以其便捷、高效的特点&#xff0c;逐渐成为企业与用户之间沟通的桥梁。其中&#xff0c;信息登记小程序更是凭借其独特的定位&#xff0c;在众多小程序中脱颖而出。本文…

荣誉艾尔迪亚人的题解

目录 原题描述&#xff1a; 题目背景 题目描述 输入格式 输出格式 样例 Input 1 Output 1 Input 2 Output 2 数据范围&#xff1a; 样例解释 主要思路&#xff1a; 代码code&#xff1a; 原题描述&#xff1a; 时间限制: 1000ms 空间限制: 65536kb 题目背景 ​…

ros2 基础教程-使用ROS 2进行相机标定

ROS 2进行相机标定&#xff08;Camera Calibration&#xff09; 相机&#xff08;摄像头&#xff09;是一种非常精密的光学仪器&#xff0c;对外界环境的感知非常敏感。由于摄像头内部和外部的一些原因&#xff0c;摄像头采集的图像常常会发生一定的畸变。如果直接将采集到的图…

【分布式技术】ELK大型日志收集分析系统

目录 步骤一&#xff1a;完成JAVA环境部署 步骤二&#xff1a;部署ES节点&#xff08;三台主机&#xff09; 步骤三&#xff1a;内核参数修改 步骤四&#xff1a;web端查看验证 步骤五&#xff1a;yum安装nginx 步骤六&#xff1a;完成logstash部署 步骤七&#xff1a;部…

matlab抽取与插值

什么是抽取&#xff1f; 我们假设一个数字信号 x ( n ) , n 1 , 2 , . . . , N x(n),n1,2,...,N x(n),n1,2,...,N共有 N N N个点&#xff0c;抽取就是每个几个点抽1个点&#xff0c;比如2倍抽取&#xff0c;那么抽取后的信号为 y ( n ) , y ( 1 ) x ( 1 ) , y ( 2 ) x ( 3 …

stm32 FOC 电机介绍

今年开始学习foc控制无刷电机&#xff0c;这几天把所学整理一下&#xff0c;记录一下知识内容。 前言: 为什么要学习FOC? 1.电机控制是自动化控制领域重要一环。 2.目前直流无刷电机应用越来越广泛&#xff0c;如无人机、机械臂、云台、仿生机器人等等。 需要什么基础&…

项目管理十大知识领域之风险管理

1. 项目风险管理的定义与概述 项目风险管理是指为了实现项目目标&#xff0c;有计划地识别、评估和应对项目中的各种风险的过程。项目风险管理的核心在于提前辨识到可能对项目目标产生不利影响的不确定因素&#xff0c;并采取适当的措施降低或消除这些风险&#xff0c;以保障项…

three.js从入门到精通系列教程005 - three.js使用鼠标拖拽缩放浏览全景图

<!DOCTYPE html> <html><head><meta charset"UTF-8"><title>three.js从入门到精通系列教程005 - three.js使用鼠标拖拽缩放浏览全景图</title><script src"ThreeJS/three.js"></script><script src&qu…

基于SpringBoot Vue博物馆管理系统

大家好✌&#xff01;我是Dwzun。很高兴你能来阅读我&#xff0c;我会陆续更新Java后端、前端、数据库、项目案例等相关知识点总结&#xff0c;还为大家分享优质的实战项目&#xff0c;本人在Java项目开发领域有多年的经验&#xff0c;陆续会更新更多优质的Java实战项目&#x…

深入数仓离线数据同步:问题分析与优化措施

一、前言 在数据仓库领域&#xff0c;离线数仓和实时数仓是常见的两种架构类型。离线数仓一般通过定时任务在特定时间点&#xff08;通常是凌晨&#xff09;将业务数据同步到数据仓库中。这种方式适用于对数据实时性要求不高&#xff0c;更侧重于历史数据分析和报告生成的场景…

Spring第六天(注解开发第三方Bean)

注解开发管理第三方Bean 显然&#xff0c;我们无法在第三方Bean中写入诸如service这样的注解&#xff0c;所以&#xff0c;Spring为我们提供了Bean这一注解来让我们通过注解管理第三方Bean 第二种导入方式由于可读性太低&#xff0c;故只介绍第一种导入方式&#xff0c;这里我…

【JavaEE】线程安全的集合类

作者主页&#xff1a;paper jie_博客 本文作者&#xff1a;大家好&#xff0c;我是paper jie&#xff0c;感谢你阅读本文&#xff0c;欢迎一建三连哦。 本文于《JavaEE》专栏&#xff0c;本专栏是针对于大学生&#xff0c;编程小白精心打造的。笔者用重金(时间和精力)打造&…

【ARM Cortex-M 系列 1.1 -- Cortex-M33 与 M4 差异 详细介绍】

请阅读【嵌入式开发学习必备专栏 之 Cortex-Mx 专栏】 文章目录 背景Cortex-M33 与 M4 差异Cortex-M33Cortex-M4关系和差异举例说明 背景 在移植 RT-Thread 到 瑞萨RA4M2&#xff08;Cortex-M33&#xff09;上时&#xff0c;遇到了hardfault 问题&#xff0c;最后使用了Cortex…

路由器结构

路由器是连接互联网的设备&#xff0c;本文主要描述路由器的结构组成。 如上所示&#xff0c;OSI&#xff08;Open System Interconnect&#xff09;开放系统互联参考模型是互联网架构的标准协议栈&#xff0c;由ISO标准组织制定。自底向上&#xff0c;互联网架构分为7层&#…

行政快递管理软件使用教程

勤勤恳恳的行政人员&#xff0c;还在努力地修改企业快递管理制度&#xff0c;而聪明的行政人员&#xff0c;已经开始物色合适的快递管理软件了。随着企业管理的现代化发展&#xff0c;我们会发现很多管理模块都有相应的管理制度。人力资源管理、客户关系管理、财务管理等等&…

Unity animator动画倒放的方法

在Unity中&#xff0c; 我们有时候不仅需要animator正放的效果&#xff0c;也需要倒放的效果。但我们在实际制作动画的时候可以只制作一个正放的动画&#xff0c;然后通过代码控制倒放。 实现方法其实很简单&#xff0c;只需要把animator动画的speed设置为-1即为倒放&#xff…