param参数服务器

声明:本文主要内容来自: MOOC 机器人操作系统入门.仅仅是为了查阅方便,做了个小结,侵权必删!

Table of Contents

零.param介绍

0.0 param有什么用

0.1参数类型

 

 二.如何使用----三种维护方式

2.1命令行维护

2.2.launch文件

 2.2.1 yaml文件

2.3node源码

 三.命名空间对param的影响


 

零.param介绍

0.0 param有什么用

机器人工作时,我们有需要对机器人的参数(如传感器参数、算法的参数)进行设置。有些参数(如机器人的轮廓、传感器的高度)在机器人启动时就设定好就行了;有些参数则需要动态改变(特别是在调试的时候)。ROS提供了参数服务器来满足这一需求。我们可以将参数设置在参数服务器,在需要用到参数的时候再从参数服务器中获取。[1]
 

0.1参数类型

ROS参数服务器为参数值使用XMLRPC数据类型, 其中包括:strings, integers, floats,booleans, lists, dictionaries, iso8601 dates, and base64-encoded data

 

 二.如何使用----三种维护方式

2.1命令行维护

2.2.launch文件

       parameter是ROS系统中运行的参数,存储在参数服务器当中.在launch文件当中通过<param>元素加载parameter;launch文件执行后,parameter就加载到ROS的参数服务器上了.

      launch文件中有很多标签, 而与参数服务器相关的标签只有两个, 一个是 <param> , 另一个是 <rosparam>rosparam可操作多个参数,以及yaml文件参数,param一次性只能指定一个参数,且是标准类型的参数。

 

  • <param>标签可用于直接设置参数,也可以从文件中读取
  • <rosparam>标签用于从yaml文件中读取并设置参数,也可以设置多个参数
  • roslaunch发现<param>和<rosparam>标签后会调用rosparam包来实现设置
<launch>
	<!--param参数配置-->
	<param name="param1" value="1" />
	<param name="param2" value="2" />
	<!--param name="table_description" command="$(find xacro)/xacro.py $(find gazebo_worlds)/objects/table.urdf.xacro" /-->

	<!--rosparam参数配置  一次设置多个参数-->
	<rosparam>   
        param3: 3
        param4: 4
        param5: 5
        </rosparam>
	<!--以上写法将参数转成YAML文件加载,注意param前面必须为空格,不能用Tab,否则YAML解析错误-->
	<!--rosparam file="$(find robot_sim_demo)/config/xbot-u_control.yaml" command="load" /-->
	<node pkg="param_demo" type="param_demo" name="param_demo" output="screen" />

	

</launch>

 2.2.1 yaml文件

这个例子在自己创建的功能包param_meter下.

  • 如下图所示在功能包下创建新的文件夹param,再在这个文件夹下创建 yaml文件param.yaml.

 

  • 编写yaml文件
parammeter_test:
    param3: 56
    param4: 58
    param5: 96
  • 在launch文件中进行修改

加入

	<rosparam file="$(find param_meter)/param/param.yaml" command="load" />

 变成

<launch>
	<!--param参数配置-->

	<param name="param1" value="1" />
	<param name="param2" value="2" />
	<!--param name="table_description" command="$(find xacro)/xacro.py $(find gazebo_worlds)/objects/table.urdf.xacro" /-->

	<!--rosparam参数配置-->
	<rosparam>   
        param3: 3
        param4: 12
        param5: 9
    </rosparam>
	<!--以上写法将参数转成YAML文件加载,注意param前面必须为空格,不能用Tab,否则YAML解析错误-->
	<rosparam file="$(find param_meter)/param/param.yaml" command="load" />
    <!--rosparam file="$(find robot_sim_demo)/config/xbot-u_control.yaml" command="load" /-->
	<node pkg="param_meter" type="param_meter" name="param_meter" output="screen" />

	

</launch>
  •  运行launch文件

得到了运行结果,param的值和自己设置的相同.

 

2.3node源码

