ROS机器人入门第七课:参数服务器

2024-04-21 23:04

本文主要是介绍ROS机器人入门第七课:参数服务器,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • ROS机器人入门第七课:参数服务器
    • 一、参数服务器介绍
    • 二、参数操作
      • 1.参数服务器新增(修改)参数
      • 2.参数服务器获取参数
      • 3.参数服务器删除参数

ROS机器人入门第七课:参数服务器

一、参数服务器介绍

参数服务器在ROS中主要用于实现不同节点之间的数据共享。参数服务器相当于是独立于所有节点的一个公共容器,可以将数据存储在该容器中,被不同的节点调用,当然不同的节点也可以往其中存储数据,关于参数服务器的典型应用场景如下:

导航实现时,会进行路径规划,比如: 全局路径规划,设计一个从出发点到目标点的大致路径。本地路径规划,会根据当前路况生成时时的行进路径

上述场景中,全局路径规划和本地路径规划时,就会使用到参数服务器:

  • 路径规划时,需要参考小车的尺寸,我们可以将这些尺寸信息存储到参数服务器,全局路径规划节点与本地路径规划节点都可以从参数服务器中调用这些参数

参数服务器,一般适用于存在数据共享的一些应用场景。

概念
以共享的方式实现不同节点之间数据交互的通信模式。

作用
存储一些多节点共享的数据,类似于全局变量。

案例
实现参数增删改查操作。

参数可使用数据类型:

  • 32-bit integers:32位整数类型,用于存储不需要小数部分的数值,如计数器、标识符等。

  • booleans:布尔类型,用于存储真(True)或假(False)值,适用于开关状态、条件判断等场景。

  • strings:字符串类型,用于存储文本数据,如路径名、配置选项的名称等。

  • doubles:双精度浮点数类型,用于存储需要精确到小数点后多位的数值,如传感器读数、位置坐标等。

  • iso8601 dates:符合ISO 8601标准的日期格式,用于存储日期和时间信息,如日志时间戳、事件发生的时间等。

  • lists:列表类型,用于存储一系列同种或不同种类型的数据项,适用于配置参数的多个值、一系列操作指令等。

  • base64-encoded binary data:Base64编码的二进制数据类型,用于存储二进制数据,如图像数据、文件内容等。采用Base64编码是因为参数服务器通常以文本形式存储和传输数据,而Base64编码能将二进制数据转换为文本表示。

  • 字典:字典类型(也称为映射或哈希表),用于存储键值对,每个键对应一个值。适用于存储具有结构性的数据,如配置参数的集合、不同类型数据的聚合等。

注意:参数服务器不是为高性能而设计的,因此最好用于存储静态的非二进制的简单数据

二、参数操作


需求:实现参数服务器参数的增删改查操作。


1.参数服务器新增(修改)参数

#! /usr/bin/env python
# - coding: utf-8 -*-
"""参数服务器操作之新增与修改(二者API一样)_Python实现:本脚本展示了如何在ROS中使用Python设置和更新参数服务器的参数。
"""# 导入rospy模块,这是ROS中与Python程序交互的主要模块。
import rospy# 确定这个脚本是作为主程序运行,而不是作为模块导入到其他脚本中。
if __name__ == "__main__":# 初始化一个ROS节点,节点名为"set_update_paramter_p"。# 在ROS中,节点是通信的基本单元,每个节点都要有一个唯一的名称。rospy.init_node("set_update_paramter_p")# 下面一系列的set_param调用设置了参数服务器上的不同类型的参数。# 参数服务器是ROS中用于存储和管理参数的系统,如配置参数。# 设置一个名为"p_int"的整型参数,值为10。rospy.set_param("p_int",10)# 设置一个名为"p_double"的浮点型参数,值为3.14。rospy.set_param("p_double",3.14)# 设置一个名为"p_bool"的布尔型参数,值为True。rospy.set_param("p_bool",True)# 设置一个名为"p_string"的字符串型参数,值为"hello python"。rospy.set_param("p_string","hello python")# 设置一个名为"p_list"的列表型参数,值为一个字符串列表["hello", "haha", "xixi"]。rospy.set_param("p_list",["hello","haha","xixi"])# 设置一个名为"p_dict"的字典型参数,值为一个字典{"name":"hulu","age":8}。rospy.set_param("p_dict",{"name":"hulu","age":8})# 修改已有的参数。这行代码将名为"p_int"的参数的值更改为100。rospy.set_param("p_int",100)

