赞
踩
1 nodelet简介
使用ROS中nodelet包可以实现在同一个进程内同时运行多种算法,且算法之间通信开销零拷贝。这个包有2个重要的class:1)提供了实现nodelet插件所必须的基类nodelet::Nodelet; 2)提供了NodeletLoader类用以实例化nodelet插件。由于nodelets实现了零拷贝,所以常常应用于大数据吞吐量场景,避免了多node通过ROSTCP通信带来的延时问题。
nodelets动态加载nodelet插件类到同一个node中实现了零拷贝, 加入进来的各个nodelet虽然在同一个进程内,但是由于nodelet拥有自己的命名空间,所以看似是一个个独立的node在存在。
2 nodelet技术原理
1)nodelet包定义了一个基类nodelet::Nodelet,所有的nodelet插件类会继承这个基类,并通过pluginlib实现nodelet插件的动态加载;
2)存在一个nodelet_manager进程,可以把nodelet到加载到该manager内进行管理;
3)任何nodelet之间的通信可以使用零拷贝的roscpp publish完成,这种零拷贝实质上是使用了boost shared_ptr;
2 应用
2.1 基本命令
这里将简单运行ROS中的一个tutorial(nodelet_tutorial_math),需要提前安装。
1)启动nodelet manager
一般nodelet manager是用C++实现的一段程序,用以监听ROS service,nodelet可以动态加载进来运行。本例子将运行一个standalone manager,但通常manager是被嵌入到node中使用的。
2)启动nodelet
3)简单测试
方式一: 命令行测试
一个终端运行:
rosnode list
/nodelet1
/nodelet_manager
/rosout
rostopic echo /nodelet1/out
data: 6.1
---
data: 6.1
---
data: 6.1
---
rosrun rqt_graph rqt_graph
方式二:启动文件测试
rosrun rqt_graph rqt_graph
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。