标签:name arch hand 消息发布 over 独立 har 使用方法 cti
1.介绍
nodelet包可以为在相同进程中的多个算法之间实现零拷贝的传输方式。
这个包也提供了实现一个nodelet所需的nodelet基类以及用于实例化nodelet的NodeletLoader类。
Source: git https://github.com/ros/nodelet_core.git (branch: indigo-devel)
Nodelets旨在提供一种在单机器单进程运行多个算法而不会在进程中传递消息时产生复制成本的方法。
roscpp具有在同一节点内的发布和订阅调用之间进行零拷贝指针传递的优化。
为了做到这一点,nodelet允许将类动态加载到同一个节点,然而它们提供了简单的单独命名空间,使得尽管nodelet在同一个进程中,它仍然像一个独立的节点
这进一步扩展了,它在运行时使用pluginlib是动态可加载的。
2.应用
高吞吐量的数据流可以由许多节点组成,然后加载到同一进程,以避免复制和网络流量。
3.设计目标
4.技术
5.基本用法
nodelet usage: nodelet load pkg/Type manager - Launch a nodelet of type pkg/Type on manager manager nodelet standalone pkg/Type - Launch a nodelet of type pkg/Type in a standalone node nodelet unload name manager - Unload a nodelet a nodelet by name from manager nodelet manager - Launch a nodelet manager node
API
对于命令行和启动文件示例,请参阅本教程运行节点
6.
1)Nodelet基类
参考API
公共方法://动态加载时使用的默认构造函数
Nodelet()
//这个方法是一个描述nodelet如何启动。
//参数是管理器启动本节点所需的参数。这将初始化nodelet基类,然后调用子类的onInit()方法。
void init (const std::string& name, const ros::M_string& remapping_args, const std::vector<std::string>& my_argv);
子类中使用的受保护成员和方法:
std::string getName() //Get the name of the nodelet
ros::NodeHandle& getNodeHandle () // Get the node handle (provides this nodelets custom remappings and name)
ros::NodeHandle& getPrivateNodeHandle () // Get the private node handle (provides this nodelets custom remappings in its private namespace)
ros::NodeHandle& getMTNodeHandle () // Get the node handle with the Multi Threaded callback queue. (provides this nodelets custom remappings and name)
ros::NodeHandle& getMTPrivateNodeHandle () // Get the private node handle with the Multi Threaded callback queue. (provides this nodelets custom remappings in its private namespace)
ros::CallbackQueue& getMTCallbackQueue () // Get the callback queue (threadpool available from the manager)
std::vector<std::string> getMyArgv() // Get command line arguments to the nodelet stripped of ROS and nodelet specific args.
用于在子类中启动ROS API的初始化方法:
virtual void onInit () = 0 //Virtual and must be overridden by subclass. All initialization of the ROS infrastructure must be put into this function.
7.NODELET ROSCONSOLE宏
示例代码
#include "nodelet/nodelet.h"
//... inside a nodelet method
NODELET_DEBUG("My debug statement")
NODELET_DEBUG_STREAM("my debug statement " << (double) 1.0)
NODELET_DEBUG_COND( 1 == 1, "my debug_statement")
NODELET_DEBUG_STREAM_COND( 1 == 1, "my debug statement " << (double) 1.0)
8.
从Nodelet发布
9.线程模型
1)onInit,这个方法在init上调用,不应该阻塞或做重要的工作。
2)Single Threaded API单线程API,使用方法getNodeHandle()和getPrivateNodeHandle()将保证所有回调都并行到达。
3)Multi Threaded API多线程API,使用方法getMTNodeHandle()和getMTPrivateNodeHandle()回调将分布在管理器线程池。
4)Additional Threads其他线程,它是节点创建自己的线程进行操作的有效操作。这些线程应该在析构函数中正确清理。
5)Thread Sharing线程共享,所有nodelet共享管理器的线程池。如果nodelet阻塞线程,它们可能会阻止其他nodelet获得回调。确保管理器配置了足够的线程以防止阻塞。
注意:即使单个线程的节点句柄也可以每个节点使用池的1个线程。
标签:name arch hand 消息发布 over 独立 har 使用方法 cti
原文地址:http://www.cnblogs.com/gary-guo/p/7049684.html