ros函数解释:

  • rospy.init_node(NAME, ...): 这个函数告诉ROS你将要开始一个新的节点。NAME是节点的名称,在ROS网络中应当是唯一的。

  • rospy.set_param(PARAM_NAME, PARAM_VALUE): 这是一个设置参数的函数,PARAM_NAME是要设置的参数的名称,PARAM_VALUE是参数的值,可以是整型、浮点型、布尔型、字符串型、列表型、字典型等。这个函数既可以用来创建新的参数,也可以用来修改现有的参数。如果参数已经存在,这个函数将更新它的值。

然后和前几篇文章一样修改CmakeLists.txt文件和为python文件添加可执行权限,这里不再赘述


可以用rosparam list列出当前参数服务器上所有的参数名称
在这里插入图片描述

可以用rosparam get从参数服务器检索单个参数的值

在这里插入图片描述


2.参数服务器获取参数

#! /usr/bin/env python
# - coding: utf-8 -*-
"""参数服务器操作之查询_Python实现:本脚本展示了如何在ROS中使用Python查询参数服务器中的参数。
"""# 导入rospy模块,rospy是ROS用于Python的主要客户端库。
import rospy# 这个条件确保了以下代码只有在该Python文件作为主程序运行时才会执行。
# 当文件被其他文件import时,这些代码不会执行。
if __name__ == "__main__":# 初始化ROS节点,节点名为"get_param_p"。rospy.init_node("get_param_p")# 获取参数服务器上名为"p_int"的参数,如果该参数不存在,则返回默认值10000。int_value = rospy.get_param("p_int",10000)# 获取参数服务器上名为"p_double"的参数,如果该参数不存在,将引发错误。double_value = rospy.get_param("p_double")# 获取参数服务器上名为"p_bool"的参数,如果该参数不存在,将引发错误。bool_value = rospy.get_param("p_bool")# 获取参数服务器上名为"p_string"的参数,如果该参数不存在,将引发错误。string_value = rospy.get_param("p_string")# 获取参数服务器上名为"p_list"的参数,如果该参数不存在,将引发错误。p_list = rospy.get_param("p_list")# 获取参数服务器上名为"p_dict"的参数,如果该参数不存在,将引发错误。p_dict = rospy.get_param("p_dict")# 使用loginfo打印信息,显示获取的各种类型的参数。rospy.loginfo("获取的数据:%d,%.2f,%d,%s",int_value,double_value,bool_value,string_value)# 遍历列表参数,并打印其元素。for ele in p_list:rospy.loginfo("ele = %s", ele)# 打印字典参数中的"name"和"age"键对应的值。rospy.loginfo("name = %s, age = %d", p_dict["name"], p_dict["age"])# get_param_cached用于获取参数的缓存值,这可能比直接获取参数更快。int_cached = rospy.get_param_cached("p_int")rospy.loginfo("缓存数据:%d", int_cached)# get_param_names返回一个包含所有参数名称的列表。names = rospy.get_param_names()# 遍历并打印出所有参数的名称。for name in names:rospy.loginfo("name = %s", name)# 打印分隔线,用于清晰显示输出结果。rospy.loginfo("-" * 80)# has_param检查参数服务器是否有名为"p_int"的参数。flag = rospy.has_param("p_int")rospy.loginfo("包含p_int吗?%d", flag)# search_param搜索特定的参数名称,并返回完整的参数名称路径。# 如果参数位于不同的命名空间下,这个方法会很有用。key = rospy.search_param("p_int")rospy.loginfo("搜索的键 = %s", key)