关于param的API, roscpp为我们提供了两套, 一套是放在 ros::param namespace下, 另一套是在 ros::NodeHandle 下, 这
两套API的操作完全一样, 用哪一个取决于你的习惯。

  •     ros::param namespace
  •     ros::NodeHandle

和param相关的操作如下:

  • get param
  • set param
  • check param
  • delete param
#include<ros/ros.h>

int main(int argc, char **argv){
	ros::init(argc, argv, "param_demo");
	ros::NodeHandle nh;
	int parameter1, parameter2, parameter3, parameter4, parameter5;
	
	//Get Param的三种方法
	//① ros::param::get()获取参数“param1”的value,写入到parameter1上
	bool ifget1 = ros::param::get("param1", parameter1);
	
	//② ros::NodeHandle::getParam()获取参数,与①作用相同
	bool ifget2 = nh.getParam("param2",parameter2);
	
	//③ ros::NodeHandle::param()类似于①和②
	//但如果get不到指定的param,它可以给param指定一个默认值(如33333)
        nh.param("param3", parameter3, 33333);
	
	if(ifget1)
		ROS_INFO("Get param1 = %d", parameter1);
	else
		ROS_WARN("Didn't retrieve param1");
	if(ifget2)
		ROS_INFO("Get param2 = %d", parameter2);
	else
		ROS_WARN("Didn't retrieve param2");
	if(nh.hasParam("param3"))
		ROS_INFO("Get param3 = %d", parameter3);
	else
		ROS_WARN("Didn't retrieve param3");


    //Set Param的两种方法
	//① ros::param::set()设置参数
	parameter4 = 4;
	ros::param::set("param4", parameter4);

	//② ros::NodeHandle::setParam()设置参数
	parameter5 = 5;
	nh.setParam("param5",parameter5);
	
	ROS_INFO("Param4 is set to be %d", parameter4);
	ROS_INFO("Param5 is set to be %d", parameter5);


	//Check Param的两种方法
	//① ros::NodeHandle::hasParam()
	bool ifparam5 = nh.hasParam("param5");

	//② ros::param::has()
	bool ifparam6 = ros::param::has("param6");

	if(ifparam5) 
		ROS_INFO("Param5 exists");
	else
		ROS_INFO("Param5 doesn't exist");
	if(ifparam6) 
		ROS_INFO("Param6 exists");
	else
		ROS_INFO("Param6 doesn't exist");


	//Delete Param的两种方法
	//① ros::NodeHandle::deleteParam()
	bool ifdeleted5 = nh.deleteParam("param5");

	//② ros::param::del()
	bool ifdeleted6 = ros::param::del("param6");
	


	
}

 三.命名空间对param的影响

