有限状态机及其扩展课件.ppt
- 【下载声明】
1. 本站全部试题类文档,若标题没写含答案,则无答案;标题注明含答案的文档,主观题也可能无答案。请谨慎下单,一旦售出,不予退换。
2. 本站全部PPT文档均不含视频和音频,PPT中出现的音频或视频标识(或文字)仅表示流程,实际无音频或视频文件。请谨慎下单,一旦售出,不予退换。
3. 本页资料《有限状态机及其扩展课件.ppt》由用户(ziliao2023)主动上传,其收益全归该用户。163文库仅提供信息存储空间,仅对该用户上传内容的表现方式做保护处理,对上传内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(点击联系客服),我们立即给予删除!
4. 请根据预览情况,自愿下载本文。本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
5. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007及以上版本和PDF阅读器,压缩文件请下载最新的WinRAR软件解压。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 有限状态机 及其 扩展 课件
- 资源描述:
-
1、1Chapter 2 有限状态机及其扩展有限状态机及其扩展 o有限状态机有限状态机 n 有限状态机是有限计算的基本模型,也是许多形式化规格、验证方法的基础模型。o Statecharts n Statecharts是通过定义递阶状态、状态的AND或OR分解等高级特性的有限状态机的一种扩展形式。2(一)(一)有限状态机有限状态机(1)基本概念基本概念 有限状态机(有限状态机(finite state machine)或有限自动机)或有限自动机(finite automata)是有限计算的基本模型,是许多形式化)是有限计算的基本模型,是许多形式化规格、验证方法的基础模型。规格、验证方法的基础模型。
2、超级商场的自动门控制器超级商场的自动门控制器 自动门的前、后分别有两个缓冲自动门的前、后分别有两个缓冲区。自动门的前缓冲区用来检测是否有人接近。自动门的区。自动门的前缓冲区用来检测是否有人接近。自动门的后缓冲区,使得控制器把门打开足够长的时间让人走进去,后缓冲区,使得控制器把门打开足够长的时间让人走进去,并且不让门在打开的时候碰到站在它附近的人。自动门控并且不让门在打开的时候碰到站在它附近的人。自动门控制器依据前缓冲区、后缓冲区的检测信息给出打开或闭合制器依据前缓冲区、后缓冲区的检测信息给出打开或闭合的动作指令。的动作指令。自动门的动作控制应满足如下要求(规格):自动门的动作控制应满足如下要求
3、(规格):当前缓冲区和后缓冲区均无顾客出现,则自动门处于闭当前缓冲区和后缓冲区均无顾客出现,则自动门处于闭合状态;合状态;当后缓冲区有顾客出现,则自动门维持其原有状态;当后缓冲区有顾客出现,则自动门维持其原有状态;当前缓冲区有顾客且后缓冲区无顾客,则打开自动门。当前缓冲区有顾客且后缓冲区无顾客,则打开自动门。前缓冲区后缓冲区(1)基本概念基本概念状态集合状态集合Q=closed,open;初始状态初始状态 q0=closed;输入集合输入集合 =front,rear,both,neither状态转移关系集合状态转移关系集合(closed,rear)=closed;(closed,both)=c
4、losed;(closed,neither)=closed;(closed,front)=open;(open,rear)=open;(open,both)=open;(open,front)=open;(open,neither)=closedclosed:闭合状态;open:打开状态;front:前缓冲区有顾客;rear:后缓冲区有顾客;both=front rear:前、后缓冲区都有顾客;neither=front rear:前、后缓冲区都无顾客closed openfrontneitherboth,rear,neitherboth,rear,front前缓冲区后缓冲区4(1)基本概念基
5、本概念模模3计数器计数器 状态集合状态集合Q=0,1,2;初始状态初始状态 q0=0;输入集合输入集合 =inc,dec状态转移关系集合状态转移关系集合(0,inc)=1;(0,dec)=2;(1,inc)=2;(1,dec)=0;(2,inc)=0;(2,dec)=1 01dec2incincincdecdecinc:增加1dec:减少15(1)基本概念基本概念身份认证系统身份认证系统 (合法身份:(合法身份:ABAABA)状态集合状态集合Q=1,2,3,4;初始状态初始状态 q0=1;终结状态集合终结状态集合 F=4;输入集合输入集合 =A,B,C 状态转移关系集合状态转移关系集合(1,A
6、)=2;(1,B)=1;(1,C)=1;(2,A)=2;(2,B)=3;(2,C)=1;(3,A)=4;(3,B)=1;(3,C)=1 ABCACA AABCABA (1,AB)=312A3B,CB,CCBA4A终结状态accepting state6(1)基本概念基本概念有限状态机是一个五元组 M=(Q,q0,F),其中 Q=q0,q1,qn是有限状态集合。在任一确定的时刻,有限状态机只能处于一个确定的状态qi;=1,2,m是有限输入字符集合。在任一确定的时刻,有限状态机只能接收一个确定的输入j;:Q Q是状态转移函数。如果在某一确定的时刻,有限状态机处于某一状态qiQ,并接收一个输入字符j
7、,那么下一时刻将处于一个确定的状态q=(qi,j)Q。在这里规定q=(q,);q0 Q是初始状态,有限状态机由此状态开始接收输入;F Q是终结状态集合,有限状态机在达到终结态后不再接收输入。7(1)基本概念基本概念:字母表字符串:字母表上的字符组成的有限序列(为空串)语言:字母表上的字符串的集合当=a,b,aabb,ab,abab,bba,等都是上的语言有限状态机接受的语言:L(M)=x|(q0,x)F有限状态机可用四元组 M=(Q,q0)或三元组 M=(Q,)来表示。状态转移函数:刻画其行为的最关键部分,一个从Q到Q的二元函数。状态转移函数通常可以用关系矩阵、状态转移表或状态转移图的形式来表
8、示。8(1)基本概念基本概念o 状态转移矩阵 用行表示状态机所处的当前状态,列表示将要到达的下一个状态,行列交叉处表示输入字符。称该矩阵为转移函数的关系矩阵,或者有限状态机M的状态转移矩阵。模3计数器 0 1 20 inc dec2 inc dec1 dec inc状态转移矩阵01dec2incincincdecdec9o 状态转移表 用表格的行表示状态机所处的当前状态,列表示当前的输入字符,行列交叉处表示要到达的下一个状态。模3计数器 输入字符状态inc dec1 20 12 0 012状态转移表01dec2incincincdecdec10o 状态转移图 用圆圈(结点)表示状态;将存在转移
9、关系的状态用有向弧连接,并标注相应的输入字符在有向弧旁;用标有箭头的结点表示初始状态;属于终结状态集中的状态用双圈表示。01dec2incincincdecdec状态转移图模3计数器 11(1)基本概念基本概念p 前面讨论的有限状态机,可以看作仅接受输入符号并发生状态改变,但无任何输出的自动机器。p 现实生活中的许多有限状态系统,对于不同的输入信号,除内部状态不断改变外,还不断向系统外部输出各种信号。p 将有限状态机进行推广,引出具有输出机制的自动机器模型。p 带输出的自动机器模型,按照输出的不同分成两类:输出与状态有关Moore机机;输出与状态和输入有关Mealy机机。12(2)Moore机
10、机Moore机形式定义为六元组M=(Q,q0),其中 Q=q0,q1,qn是有限状态集合;=1,2,m是有限输入字符集合;=a1,a2,ar是有限输出字符集合;:Q Q是状态转移函数;:Q 是输出函数;q0 Q是初始状态。101010q0q2q1例例:二进制数的:二进制数的模模3余数余数Q=q0,q1,q2=0,1=0,1,2(qj)=j,j=0,1,2在输入010100 下,输出为012212 13(2)Mealy机机Mealy机形式定义为六元组M=(Q,q0),其中 Q=q0,q1,qn是有限状态集合;=1,2,m是有限输入字符集合;=a1,a2,ar是有限输出字符集合;:Q Q是状态转移
11、函数;:Q 是输出函数;q0 Q 是初始状态。状态转移函数为:(q0,0)=q1,(q0,1)=q2,(q1,1)=q2,(q1,0)=q1,(q2,1)=q2,(q2,0)=q1输出函数为:(q0,0)=n,(q0,1)=n,(q1,1)=n,(q1,0)=y,(q2,1)=y,(q2,0)=n。在输入01100 下,输出为nnyny 1/y0/n1/n0/y0/n1/nq0q2q114(2)Mealy机机身份认证系统(具有条件和变量机制的有限状态机)(最大允许错误次数为3)(err:报警状态;ctr:计数变量)Xcon/Yexec含义在于:所标注的状态转移关系在输入x且条件con成立下,转
12、移至下一状态,并输出y且执行exec。标注中的各项x、con、y或exec可以缺省。12A3B,Cctr3/ctr:=ctr+1 BA4errCctr3/ctr:=ctr+1 B,Cctr=3/ctr:=ctr+1 B,Cctr=3/ctr:=ctr+1 A,Cctr=3/ctr:=ctr+1 B,Cctr3/ctr:=ctr+1 Actr3/ctr:=ctr+1/ctr:=0 15(2)Mealy机机身份认证系统身份认证系统err12A3BA4ctr=2 ctr=2 ctr=2 ctr=2 12A3BA4ctr=3 ctr=3 ctr=3 ctr=3 12A3BA4ctr=1 ctr=1 c
13、tr=1 ctr=1 12A3BA4ctr=0 ctr=0 ctr=0 ctr=0 ctr=4 B,CB,CB,CB,CB,CB,CB,CB,CA,CCCCAAA16(3)有限状态机的复合有限状态机的复合o 通常,软件系统是以模块或子系统的形式出现o 整个软件系统的有限状态机规格,需要对各个模块的有限状态机进行复合。o 有限状态机复合的最简单方式是笛卡尔积o 有限状态机的笛卡尔积复合,规格了多个有限状态机相互独立运行的行为。o 软件系统之间存在交互问题,有限状态机的复合也必然涉及交互问题。17(3)有限状态机的复合有限状态机的复合有限状态机M1=(Q1,1,1,q10)和M2=(Q2,2,2,
14、q20)的笛卡尔积为M=M1 M2=(Q,q0),其中,Q=Q1Q2;=(1)(2);q0=(q10,q20)Q1Q2;(q1,q2),(a1,a2)=(q1,q2)1(q1,a1)=q1,a2=,a11 (q1,q2)2(q2,a2)=q2,a1=,a22 (q1,q2)1(q1,a1)=q1,2(q2,a2)=q2,a11,a22 无定义无定义 其余其余 18(3)有限状态机的复合有限状态机的复合01dec2incincincdecdec模模3计数器计数器模模4计数器计数器01dec2incincdec3incincdecdecdeco 模3和模4计数器的笛卡尔积复合有34=12个状态o
15、每个状态下,两个模计数器均可相互独立地进行加数、减数或保持不变19(3)有限状态机的复合有限状态机的复合o 每个状态有33=9种状态转移选择,但其中一种为无任何状态转移发生,故只有8种状态转移。o 其笛卡尔积复合具有128=96个状态转移2,02,12,32,21,01,11,31,20,00,10,30,2dec,decinc,inc,decinc,incdec,incdec,inc,dec模计数器的笛卡尔积模计数器的笛卡尔积复合复合 20有限状态机的同步积复合有限状态机的同步积复合有限状态机M1=(Q1,1,1,q10)和M2=(Q2,2,2,q20)的同步积复合为M=M1 M2=(Q,q
16、0),其中,Q=Q1Q2;=1 2;q0=(q10,q20)Q1Q2;(q1,q2),a)=(q1,q2)1(q1,a)=q1,2(q2,a)=q2,a1 2 (q1,q2)2(q2,a)=q2,a1,a2 (q1,q2)1(q1,a)=q1,a1,a2 无定义 其余 21有限状态机的同步积复合有限状态机的同步积复合模计数器的同步积模计数器的同步积复合复合 2,02,12,32,21,01,11,31,20,00,10,30,2decincp模模3 3和模和模4 4计数器,可以进行耦合运行,阻止各自的独计数器,可以进行耦合运行,阻止各自的独立运行行为。立运行行为。只有只有incinc、inci
17、nc和和decdec、decdec两种共两种共2424个状态转移个状态转移22有限状态机的异步积复合有限状态机的异步积复合有限状态机M1=(Q1,1,1,q10)和M2=(Q2,2,2,q20)的异步积复合为M=M1 M2=(Q,q0),其中,Q=Q1Q2;=1 2;q0=(q10,q20)Q1Q2;(q1,q2),a)=(q1,q2)2(q2,a)=q2,a2 (q1,q2)1(q1,a)=q1,a1 无定义 其余23有限状态机的异步积复合有限状态机的异步积复合模计数器的异步积模计数器的异步积复合复合 2,02,12,32,21,01,11,31,20,00,10,30,2incdecinc
18、decp模模3 3和模和模4 4计数器,可以进行耦合运行,但在任何状态计数器,可以进行耦合运行,但在任何状态下仅有其中一个模计数器运行。下仅有其中一个模计数器运行。分别有分别有incinc和和decdec两种共两种共4848个状态转移个状态转移(4 4)生产者生产者-消费者问题消费者问题 生产者消费者系统生产者消费者系统包含一个生产者和一个消费者。生产者进程产包含一个生产者和一个消费者。生产者进程产生消息,并把产生的消息写入一个能容纳两个消息的缓存区中。生消息,并把产生的消息写入一个能容纳两个消息的缓存区中。生产者在进行“生产”动作后,状态由P1转变为P2;而在“写”动作后,状态由P2恢复为P
19、1。消费者进程能读取消息,并把消息从缓存器中取走。消费者在“读”动作后,状态由C1转变为C2;而在进行“消费”动作后,状态由C2恢复为C1。如果缓存器是满的,那么生产者进如果缓存器是满的,那么生产者进程必须等待,直到消费者进程从缓存器中取出一个消息,程必须等待,直到消费者进程从缓存器中取出一个消息,使缓存器产生一个消息空位。同样,如果缓存器是空的,使缓存器产生一个消息空位。同样,如果缓存器是空的,那么消费者进程就必须等待,直到生产者进程产生一个那么消费者进程就必须等待,直到生产者进程产生一个消息并把所产生的消息写入缓存器中。消息并把所产生的消息写入缓存器中。缓存器在进行“读”动作后,缓存器大小
展开阅读全文