ROS函数解释:

  • rospy.init_node(NAME, ...): 初始化一个ROS节点。NAME是节点的名称,在ROS网络中必须是唯一的。

  • rospy.get_param(PARAM_NAME, DEFAULT=None): 从参数服务器获取一个参数。如果指定的PARAM_NAME存在,返回其值;否则返回DEFAULT指定的默认值。

  • rospy.loginfo(msg, *args): 将一个消息作为info类型记录到/rosout话题和节点的控制台。msg是消息格式,*args是格式化消息的参数。

  • rospy.get_param_cached(PARAM_NAME): 与get_param类似,但是它使用缓存来加速参数的获取。适合频繁查询的情况。

  • rospy.get_param_names(): 返回一个字符串列表,包含参数服务器上所有参数的名称。

  • rospy.has_param(PARAM_NAME): 检查参数服务器上是否有指定的参数。返回True或False。

  • rospy.search_param(PARAM_NAME): 在当前命名空间以及父命名空间中搜索参数,并返回完整的参数名称(可能包含命名空间路径)。如果参数不存在,返回None。

每个函数都与ROS参数服务器的操作有关,这些操作用于查询和管理参数,这些参数可以配置ROS节点的行为。

在这里插入图片描述

3.参数服务器删除参数

下面是提供的代码块的详细注释版本,包括ROS函数delete_param的作用说明:

