版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、基于有限状态机的工控系统软件设计 (1)2008-07-11 11:20:25 来源:互联网 浏览次数:27 · 通过分析工控系统的特性,提出采用状态机的思想进行工控软件设计。详细论述了高速状态机的错步问题以及控制层中状态机的状态划分问题。结合具体的应用实例,给出了基于状态机的实现方法。实验表明,采用状态机的设计方法有助于准确描述受控对象的行为,软件的健壮性和可靠性得到显著提高。 关键字:有限状态机 工控软件 控制环 状态划分 1. 引言1.1 工控软件的一般问题工控软件设计可分为基于控制环和基于
2、实时操作系统两大类。控制环是把各个功能模块连接成首尾相接的环状结构。其特点为任何一个功能模块都不能出现死循环,甚至循环次数太多的循环语句都应避免出现。以保证能够在实时意义上尽可能快地遍历各功能模块,从而满足实时多任务的需求。在各功能模块中一般用状态机来描述模块所处的状态。而实时操作系统则可以通过一套底层机制根据优先级和各任务状态调度各功能模块。此时各功能模块就以“任务”作为表现形式。但是在每个任务内部仍然为一个独立的控制环结构,仍然需要用状态机描述。本文将结合工程实践论述状态机在工控中的应用,给出通用模型和注意要点。1.2 有限状态机有限状态机是一种重要的思想方法。从数学的角度看,它
3、实际是一个五元组M = (I, O, S, , ),其中I,O分别表示输入输出,S为状态向量,为次态方程(: S×I ->S), 表示输出方程(: S×I -> O)。有限状态机从结构体系上有层级状态机,并发状态机等。层级状态机类似于软件中的子程序调度:更高层的一个状态对应于较低层的一个状态机。这个高层的状态处于底层状态机的某个状态中。这个低层状态称为子状态。与子程序调用受到系统堆栈深度制约不一样,层级状态机可以由开发者根据控制对象的层次性运动
4、规律任意指定深度。与子程序的目的一样,层级状态机也是为了提高控制软件的模块化程度,降低状态分析的复杂度。并发状态机偏重于描述状态机的调度。状态机本身不能实现什么并发功能,并发的实现是通过软件调度的。如果把状态机理解成一个任务,那么就能理解并发的实现。在控制环中,一个“任务”就是一个功能模块,我们只需要把多个状态机串联在环中,也就是实现了多输入多输出的并发控制。此时,多个状态机在空间上是并存的,然而却是分时调用的,调用的周期等同于控制环扫描一周的时间。不过如果CPU运算速度足够快,这个周期将会足够的快,达到“实时”的程度,从而这多个状态机也就实现了“并发”运行。同理,在多任务操作系统中,“并发”
5、的实现就更容易理解了,除了在单个任务内存在控制环的并发控制外,在任务之间也同样存在多状态机的并发运行。当然,从CPU的角度而言,只要是单核的,也就从来不存在真正的“并发”,它在任何一个特定的时间点都只能处理某个特定状态机。不过多任务操作系统却提供了一套底层机制来调度原来仅靠控制环来调度的任务。2.有限状态机在前后台信息交互中的作用工控系统一般都具有人机对话界面。其通常的操作模式为用户进入某个页面,选取某项操作并执行。人机对话界面通常被设定为一个独立模块。该模块软件结构为一个消息控制环。用户在硬件接口的操作会通过接口的驱动程序封装成消息加入到专属界面模块的消息队列中。消息控制环循环扫描该队列,如
6、有新消息则提取并解释然后封装成新消息发往后台执行。前后台软件的接口模块负责分发界面消息到各个执行模块。消息应包括目标模块的编码,命令编码以及命令参数。前后台接口模块的软件结构多采用以下两种模式。图1 两种消息分发结构模式一的输出结构根据消息数据的目标模块编码直接分发消息到各模块中。模式二则是根据当前系统所处的状态再分发消息到各模块中。也就是说模式二在模式一的基础上增加了一个系统级的状态机。下面我们看看两种不同的输出结构会带来何种影响。工控软件设计者通常会碰到两种情况。一是在研发阶段,界面任务与控制任务联调时,双方均有可能出错。对于界面任务而言,有可能自身原因误发消息;而对控制任务,也
7、有可能输出时序出错。此时需要在联调中快速定位故障,缩短研发周期。二是在产品运行中由于恶劣工况的影响,导致缓冲区数据发生异常。比如消息头的模块编码发生位翻转,则会直接导致控制任务接收到错误的界面消息。对于模式一,如果界面消息出错则会出现全局的混乱。比如模块1收到消息后开始输出一个控制时序,期间界面层又发来一个错误的消息,使其分发到模块2,于是模块2马上开始输出时序。这个不希望输出的时序在工控中有可能会导致灾难。而在联调时出现这种现象,则无法立刻判断到底是模块1还是界面层出的问题。但如果采用模式二则可以屏蔽这种混乱。如下图图2 不同分发结构对错误消息的处理示意图我们可以看到由于模式二采用
8、全局状态机标定当前软件所处的状态,消息首先会到达相应的状态处理程序,然后才进行分发。此时分发语句可以根据当前的状态屏蔽不应该被调用的模块。即使消息出现错误,也会过滤掉,等待正确消息的到来。而且可进一步优化为当收到错误消息可以通知界面层。可见在控制软件前后台的接口层增加一个标记后台状态的全局状态机有助于增强软件的健壮性。3.状态机的错步问题工控软件本质上是根据一定的逻辑条件给出有序的输出。根据输出的次序可以划分不同的状态。逻辑条件在嵌入式领域中就是用户的输入和传感器的状态。正是这些条件决定了状态的跃迁。在这里我们探讨的是根据传感器输入而建立的状态机。很明显,它的运行速度比前述系统级状态机高很多。
9、这种状态机分布在软件的控制层中,正是它们使得受控对象能够有序精确高速的运行。对于这样高速运转的状态机,如果考虑不周全,会使其产生失步或者跳步,即高速状态机中的错步现象。由于控制层的状态机的跃迁条件来源于传感器信号,如果不能完全跟踪到传感器信号的变化,则跃迁条件将被遗漏,导致状态机不能跃迁到新的状态。这就会导致失步。有两种情况会导致传感器信号的检测遗漏:一是采样频率不够高,漏掉了一些保持时间较短的信号。这可以通过硬件上提高采样频率得到解决。二是状态机设计的缺陷,详见以下例子。图3 出现失步的状态机由图3可以看出,状态1根据传感器a信号跃迁到状态2,状态2根据传感器b信号跃迁到状态3。如
10、果b信号在a信号前发出了一个完整的脉冲,由于根据状态图在状态1时并不需要检测b信号,因此当跃迁到状态2以后,状态机就出现失步了。解决这个问题需要预先分析好a,b信号的关系。如果是b信号一定出现在a信号前,那不妨把状态1和2的条件判断对调,如果两个信号是并发关系的,那就要合并状态机1,2,把a,b信号作为跃迁到3的综合条件。因此解决失步问题的要点在于仔细考察受控对象处于此状态时所可能出现的传感器信号变化及其变化关系。在处理“输入-输出对”时要注意防止状态机跳步。“输入-输出对”是嵌入式领域中经常遇到的控制模式,类似于应答机制。控制层给出一个输出,使得传感器信号产生变化并反馈,过一段时间后,控制对
11、象运动完成,传感器信号恢复初态,此时控制层可以撤消原输出并给出相关处理。设计者会有意无意的把注意力放在“什么时候撤消输出”,因此设计出如图4(a)所示的有潜在问题的状态机。图4 出现跳步的状态图可是控制对象在收到控制层输出的驱动产生运动,传感器感知运动并给出信号变化是需要时间的。根据图4(a)的状态机,很可能跳过传感器信号变化的状态,而直接到达“撤消输出”的状态。结果导致控制层的输出仅仅是一瞬而过甚至是无法输出,这就是跳步。为解决跳步问题,就需要设计者仔细分析所有的“输入-输出对”,把状态细分。如图4(b)所示,增加一个等待对象运动的新状态,确保上一状态的输出驱使对象真正运动以后才判
12、断对象运动停止。然而在细分状态的同时也要注意防止失步。状态分得越细,越要注意分析此状态中所有可能出现的信号变化· 通过分析工控系统的特性,提出采用状态机的思想进行工控软件设计。详细论述了高速状态机的错步问题以及控制层中状态机的状态划分问题。结合具体的应用实例,给出了基于状态机的实现方法。实验表明,采用状态机的设计方法有助于准确描述受控对象的行为,软件的健壮性和可靠性得到显著提高。 关键字:有限状态机 工控软件 控制环 状态划分 4.状态机在工控软件中的状态划分问题把一个状态机看作是一个动作模块,并把这些模块串联起来,就可以实现这几个动作的并发输出。如果是基于操作系统的,状态机还可以放
13、在不同的任务中,也可以实现并发输出。每个状态机设定一个空闲状态,当不需要其运转时让其进入该状态。同一个控制环的状态机之间的通信可以用标志位或者状态变量,不同任务的状态机可以通过一个全局的结构体交互信息,实现同步。状态机的调度并不困难,关键在于如何根据受控对象的运动规律来划分状态机动作模块。在实际应用中,“周期性”是解决问题的关键。从复杂的运动时序中归纳出带有“往复运动”性质的输出,连同与其同步的其他输入输出归入一个状态机中。这样每个具有“往复运动”性质的运动模态都建立一个状态机。同时,可以运用上文介绍的方法实现这几个运动模态的并发和同步控制。下面通过某型进油系统来说明如何划分状态机。某型进油系
14、统分左右两路。每路由一油链,摆臂,拨动滑板组成。油链上装载多个装油模块。摆臂把模块提升到滑板,并由滑板推进到燃烧舱中,然后油链步进一次。全过程双路交替供油。供油分为低速供油和高速供油。时序如下图,黑色横线代表动作持续时间。图5供油系统低速供油时序图图6 供油系统高速供油时序图先分析低速供油的情况。可以看出油槽下降-油门关-油槽上升-油门开-滑板(左或右)这几个动作是交替出现,在滑板动作完成以后,油槽又开始新一轮的动作。由于这种周期性,可以把这几个动作归入状态机A中。而油链动作是由滑板动作触发的,当滑板运动到一定位置时候油链会启动,油链的运动会持续到下一次同侧运动开始后。如果把油链运动也归入状态机A中,就打破了A的周期性,从而增加了A的状态确定复杂化。另外从运动的本质上来说,油链运动被状态机A中的滑板运动所激发,因而把油链运动定义在另一个状态机B更为合理。B是在A运动到某个状态时所触发的,触发后,B和A就是并发运行的状态机。高速供油与低速时序的区别在于在左路状态机A的周期没有完成的情况下,右路的状态机A已经开始了。但是尽管如此,对于单路而言,油槽下降-油门关-油槽上升-油门开-滑板(左或右)仍然呈现周期性。所以应该为左右两路各建立一个状态机A,也就是A1和A2。A1和A2的状态机代码是一样的,当判断油槽重新上升后马上触发相对一侧的状态机。同理对于油链
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025车贷年终总结参考6篇
- 生物活性成分筛选-第1篇-洞察与解读
- 2025年下半年下半年四川乐山夹江县招考事业人员拟聘用人员易考易错模拟试题(共500题)试卷后附参考答案
- 2025山西省晋中市太谷县政府专职消防员招聘10人易考易错模拟试题(共500题)试卷后附参考答案
- 2025山西太钢招聘操作岗位人员100人易考易错模拟试题(共500题)试卷后附参考答案
- 2025山东省盐业集团菏泽限公司招聘6人易考易错模拟试题(共500题)试卷后附参考答案
- 2025山东滨州市无棣县医疗卫生机构招聘易考易错模拟试题(共500题)试卷后附参考答案
- 2025山东德州市光明电力服务限责任公司招聘21人易考易错模拟试题(共500题)试卷后附参考答案
- 2025宣城公路工程试验检测中心招考45人易考易错模拟试题(共500题)试卷后附参考答案
- 2025大冶市中小企业融资担保限责任公司面向社会公开招聘工作人员【6人】易考易错模拟试题(共500题)试卷后附参考答案
- 甲状腺亢进课件
- 2025年海南高考历史卷试题真题及答案详解(精校打印版)
- 统编版语文二年级上册 18古诗二首 敕勒歌 课件
- 2025年沈抚示范区工会面向社会公开招聘工会社会工作者20人笔试考试参考题库及答案解析
- 商铺顶账买卖合同范本
- 2025年一级造价师交通案例分析真题及答案
- 髂筋膜间隙阻滞技术中国专家共识(2025版)解读 2
- 戒毒人员康复训练
- 纳米银抗菌涂层应用-洞察与解读
- 2025云南昆明巫家坝建设发展有限责任公司及下属公司第四季度社会招聘31人考试参考题库及答案解析
- 《公路工程施工安全检查表》
评论
0/150
提交评论