《需求工程》PPT课件.ppt
1,RE vs.Systems Analysis 需求工程vs.系统分析,2,需求工程vs.系统分析RE vs.Systems Analysis,需求工程由系统分析发展而来系统分析关注企业内部的信息系统主要采用非形式化的需求描述,工具和方法,例如:DFD,E-R,OO,80年代中期形成,90年代以来成为研究热点。多见于管理学院,工程学科,和计算机科学的本科生和研究生教学,3,需求工程vs.系统分析RE vs.Systems Analysis,需求工程超出系统分析的范围涵盖整个形式化问题从“企业需求”到“精确描述”不仅限于信息系统实时系统嵌入系统交互系统基于组件的系统web services相对较少关注企业管理问题和企业业务流程,4,But,what is a requirement?,每一个“人造物”都是一个内部环境与外部环境的“接口”。这里内部环境指人造物本身的设计组成。外部环境指人造物的周遭及其作用环境。对这个接口的描述即是需求。Herbert Simon,1969需求,即是人们要解决的某个问题或达到某种目的的需要。是系统或其组成部分为满足某种书面规定(合同,标准,规范等)所要具备的能力。需求将作为系统开发,测试,验收,提交的依据。IEEE 610.12,1990,5,将问题与解决方案分开,理解问题需求获取问题的形式化表示形式规约,形式建模就问题性质达成共识验证,冲突及矛盾消解,磋商需求管理 维护双方的共识,6,设计活动改变客观世界状态,7,什么是需求?(Jackson,1995),领域性质(Domain Property):无论系统存在与否均存在的应用领域的性质。需求(Requirements):由系统的存在而产生的应用领域性质。规约描述(Specification):描述系统为满足需求而应具有的行为。需求证明的标准(Verification Criteria):1、运行在某台机器上的程序满足规约描述;2、针对给定的领域性质,规约描述满足需求。需求验证的标准(Validation Criteria):1、是否已发现所有重要需 求?2、是否已发现所有有关的领域性质?,8,实例,Requirement R需求:只有被授权者能够访问数据库。Domain Properties D领域性质:授权者持有密码。密码不会分享给未授权者。Specification S 规约描述:用户输入密码后,将被准许访问数据库。S+D imply R当领域模型出错时,会有什么后果,9,需求:关于为什么?做什么?不包括怎么做?(why,what,how),需求描述必须给出为什么需要这样一个系统。Ross,1977通常,需求描述系统要做什么,而不是怎么做。但是,二者不太容易区分,上一个抽象层次的“怎么做”经常在下一个抽象层次上转化为“做什么”。Jackson给出的稍为清楚的解释:“为什么”和“做什么”是指系统的设计目的,是置身系统外部,对应用领域性质的描述。“怎么做”是指系统的内部结构和行为。Jackson,1995,10,“描述”是需求工程的核心(Jackson,1995),用非形式化的语言指出感兴趣的主题现象,并命名(designation)。例如:Parent(x,p):p是x的父母。Female(x):x是女性。术语的形式化定义(definition)和使用。例如:Mother(x,m)Parent(x,m)and Female(m)Sister(x,y)Female(y)and mother(x,m)and mother(y,m)and father(x,f)and father(y,f),11,“描述”是需求工程的核心(Jackson,1995,p58-59),关于领域性质的无可驳的描述(refutable description)。无可驳性依赖于与主题现象的一致性。例如:对所有的m和x,Parent(x,m)蕴含not(parent(m,x)开发过程中的带有假设性质的概略描述(rough sketch)。例如:“人与人之间总是通过某种方式相互联系”“每个人实际上只能有一个家”,12,存在问题的需求描述实例,含糊的需求描述:“工资总额由上一条记录获得”“所有客户都具有同一控制域“错误的需求描述:“所有系统将九月作为财政年度的起始时间”不完整的需求描述:“出错信息显示在屏幕的第24行“矛盾或不一致的需求描述:“C=A+B”;“C=A-B”无法测试的需求:“系统应具有友好的界面“,13,需求的层次,软件需求包括三个不同的层次业务需求(business requirement)反映了组织机构或客户对系统、产品高层次的目标要求,它们在项目视图与范围文档中予以说明。用户需求(user requirement)描述了用户使用产品必须要完成的任务,这在使用实例(use case)文档或方案脚本(scenario)说明中予以说明。功能需求(functional requirement)(包括非功能需求):定义了开发人员必须实现的软件功能,使得用户能完成他们的任务,从而满足了业务需求。,14,软件需求各组成部分之间的关系,对一个复杂产品来说,软件功能需求也许只是系统需求的一个子集,另外一些可能属于软件部件。,管理人员或市场分析人员确定软件的业务需求,使公司运作更加高效(对信息系统而言)或具有很强的市场竞争力(对商业软件产品而言)。,所有的用户需求必须与业务需求一致。用户需求使需求分析者能从中总结出功能需求以满足用户对产品的要求从而完成其任务,而开发人员则根据功能需求来设计软件以实现必须的功能。,15,非功能性需求:,作为功能需求的补充,软件需求规格说明还应包括非功能需求,它描述了系统展现给用户的行为和执行的操作等。它包括产品必须遵从的标准、规范和合约;外部界面的具体细节;性能要求;设计或实现的约束条件及质量属性。所谓约束是指对开发人员在软件产品设计和构造上的限制。质量属性是通过多种角度对产品的特点进行描述,从而反映产品功能。多角度描述产品对用户和开发人员都极为重要。,16,需求工程,17,本章内容,工程与软件工程软件需求工程需求工程师需求工程vs.系统分析软件生命周期中的需求活动关于需求的基本观点,18,Requirement activities in the SE lifecycle 软件生命周期中的需求活动,19,瀑布模型(Waterfall/Baseline),核心思想:系统开发是逐步求精的过程各步骤相对独立,便于管理存在的问题:忽略了需求的动态性需求完成后,用户对项目的参与即停止需求描述与设计分开不支持原型的使用和软件重用(Loucopoulos&Karakostas,1995),20,原型法(Prototype),适用范围:用于获取关于系统用户界面的需求用于检验设计方案的可行性,或探讨系统性能问题存在的问题:用户将原型误认为最终系统原型所反映的系统是不全面的(Loucopoulos&Karakostas,1995,p30),21,增量式开发与演化式开发Incremental vs.Evolutionary(Thayer&Dorfman,1997,p10),22,螺旋模型(Spiral Model),螺旋模型主要用于风险分析每一轮开发活动具体包括:制定下一轮计划决定设计目标和限制条件评估候选方案,风险降解产品开发需求工程有关步骤为:需求风险分析规划设计可以减少需求变更所带来的风险存在的问题:无法应付不可预见的需求变化,23,V型模型(V-Model)(Macaulay,1996),24,关于敏捷模型(Agile Models),基本原则:减少沟通障碍程序员与客户直接交流减低繁重的文档负担文档代价昂贵但用途有限对开发人员给予充分信任无需运用花样翻新的过程模型给与提示响应客户要求而非严格遵循合同条文,缺点:依赖程序员的记忆力源代码是难于维护的依赖口头交流易发生误解假定只有唯一的客户代表不可能反映多视角制作短期计划无长期及前瞻性规划,25,本章内容,工程与软件工程软件需求工程需求工程师需求工程vs.系统分析软件生命周期中的需求活动关于需求的基本观点,26,Viewpoints 关于需求的基本观点,27,关于需求的基本观点,需求工程活动不总是顺序进行问题描述不总是先于解决方案描述在系统开发的任何阶段描述问题均是有益的需求工程是在各开发阶段持续进行的一系列活动问题陈述无法追求完美需求模型是对世界的近似表示将包括不精确和不一致性会省略某些信息细致的分析将降低导致严重问题的风险但风险永不可能降解为零,28,关于需求的基本观点,追求规约的描述会降低性价比需求分析是有开销的不同的项目,性价比的平衡点是不同的问题描述永不可能是固定的变化是无法避免的,因此应纳入计划之中对变化的处理应定期进行,29,可能的需求来源,客户专有需求对于有着明确问题的特定客户,最终客户享有决定权。市场需求对于在市场上广泛出售的产品,营销团队扮演着顾客和用户代表的角色,产品必须拥有顾客。社会需求系统的目的是造福社会,而不需要客户(支付报酬)一些开源/自由软件,科学研究软件综合为特定客户开发,但最终希望面向市场的软件。,30,作业一,选择任何你认为合适的系统,用自然语言写出其需求描述(e.g.电梯控制系统,ATM机系统,图书管理系统,交通信号控制系统)。1.明确区分:领域性质,需求和规约描述。2.给出对该系统的非功能性需求。3.试用你过去所学的某种方法形式化该需求。例如:一阶逻辑,状态机。指出哪些是命名,哪些是定义,哪些是可驳的描述。4.作业成绩将根据你对课程内容的理解。,