当前位置: 首页 > news >正文

【ROS学习】ROS中 use_sim_time 参数的含义与作用

文章目录

  • 写在前面
  • 一、背景描述
  • 二、 use_sim_time 参数的含义与作用
  • 三、举例说明
    • 1. 不设置`use_sim_time` (也即 `use_sim_time = false`),播放数据集使用`rosbag play **.bag `
    • 2. 不设置`use_sim_time` (也即 `use_sim_time = false`),播放数据集使用`rosbag play **.bag --clock`
    • 3. 设置`use_sim_time = true`,播放数据集使用`rosbag play **.bag `
    • 4. 设置 `use_sim_time = true`,播放数据集使用`rosbag play **.bag --clock`
  • 参考链接

写在前面

自己的测试环境:
Ubuntu20.04
ROS-Noetic

一、背景描述

  在程序运行是经常会看到 launch 文件中出现如下程序:

<param name="/use_sim_time" value="true" />

但是这句程序的具体含义和作用是什么,并不清晰。这里对当前这个参数进行解析,便于同行参考。

二、 use_sim_time 参数的含义与作用

use_sim_time 的字面含义是(是否)使用仿真时间。当设置参数 use_sim_timetrue 时,意味着使用仿真时间。它的作用是当前ros程序中使用rospy.Time.now() 进行读取,则读取到的是仿真时间。

三、举例说明

首先这里附上读取当前ros 时间的 python 程序:

#!/usr/bin/env python
import rospydef main():# 初始化节点rospy.init_node('get_ros_time')# 等待rospy的内部通信建立# rospy.wait_for_service('rospy.set_param')# 设置循环的速率为1Hzrate = rospy.Rate(1)# 循环直到节点被关闭while not rospy.is_shutdown():rospy.loginfo("====================")current_time = rospy.Time.now()# 打印当前ROS时间rospy.loginfo("Current ROS time is: %f", current_time.to_sec())# 等待下一次循环rate.sleep()
if __name__ == '__main__':try:main()except rospy.ROSInterruptException:pass

1. 不设置use_sim_time (也即 use_sim_time = false),播放数据集使用rosbag play **.bag

运行指令:

roscore
rosparam set use_sim_time false # 这句指令是否执行,结果都是一样的
rosbag play **.bag

这种设置就是典型的使用ROS当前的时间,即使用 ROS系统的最新时间。此时上述 python 程序打印如下:

[INFO] [1722673831.056924]: ====================
[INFO] [1722673831.059255]: Current ROS time is: 1722673831.059109
[INFO] [1722673832.058092]: ====================
[INFO] [1722673832.061643]: Current ROS time is: 1722673832.061444
[INFO] [1722673833.058037]: ====================
[INFO] [1722673833.061723]: Current ROS time is: 1722673833.061501
[INFO] [1722673834.058022]: ====================
[INFO] [1722673834.060917]: Current ROS time is: 1722673834.060722
[INFO] [1722673835.058394]: ====================
[INFO] [1722673835.061902]: Current ROS time is: 1722673835.061656
[INFO] [1722673836.058457]: ====================
[INFO] [1722673836.061843]: Current ROS time is: 1722673836.061635
[INFO] [1722673837.058018]: ====================
[INFO] [1722673837.061253]: Current ROS time is: 1722673837.061034

2. 不设置use_sim_time (也即 use_sim_time = false),播放数据集使用rosbag play **.bag --clock

运行指令:

roscore
rosparam set use_sim_time false # 这句指令是否执行,结果都是一样的
rosbag play **.bag --clock

这种设置和《1. 不设置use_sim_time (也即 use_sim_time = false),播放数据集不使用--clock 》是一样的,即使用``ROS系统的最新时间。此时上述python 程序打印和《1. 不设置use_sim_time(也即use_sim_time = false),播放数据集不使用–clock `》是一样的。

3. 设置use_sim_time = true,播放数据集使用rosbag play **.bag

这种设置就是典型的使用ROS当前的时间,即``ROS系统的最新时间。此时上述python` 程序打印如下:
运行指令:

roscore
rosparam set use_sim_time true
rosbag play **.bag

这种设置就是是有问题的,因为设置了use_sim_time = true,但是没有仿真时间发出来,因此这种设置是错误的。此时上述python 程序不能打印,因为ROS系统没有始终,程序不能运行。

4. 设置 use_sim_time = true,播放数据集使用rosbag play **.bag --clock

运行指令:

roscore
rosparam set use_sim_time true
rosbag play **.bag --clock

这种设置就是典型的使用仿真时间,即使用数据集时间 作为整个ROS系统的时间。此时上述python 程序打印如下:

[INFO] [1722673596.663416, 0.000000]: ====================
[INFO] [1722673596.666444, 0.000000]: Current ROS time is: 0.000000
[INFO] [1722673596.668134, 1317357628.400755]: ====================
[INFO] [1722673596.669762, 1317357628.400755]: Current ROS time is: 1317357628.400755
[INFO] [1722673597.671652, 1317357629.405819]: ====================
[INFO] [1722673597.674328, 1317357629.405819]: Current ROS time is: 1317357629.405819
[INFO] [1722673598.669123, 1317357630.403105]: ====================
[INFO] [1722673598.672169, 1317357630.403105]: Current ROS time is: 1317357630.403105
[INFO] [1722673599.667219, 1317357631.401356]: ====================
[INFO] [1722673599.670245, 1317357631.401356]: Current ROS time is: 1317357631.401356
[INFO] [1722673600.674717, 1317357632.408664]: ====================
[INFO] [1722673600.678019, 1317357632.408664]: Current ROS time is: 1317357632.408664

参考链接

http://www.lryc.cn/news/414605.html

相关文章:

  • python-查找元素3(赛氪OJ)
  • 苹果 Safari 的隐私保护与广告追踪问题 :技术进展与挑战
  • pytest之fixture
  • Rancher
  • Wordpress建站问题记录
  • JavaFx中通过线程池运行或者停止多个周期性任务
  • 使用RabbitMQ实现异步支付状态通知
  • [最短路dijkstra],启动!!!
  • Java企业微信服务商代开发获取AccessToken示例
  • How does age change how you learn?(2)年龄如何影响学习能力?(二)
  • 可验证随机函数 vrf 概述
  • 鸿蒙双向绑定组件:TextArea、TextInput、Search、Checkbox,文本输入组件,图案解锁组件PatternLock
  • JS 算法 - 计数器
  • JavaScript基础——JavaScript运算符
  • E23.【C语言】练习:不创建第三个变量实现两个整数的交换
  • 如何搭建一个web系统?
  • 三十种未授权访问漏洞复现 合集( 二 )
  • C语言学习笔记[29]:函数①
  • 使用Springboot + netty 打造聊天服务之Nacos集群问题记录
  • 全网唯一!R语言顶刊配色包TheBestColors
  • 链表题型思路错误总结
  • 算法学习day28
  • C语言基础题:迷宫寻路(C语言版)
  • 力扣-1两数之和2两数相加-2024/8/3
  • 简站WordPress主题 专业的WordPress建站服务商
  • Final Shell for Mac 虚拟机连接工具【简单易操作,轻松上手】【开发所需连接工具】
  • Oracle JDK:版本、支持与许可
  • 大模型学习笔记 - LLM 之RLHF人类对齐的简单总结
  • 【从零开始一步步学习VSOA开发】 概述
  • 小程序背景图片无法通过 WXSS 获取