SMACH专题(四)----状态State类的实现和中文注释
SMACH中,状态(State)是状态机器组成的重要部分,理解State的原理和实现,对使用SMACH很有帮助,特别是理解
__init__(),execute(),preempt是尤为关键。
__init__():初始化函数,状态初始化时,进行参数的初始化
execute():状态运行时执行的函数
preempt:暂停状态
详细的说明请参考例子:The principle of Passing User Data between States
下面对State类进行解释注释,代码如下:
import threading
import traceback import smach __all__ = ['State','CBState'] class State(object):
"""SMACH的状态基类 SMACH状态和SMACH容器交互的方式有两种。第一种是它的输出标识符outcome。
第二种是运行(execute)时,用来读入和输出打用户数据(userdata)。在execute()
调用前,需要在构造函数(__init__())中声明outcome和userdata并做相应的校验。
"""
def __init__(self, outcomes=[], input_keys=[], output_keys=[], io_keys=[]):
"""状态构造函数
@type outcomes:字符串数组
@param outcomes: 为此状态定义输出(outcomes). @type input_keys: 字符串数组
@param input_keys: 在运行时,从外部输入的用户数据keys. @type output_keys: 字符串数组
@param output_keys: 在运行时,从外部输出的用户数据keys. @type io_keys: 字符串数组
@param io_keys: 在运行时,从外部输入/输出的用户数据keys.
"""
# 存储输出结果(outcomes)
self._outcomes = set(outcomes) # 存储用户数据接口的描述
self._input_keys = set(input_keys + io_keys)
self._output_keys = set(output_keys + io_keys) # 声明暂停的标识符
self._preempt_requested = False ### Meat
def execute(self, ud):
"""Called when executing a state.当执行状态时调用
在基类中该函数会抛出异常NotImplementedError. @type ud: 用户数据结构体
@param ud: 状态在执行时,传递的用户数据
"""
raise NotImplementedError() ### SMACH 接口 API
def register_outcomes(self, new_outcomes):
"""向结果集中添加结果标签."""
self._outcomes = self._outcomes.union(new_outcomes) def get_registered_outcomes(self):
"""获取已经注册打结果集.
@rtype: 字符串数组
@return: 已经注册打结果字符串的数组.
"""
return tuple(self._outcomes) ### 用户数据API
def register_io_keys(self, keys):
"""向io_keys集合中添加keys.
@type keys: 字符串数组
@param keys: 输入输出的keys.
"""
self._input_keys = self._input_keys.union(keys)
self._output_keys = self._output_keys.union(keys) def register_input_keys(self, keys):
"""向input_keys集合中添加keys.
@type keys: 字符串列表
@param keys: 输入的keys.
"""
self._input_keys = self._input_keys.union(keys) def get_registered_input_keys(self):
"""获得已经注册的input_keys数组."""
return tuple(self._input_keys) def register_output_keys(self, keys):
"""向output_keys集合中添加keys.
@type keys: 字符串列表
@param keys: 输出的keys.
"""
self._output_keys = self._output_keys.union(keys) def get_registered_output_keys(self):
"""获得已经注册打output keys的数组."""
return tuple(self._output_keys) ### 暂停的接口
def request_preempt(self):
"""设置暂停请求preempt_requested为True,状态机暂停的时候,就需要设置该状态为False,运行时
需要设置为True才行,否则运行到该状态就会停止了。
"""
self._preempt_requested = True def service_preempt(self):
"""设置暂停请求preempt_requested为False"""
self._preempt_requested = False def recall_preempt(self):
"""设置暂停请求preempt_requested为False"""
self._preempt_requested = False def preempt_requested(self):
"""如果暂停则返回True."""
return self._preempt_requested class CBState(State):
def __init__(self, cb, cb_args=[], cb_kwargs={}, outcomes=[], input_keys=[], output_keys=[], io_keys=[]):
"""从一个函数中创建一个状态. @type outcomes: 字符串数组
@param outcomes: 为该状态定义的outcomes. @type input_keys: 字符串数组
@param input_keys: 在运行时,从外部输入的用户数据keys. @type output_keys: 字符串数组
@param output_keys: 在运行时,从外部输出的用户数据keys. @type io_keys: 字符串数组
@param io_keys: 在运行时,从外部输入/输出的用户数据keys.
"""
State.__init__(self, outcomes, input_keys, output_keys, io_keys)
self._cb = cb
self._cb_args = cb_args
self._cb_kwargs = cb_kwargs if smach.util.has_smach_interface(cb):
self._cb_input_keys = cb.get_registered_input_keys()
self._cb_output_keys = cb.get_registered_output_keys()
self._cb_outcomes = cb.get_registered_outcomes() self.register_input_keys(self._cb_input_keys)
self.register_output_keys(self._cb_output_keys)
self.register_outcomes(self._cb_outcomes) def execute(self, ud):
return self._cb(ud, *self._cb_args, **self._cb_kwargs)
SMACH专题(四)----状态State类的实现和中文注释的更多相关文章
- Html飞机大战(四):状态的切换(界面加载类的编辑)
好家伙,接着写 既然我们涉及到状态了,那么我们也会涉及到状态的切换 那么我们怎样切换状态呢? 想象一下,如果我玩的游戏暂停了,那么我们肯定是通过点击或者按下某个按键来让游戏继续 这里我们选 ...
- a链接四种伪类状态切换实现人机交互
常见的color, font-family, background 等css属性都能够设置链接的样式,a链接的特殊性在于能够根据它们所处的状态来设置它们的样式.a标签与人交互的4个状态属于伪类状态切换 ...
- 状态(State)模式
状态模式,又称状态对象模式(Pattern of Objects for States),状态模式是对象的行为模式.状态模式允许一个对象在其内部状态改变的时候改变其行为.这个对象看上去就像是改变了它的 ...
- SMACH专题(一)----安装与初探
最近使用ROS进行任务(Task)执行,深切体会用传统的方法实现是极其繁杂的.比如人脸录入工作,包含人脸检测,识别,语音提示,运动控制,这些子部分基本都是通过订阅话题的回调函数中处理,之间的切换,如人 ...
- <a>链接的四个伪类顺序
<a>元素的作用是可以创建一个链接,链接对应4个状态:未访问,已访问,鼠标悬停,鼠标点击瞬间. 为了给链接的4个状态应用样式,引入伪类的概念. 什么是伪类呢?简单点说,就是你没定义这个类, ...
- css 为元素选择器,css目标状态伪类,结构化选择器,多媒体选择器,清除表默认样式、属性选择器
伪元素选择器 :before 和 :after 添加的位置 :before --- 第一个子节点 :after --- 最后一个子节点 特点 1.默认是 inline 元素 2.必须包含 conten ...
- React-本地状态(state)
在类组件中添加本地状态(state): 1.创建一个继承自 React.Component 类的 ES6 class 同名类: 2.添加一个 类构造函数(class constructor) 初始化 ...
- SMACH专题(二)----Concurrent状态机
Concurrent状态机是一种同时执行多个状态的状态机.如下图所示.状态FOO和BAR同时执行,当两个状态输出的结果同时满足一个组合条件时(FOO输出outcome2,BAR输出outcome1)才 ...
- Java 实现状态(State)模式
/** * @author stone */ public class WindowState { private String stateValue; public WindowState(Stri ...
随机推荐
- re-sign重签名
准备: ① re-sign.jar重签名工具:(下载地址为:http://troido.de/downloads/category/1): ② 从D:\Android\sdk\build-tools\ ...
- WCF - Autofac IOC
/// <summary> /// IOC实例提供者,基于AutoFac /// /// </summary> public class IocInstanceProvider ...
- MFC的定时函数 SetTimer和结束killTimer
什么时候我们需要用到SetTimer函数呢?当你需要每个一段时间执行一件事的的时候就需要使用SetTimer函数了. 使用定时器的方法比较简单,通常告诉WINDOWS一个时间间隔,然后WINDOWS以 ...
- arp命令 清arp表
平常删除arp都用arp-d.大量存在的时候 arp -n|awk '/^[1-9]/ {print arp -d $1}' | sh 清除所有arp表,以前用这个来清arp表貌会清空,没注意到存在i ...
- elasticsearch5.5-head
修改 elasticsearch/config/elasticsearch.yml 添加 http.cors.enabled: true http.cors.allow-origin: "* ...
- TObjectList
AOwnsObjects = true 就是 objectlist释放的时候,里面的对象一并释放. TObjectList对象的创建方法有一个参数:constructor TObjectList.C ...
- sql中多层循环示例(有游标)
在需求处理中,我们会遇到需要通过SQL多层循环来处理的问题.如:A表中有8条数据,B表中有10条数据,需要实现A表中的每1条数据对应B表中的10条数据,最后就有了80条数据,从而实现一对多的关系.那如 ...
- pip常用命令总结(转载)
基本的命令解释,如下图: 列出已安装的包 pip freeze or pip list 导出requirements.txt pip freeze > <目录>/requiremen ...
- #NodeJS 服务器基本模板
基本server配置 cookie / session / get数据 / post数据 / 请求方法 const express=require('express'); const static=r ...
- day7 面向对象class()学习
面向过程 VS 面向对象 编程范式 编程是程序员用特定的语法+数据结构+算法组成的代码来告诉计算机如何执行任务的过程,一个程序是程序员为了得到一个任务结果而编写的一组指令的集合,正所谓 ...