在实际的项目中, 实例化句柄时, 经常会看到两种不同的写法 ros::NodeHandle n;  ros::NodeHandle nh("~");` 这两种写法有什么不同呢? launch文件夹的demo.launch定义两个参数, 一个全局serial 他的数值是5,一个是局部的serial, 他的数值是10.在launch 标签内的是全局参数值, node 标签内的是局部参数其有效域是当前节点。[2]

<launch>
  <!--全局参数serial-->
  <param name="serial" value="5" />
  <node name="name_demo" pkg="name_demo" type="name_demo"
   output="screen">
    <!--局部参数serial-->
    <param name="serial" value="10" />
  </node>
</launch>


在name_demo.cpp中, 我们分别尝试了, 利用全局命名空间句柄提取全局的param和局部的param以及在局部命名空间下的句柄提取全局的param和局部的param, 详细的代码如下 :

#include <ros/ros.h>

int main(int argc, char* argv[])
{
    int serial_number = -1;//serial_number初始化
    ros::init(argc, argv, "name_demo");//node初始化
    /*创建命名空间*/
    //n 是全局命名空间
    ros::NodeHandle n;
    //nh 是局部命名空间
    ros::NodeHandle nh("~");
    /*全局命名空间下的Param*/
    ROS_INFO("global namespace");
    //提取全局命名空间下的参数serial
    n.getParam("serial", serial_number);
    ROS_INFO("global_Serial was %d", serial_number);
    //提取局部命名空间下的参数serial
    n.getParam("name_demo/serial", serial_number);//在全局命名空间下,要提取局部命名空间下的参数,需要添加node name
    ROS_INFO("global_to_local_Serial was %d", serial_number);
    /*局部命名空间下的Param*/
    ROS_INFO("local namespace");
    //提取局部命名空间下的参数serial
    nh.getParam("serial", serial_number);
    ROS_INFO("local_Serial was %d", serial_number);
    //提取全局命名空间下的参数serial
    nh.getParam("/serial", serial_number);//在局部命名空间下,要提取全局命名空间下的参数,需要添加“/”
    ROS_INFO("local_to_global_Serial was %d", serial_number);
    ros::spin();
    return 0;
}

参考:

1.https://blog.youkuaiyun.com/u014695839/article/details/78348600

2.MOOC 机器人操作系统入门

 

<think>好的,我需要帮助用户了解ROS参数服务器的使用方法和相关配置。首先,我应该回顾用户提供的引用资料,从中提取关键信息。 用户提供的引用1提到参数服务器用于动态设置和获取参数,启动ROS主节点使用roscore,设置参数用rosparam set命令。引用3说明参数服务器是全局的,支持动态调整,方便节点间共享参数。引用2和4提到了C++实操,包括增删改查参数的方法。 接下来,我需要组织这些信息,按照用户要求的格式,分步骤说明参数服务器的用法。需要包括启动主节点、设置参数、获取参数、删除参数,并给出示例代码。同时,要确保所有数学表达式用$...$,独立公式用$$...$$,但这里可能涉及代码较多,数学公式可能较少。 然后,生成相关问题,参考示例中的结构,例如询问参数服务器的工作原理、如何动态调整参数、在C++中的实现等。 需要检查LaTeX语法是否正确,使用中文回答,结构清晰。最后,确认引用的标注是否正确,每个引用来源的末尾加上对应的标识符,如[^1]、[^2]等。</think>### ROS参数服务器使用说明 #### 1. 参数服务器概述 ROS参数服务器是一个集中存储和管理全局配置参数的组件,支持动态增删改查操作,适用于节点间共享配置(如传感器阈值、控制参数等)[^3]。 #### 2. 基本配置步骤 **步骤1:启动ROS主节点** ```bash $ roscore ``` **步骤2:设置参数** 通过命令行设置参数: ```bash $ rosparam set /my_param_name 42 # 设置整型参数[^1] $ rosparam set /robot_speed 0.5 # 设置浮点型参数 ``` **步骤3:获取参数** ```bash $ rosparam get /my_param_name # 输出:42[^1] ``` **步骤4:删除参数** ```bash $ rosparam delete /my_param_name # 删除指定参数[^4] ``` #### 3. C++节点操作示例 **新增/修改参数** ```cpp #include <ros/ros.h> int main(int argc, char **argv) { ros::init(argc, argv, "param_demo"); ros::NodeHandle nh; // 设置参数 nh.setParam("/control_gain", 1.2); // 浮点型参数 } ``` **获取参数** ```cpp double gain; if (nh.getParam("/control_gain", gain)) { ROS_INFO("Gain value: %.2f", gain); // 输出:1.20 } ``` **删除参数** ```cpp nh.deleteParam("/control_gain"); // 删除参数[^4] ``` #### 4. 动态调整参数示例 通过`ros::param::set`实现运行时动态修改: ```cpp ros::param::set("/sensor_threshold", 75); // 更新传感器阈值 ``` #### 5. YAML文件批量加载 将参数存储在YAML文件中并批量导入: ```bash $ rosparam load config.yaml # 加载文件中的所有参数 ``` 示例`config.yaml`内容: ```yaml camera_fps: 30 max_velocity: 2.0 ``` ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值