- 其他ROS1学习笔记: ROS1学习笔记
- 代码仓库:Github连接地址
- 欢迎各位互相学习交流
参数服务器的数据被重新配置后时,如果节点不重新访问,那么就不能获取配置后的数据,针对这一特殊场景,ROS提出了动态重配参数(dynamic reconfigure),即参数一旦修改,能够使得节点读取修改后的数据,比如:在某些GUI界面中,可以向节点查询一组可重新配置的参数,包括它们的名称、类型和范围,并向用户呈现定制的效果。
根据官网提供的教程:
(一)创建功能包和ROS文件夹:
myDyCfg.cfg
#!/usr/bin/env python
# -*- coding: utf-8 -*-# catkin_ws/src/dy_reconfigure/cfg/myDyCfg.cfg
# 指定功能包的位置
PACKAGE = "dy_reconfigure"# 导入包
from dynamic_reconfigure.parameter_generator_catkin import *# 2.创建动态重配参数生成器
gen = ParameterGenerator()# 使用方法add(name, type, level, description, default=None, min=None, max=None, edit_method="")
# name:一个字符串,用于指定应存储此参数的名称
# type:定义存储的值的类型,可以是int_t、double_t、str_t或bool_t中的任何一个
# level:A bitmask which will later be passed to the dynamic reconfigure callback.
# description:描述参数的字符串
# default:指定默认值
# min:指定最小值(可选,不适用于字符串和布尔值)
# max:指定最大值(可选,不适用于字符串和布尔值)gen.add("myint", int_t, 0, "整形式托拉条", 50, 0, 100)# 创建枚举类型,在rqt-gui实现下拉操作
myListobj = gen.enum([ gen.const("Small", int_t, 0, "A small constant"),gen.const("Medium", int_t, 1, "A medium constant"),gen.const("Large", int_t, 2, "A large constant"),gen.const("ExtraLarge", int_t, 3, "An extra large constant")],"An enum to set size")gen.add("mylist", int_t, 0, "下拉式列表", 1, 0, 3, edit_method=myListobj)# exit(gen.generate("功能包名", "节点名", "cfg文件名"))
exit(gen.generate(PACKAGE, "mydycfg_node", "myDyCfg"))
(三)配置动态重配参数文件.cfg文件:
配置cfg文件主要包括给予cfg文件可执行权限,并且只需要在CMakeList.txt
进行依赖项添加
赋予cfg文件可执行权限,在功能包的cfg文件夹下,执行命令sudo chmod +x *.cfg
即可。
打开功能包的CMakeList.txt文件,主要修改两项
find_package(catkin REQUIRED COMPONENTS ..+ 依赖项功能包)
,大约在第10行,添加dynamic_reconfigure
:# catkin_ws/src/dy_reconfigure/CMakeLists.txt
find_package(catkin REQUIRED COMPONENTSroscpprospystd_msgsdynamic_reconfigure
)
generate_dynamic_reconfigure_options (cfg/文件名)
,大约在第92行,如此时的文件名为myDyCfg.cfg
:# catkin_ws/src/dy_reconfigure/CMakeLists.txt
generate_dynamic_reconfigure_options(cfg/myDyCfg.cfg
)
(四)编译cfg文件,查看中间文件:
/home/ubuntu/catkin_ws/devel/include/功能包名/文件夹
下,/home/ubuntu/catkin_ws/devel/lib/python2.7/dist-packages/功能包名cfg
(五)编译C++代码作为服务端:
dyconfig_cpp.cpp
。// catkin_ws/src/dy_reconfigure/src/dyconfig_cpp.cpp
#include
#include
#include void callback(dy_reconfigure::myDyCfgConfig &config, uint32_t level) {ROS_INFO("终端打印输出,整型数值是 %d,下拉条层级是 %d",config.myint,config.mylist);
}int main(int argc, char **argv) {setlocale(LC_ALL,"");ros::init(argc, argv, "dy_configure");dynamic_reconfigure::Server server;dynamic_reconfigure::Server::CallbackType f;f = boost::bind(&callback, _1, _2);server.setCallback(f);ros::spin();return 0;
}
# catkin_ws/src/dy_reconfigure/CMakeLists.txt
add_executable(dyconfig_cpp_node src/dyconfig_cpp.cpp)add_dependencies(dyconfig_cpp_node ${${PROJECT_NAME}_EXPORTED_TARGETS} ${catkin_EXPORTED_TARGETS})target_link_libraries(dyconfig_cpp_node ${catkin_LIBRARIES})
rosrun dy_reconfigure dyconfig_cpp_node
,启动rqt工具实现动态重调参数rosrun rqt_gui rqt_gui -s rqt_reconfigure
(六)编译Python代码作为服务端:
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# catkin_ws/src/dy_reconfigure/scripts/dyconfig_py.pyimport rospy
from dynamic_reconfigure.server import Server
from dy_reconfigure.cfg import myDyCfgConfigdef callback(config, level):rospy.loginfo("终端打印输出,整型数值是 %d,下拉条层级是 %d",config.myint,config.mylist)return configif __name__ == "__main__":rospy.init_node("dynamic_myDyCfg", anonymous = False)srv = Server(myDyCfgConfig, callback)rospy.spin()
sudo chmod +x *.py
即可赋予所有Python可执行权限。查考文献:
launch文件能够在ROS中一次启动多个节点。下面主要介绍launch文件的常用启动参数和作用。
从上面的定义规则可以看出,在启动文件中启动一个节点至少需要三个属性关键字: pkg
、type
和name
。
pkg
定义节点所在的功能包名称;type
定义节点的可执行文件名称,这两个属性等同于在终端中使用rosrun命令执行节点时的输入参数;name
属性用来定义节点运行的名称,将覆盖编程节点文件中init()赋予节点的名称。output = "log/screen"
:将节点的标准输出打印到终端屏幕;respawn = "true/false"
:复位属性,该节点停止运行,则会自动重启,默认为false;required = "true/false"
:必要节点,当该节点终止时,launch文件中的其他节点也被终止;ns = "namespace"
:命名空间,为节点内的相对名称添加命名空间前缀。args = "arguments"
:节点需要的输入参数。node存在子集标签:
env
环境变量设置,remap
重映射节点名称,param
参数设置和rosparam
参数设置,下面对其依次介绍。
其中from="原始话题名称" to "目标名称"
在 launch文件中通过元素加载
parameter
,launch文件执行后,parameter就加载到ROS的参数服务器上了。每个活跃的节点都可以通过ros::param:get()
接口来获取parameter的值,用户也可以在终端中通过rosparam
命令获得parameter的值。的使用方法如下:
parameter的参数主要入下:
name="命名空间/参数名"
,参数名称,可以包含命名空间value="xxx" (可选)
,定义参数值,如果此处省略,必须指定外部文件作为参数源type="int" (可选)
,指定参数类型,如果未指定,roslaunch会尝试自动确定参数类型。
)加载方式帮助我们将一个YAML格式文件中的参数全部加载到ROS参数服务器中,需要设置command属性为“load”
,还可以选择设置命名空间“ns”
,如下所示:
argument
是另外一个概念,类似于launch 文件内部的局部变量,仅限于launch文件使用,便于launch文件的重构,与ROS节点内部的实现没有关系。设置argument使用
标签元素,语法如下:
其中包括的参数有(rgument标签不存在子集标签):
name="参数名称"
default="默认值" (可选)
value="数值" (可选)
,不可以与 default 并存doc="描述"
。launch文件中需要使用到argument
时,可以使用如下方式调用:
其中属性包括:
file="$(find 包名)/xxx/xxx.launch"
,要包含的文件路径ns="xxx" (可选)
,在指定命名空间导入文件其中包含的子集标签有env环境变量和arg 将参数传递给被包含的文件。
上一篇:如何做好项目缺陷管理