形式化方法数据库原理.ppt
《形式化方法数据库原理.ppt》由会员分享,可在线阅读,更多相关《形式化方法数据库原理.ppt(57页珍藏版)》请在三一办公上搜索。
1、形式化说明技术,主讲人:陈云贵Tel:Email:,教学目标 了解形式化说明技术,了解有穷状态机的概念,了解Petri网的概念。教学重点 形式化说明技术的积极意义。教学难点 有穷状态机、Petri网的概念和使用。,第4章 形式化说明技术,第4章 形式化说明技术,4.1 概述4.2 有穷状态机4.3 Petri网4.4 Z语言,4.1 概述,按照形式化的程度,可以把软件工程使用的方法划分成3类:非形式化、半形式化、形式化。用自然语言描述需求规格说明,是典型的非形式化方法。用数据流图或实体-联系图建立模型,是典型的半形式化方法。所谓形式化方法,是描述系统性质的基于数学的技术,也就是说,如果一种方法
2、有坚实的数学基础,那么它就是形式化的。,形式化方法定义,如果一个方法有良好的数学基础,那么它就是形式化的,典型地以形式化规约语言给出。这个基础提供一系列精确定义的概念,如:不同的形式化方法的数学基础是不同的,有的以集合论和一阶谓词演算为基础(如Z和 VDM),有的则以时态逻辑为基础。形式化方法需要形式化规约说明语言的支持。,用自然语言书写的系统规格说明书,可能存在矛盾、二义性、含糊性、不完整性及抽象层次混乱等问题。所谓矛盾是指一组相互冲突的陈述。二义性是指读者可以用不同方式理解的陈述。,4.1.1 非形式化方法的缺点,为了克服非形式化方法的缺点,人们把数学引入软件开发过程,创造了基于数学的形式
3、化方法。在开发大型软件系统的过程中应用数学,能够带来下述的几个优点:能够简洁准确地描述物理现象、对象或动作的结果,因此是理想的建模工具。数学特别适合于表示状态,也就是表示“做什么”,数学比自然语言更适于描述详细的需求。,形式化方法的优点,在软件开发过程中使用数学的另一个优点是,可以在不同的软件工程活动之间平滑地过渡。不仅功能规格说明,而且系统设计也可以用数学表达,当然,程序代码也是一种数学符号(虽然是一种相当繁琐、冗长的数学符号)。数学作为软件开发工具的最后一个优点是,它提供了高层确认的手段。可以使用数学方法证明,设计符合规格说明,程序代码正确地实现了设计结果。,形式化方法的优点,对形式化方法
4、应该“一分为二”,既不要过分夸大它的优点也不要一概排斥。下面给出应用形式化方法的几条准则:应该选用适当的表示方法通常,一种规格说明技术只能用自然的方式说明某一类概念,如果用这种技术描述其不适于描述的概念,则不仅工作量大而且描述方式也很复杂。因此,应该仔细选择一种适用于当前项目的形式化说明技术。,4.1.3 应用形式化方法的准则,(2)应该形式化,但不要过分形式化目前的形式化技术还不适于描述系统的每个方面。带使用之,有助于防止含糊和误解。(3)应该估算成本为了使用形式化方法,通常需要事先进行大量的培训。最好预先估算所需的成本并编入预算。(4)应该有形式化方法顾问随时提供咨询绝大多数软件工程师对形
5、式化方法中使用的数学和逻辑并不很熟悉,而且没受过使用形式化方法的专业训练,因此,需要专家指导和培训。,4.1.3 应用形式化方法的准则,(5)不应该放弃传统的方法把形式化方法和结构化方法或面向对象方法集成起来是可能的,而且由于取长补短往往能获得很好的效果。(6)应该建立详尽的文档建议使用自然语言注释形式化的规格说明书,以帮助用户和维护人员理解系统。,4.1.3 应用形式化方法的准则,不应该放弃质量标准 不应该盲目依赖形式化方法 应该测试、测试再测试应该重用即使采用了形式化方法,软件重用仍然是降低软件成本和提高软件质量的惟一合理的方法。而且用形式化方法说明的软件构件具有清晰定义的功能和接口,使得
6、它们有更好的可重用性。,4.1.3 应用形式化方法的准则,4.2 有穷状态机,4.2.1 概念 有穷状态机可以准确描述一个系统,是表达规格说明的一种形式化方法。通过一个简单例子介绍有穷状态机的基本概念:一个保险箱上装了一个复合锁,锁有三个位置,分别标记为1、2、3,转盘可向左(L)或向右(R)转动。这样,在任意时刻转盘都有6种可能的运动,即1L、1R、2L、2R、3L和3R。保险箱的组合密码是1L、3R、2L,转盘的任何其他运动都将引起报警。如图描绘了保险箱的状态转换情况。,4.2.1 概念,上图是一个有穷状态机的状态转换图。状态转换并不一定要用图形方式描述,如表所示,表格形式也可以表达同样的
7、信息。,从上面这个简单例子可以看出,一个有穷状态机包括下述5个部分:状态集J:保险箱锁定,A,B,保险箱解锁,报警输入集K:1L,1R,2L,2R,3L,3R转换函数T:如表4.1所示初始态S:保险箱锁定终态集F:保险集解锁,报警,4.2.1 概念,一有穷状态机可表示为一个5元组(J,K,T,S,F):J是一个有穷的非空状态集;K是一个有穷的非空输入集;T是一个从(J-F)K到J的转换函数(非F到J)SJ,是一个初始状态;F J,是终态集。,4.2.1 概念,有穷状态机的概念在计算机系统中应用得非常广泛。例如:菜单驱动的用户界面。一个菜单的显示和一个状态相对应,键盘输入或用鼠标选择一个图标是使
8、系统进入其他状态的一个事件。状态的每个转换都具有下面的形式:当前状态菜单+事件所选择的项下个状态。,4.2.1 概念,对一个系统进行规格说明,通常都需要对有穷状态机做一个很有用的扩展:即在前述的5元组中加入第6个组件谓词集P,从而把有穷状态机扩展为一个6元组,其中每个谓词都是系统全局状态Y的函数。转换函数T现在是一个从(J-F)KP到J的函数。现在的转换规则形式如下:当前状态菜单+事件所选择的项+谓词下个状态。,4.2.1 概念,用这种技术给出大家熟悉的电梯系统的规格说明。首先给出用自然语言描述的对电梯系统的需求:在一幢m层的大厦中需要一套控制n部电梯的产品,要求这n部电梯按照约束条件C1,C
9、2和C3在楼层间移动。C1:每部电梯内有m个按钮,每个按钮代表一个楼层。当按下一个按钮时该按钮指示灯亮,同时电梯驶向相应的楼层,到达按钮指定的楼层时指示灯熄灭。,4.2.2 例子,C2:除了大厦的最低层和最高层之外,每层楼都有两个按钮分别请求电梯上行和下行。这两个按钮之一被按下时相应的指示灯亮,当电梯到达此楼层时灯熄灭,电梯向要求的方向移动。C3:当对电梯没有请求时,它关门并停在当前楼层。现在使用一个扩展的有穷状态机对本产品进行规格说明。,4.2.2 例子,这个问题中有两个按钮集。n部电梯中的每一部都有m个按钮,一个按钮对应一个楼层,称它们为电梯按钮。每层楼有两个按钮,一个请求向上,另一个请求
10、向下,这些按钮称为楼层按钮。,4.2.2 例子,令EB(e,f)表示按下电梯e内的按钮并请求到f层去。EB(e,f)有两个状态:EBON(e,f):电梯按钮(e,f)打开EBOFF(e,f):电梯按钮(e,f)关闭EBP(e,f):电梯按钮(e,f)被按下EAF(e,f):电梯e到达f层,4.2.2 例子,图4.2 电梯按钮的状态转换图,C1:每部电梯内有m个按钮,每个按钮代表一个楼层。当按下一个按钮时该按钮指示灯亮,同时电梯驶向相应的楼层,到达按钮指定的楼层时指示灯熄灭。,为了定义与这些事件和状态相联系的状态转换规则,需要一个谓词V(e,f):V(e,f):电梯e停在f层则状态转换规则的形式
11、化描述如下:EBOFF(e,f)+EBP(e,f)+not V(e,f)EBON(e,f)反之:EBON(e,f)+EAF(e,f)EBOFF(e,f),4.2.2 例子,接下来考虑楼层按钮:令FB(d,f)表示f层请求电梯向d方向运动的按钮,楼层按钮的状态如下:FBON(d,f):楼层按钮(d,f)打开FBOFF(d,f):楼层按钮(d,f)关闭FBP(d,f):楼层按钮(d,f)被按下EAF(1n,f):电梯1或或n到达f层其中1n表示或为1或为2或为n。,4.2.2 例子,C2:除了大厦的最低层和最高层之外,每层楼都有两个按钮分别请求电梯上行和下行。这两个按钮之一被按下时相应的指示灯亮,
12、当电梯到达此楼层时灯熄灭,电梯向要求的方向移动。,为了定义与这些事件和状态相联系的状态转换规则,同样也需要一个谓词,它是S(d,e,f),它的定义如下:S(d,e,f):电梯e停在f层并且移动方向由d确定为向上(d=U)或向下(d=D)或待定(d=N)。,4.2.2 例子,使用谓词S(d,e,f),形式化转换规则为:FBOFF(d,f)+FBP(d,f)+notS(d,1n,f)FBON(d,f)FBON(d,f)+EAF(1n,f)+S(d,1n,f)FBOFF(d,f)其中,d=U or D。也就是说,如果在f层请求电梯向d方向运动的楼层按钮处于关闭状态,现在该按钮被按下,并且当时没有正停
13、在f层准备向d方向移动的电梯,则该楼层按钮打开。反之,如果楼层按钮已经打开,且至少有一部电梯到达f层,该部电梯将朝d方向运动,则按钮将关闭。,4.2.2 例子,在讨论电梯按钮状态转换规则时定义的谓词V(e,f),可以用谓词S(d,e,f)重新定义如下:V(e,f)=S(U,e,f)or S(D,e,f)or S(N,e,f)讨论电梯的状态及其转换规则:一个电梯状态实质上包含许多子状态,下面定义电梯的3个状态:M(d,e,f):电梯e正沿d方向移动,即将到达的是第f层S(d,e,f):电梯e停在f层,将朝d方向移动(尚未关门)W(e,f):电梯e在f层等待(已关门),4.2.2 例子,图4.4是
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 形式化 方法 数据库 原理

链接地址:https://www.31ppt.com/p-6572556.html