#! /usr/bin/env python
# 上面的shebang指令告诉操作系统使用env来查找python解释器的位置,以便执行此脚本。"""参数服务器操作之删除_Python实现:rospy.delete_param("键")键存在时,可以删除成功,键不存在时,会抛出异常。本脚本用于演示如何从ROS参数服务器中删除一个参数。
"""# 导入rospy模块,rospy是ROS用于Python的主要客户端库,用于与ROS系统通信。
import rospy# 这个条件确保了以下代码只有在该Python文件作为主程序运行时才会执行。
# 当文件被其他文件import时,这些代码不会执行。
if __name__ == "__main__":# rospy.init_node用于告诉ROS系统这里是一个新的节点。# "delete_param_p"是这个新节点的名称。rospy.init_node("delete_param_p")# 尝试执行一个可能会抛出异常的操作。try:# rospy.delete_param函数用于删除参数服务器上的一个参数。# 这里尝试删除名为"p_int"的参数。# 如果参数存在,它将被删除。rospy.delete_param("p_int")except Exception as e:  # 如果在尝试删除参数时出现任何异常,将执行这个块内的代码。# rospy.loginfo函数用来打印信息级别的日志到/rosout话题和节点的控制台。# 这里它被用来告知用户参数删除失败。rospy.loginfo("删除失败")

ROS函数解释:

  • rospy.init_node(NAME, ...): 这个函数初始化一个ROS节点。NAME是节点的名称,在ROS网络中必须是唯一的。节点是ROS通信网络中的一个基本单位,所有的通信工具如话题(topics)、服务(services)和参数(parameters)都会与一个特定的节点相关联。

  • rospy.delete_param(PARAM_NAME): 这个函数用于删除参数服务器上的一个参数。PARAM_NAME是你想要删除的参数的名称。如果参数存在,它将被删除。如果不存在,函数会抛出rospy.ROSException

  • rospy.loginfo(msg, *args): 这个函数用来打印信息级别的日志到/rosout话题和节点的控制台。这对于调试和用户反馈都是非常有用的。

在这段代码中,delete_param函数是用来从ROS参数服务器上删除一个指定名称的参数。如果这个参数不存在,将会抛出一个异常,然后脚本会捕获这个异常并打印出"删除失败"的信息。这是一个参数管理的典型用例,确保了在删除不必要或过时的参数时系统的稳定性和一致性。

删除p_int
在这里插入图片描述
再次删除p_int
在这里插入图片描述

这篇关于ROS机器人入门第七课:参数服务器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/924254

相关文章

Spring WebClient从入门到精通

《SpringWebClient从入门到精通》本文详解SpringWebClient非阻塞响应式特性及优势,涵盖核心API、实战应用与性能优化,对比RestTemplate,为微服务通信提供高效解决... 目录一、WebClient 概述1.1 为什么选择 WebClient?1.2 WebClient 与

Python极速搭建局域网文件共享服务器完整指南

《Python极速搭建局域网文件共享服务器完整指南》在办公室或家庭局域网中快速共享文件时,许多人会选择第三方工具或云存储服务,但这些方案往往存在隐私泄露风险或需要复杂配置,下面我们就来看看如何使用Py... 目录一、android基础版:HTTP文件共享的魔法命令1. 一行代码启动HTTP服务器2. 关键参

Spring Boot 与微服务入门实战详细总结

《SpringBoot与微服务入门实战详细总结》本文讲解SpringBoot框架的核心特性如快速构建、自动配置、零XML与微服务架构的定义、演进及优缺点,涵盖开发环境准备和HelloWorld实战... 目录一、Spring Boot 核心概述二、微服务架构详解1. 微服务的定义与演进2. 微服务的优缺点三

从入门到精通详解LangChain加载HTML内容的全攻略

《从入门到精通详解LangChain加载HTML内容的全攻略》这篇文章主要为大家详细介绍了如何用LangChain优雅地处理HTML内容,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录引言:当大语言模型遇见html一、HTML加载器为什么需要专门的HTML加载器核心加载器对比表二

SpringBoot改造MCP服务器的详细说明(StreamableHTTP 类型)

《SpringBoot改造MCP服务器的详细说明(StreamableHTTP类型)》本文介绍了SpringBoot如何实现MCPStreamableHTTP服务器,并且使用CherryStudio... 目录SpringBoot改造MCP服务器(StreamableHTTP)1 项目说明2 使用说明2.1

从入门到进阶讲解Python自动化Playwright实战指南

《从入门到进阶讲解Python自动化Playwright实战指南》Playwright是针对Python语言的纯自动化工具,它可以通过单个API自动执行Chromium,Firefox和WebKit... 目录Playwright 简介核心优势安装步骤观点与案例结合Playwright 核心功能从零开始学习

Spring Boot spring-boot-maven-plugin 参数配置详解(最新推荐)

《SpringBootspring-boot-maven-plugin参数配置详解(最新推荐)》文章介绍了SpringBootMaven插件的5个核心目标(repackage、run、start... 目录一 spring-boot-maven-plugin 插件的5个Goals二 应用场景1 重新打包应用

从入门到精通MySQL联合查询

《从入门到精通MySQL联合查询》:本文主要介绍从入门到精通MySQL联合查询,本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下... 目录摘要1. 多表联合查询时mysql内部原理2. 内连接3. 外连接4. 自连接5. 子查询6. 合并查询7. 插入查询结果摘要前面我们学习了数据库设计时要满

Java内存分配与JVM参数详解(推荐)

《Java内存分配与JVM参数详解(推荐)》本文详解JVM内存结构与参数调整,涵盖堆分代、元空间、GC选择及优化策略,帮助开发者提升性能、避免内存泄漏,本文给大家介绍Java内存分配与JVM参数详解,... 目录引言JVM内存结构JVM参数概述堆内存分配年轻代与老年代调整堆内存大小调整年轻代与老年代比例元空

从入门到精通C++11 <chrono> 库特性

《从入门到精通C++11<chrono>库特性》chrono库是C++11中一个非常强大和实用的库,它为时间处理提供了丰富的功能和类型安全的接口,通过本文的介绍,我们了解了chrono库的基本概念... 目录一、引言1.1 为什么需要<chrono>库1.2<chrono>库的基本概念二、时间段(Durat