功能点(FP)估算法(二) 事务复杂度计算

转帖  http://space.itpub.net/21011012/viewspace-621025

 

软件项目管理中的功能点估算法将功能点分为5类:ILF(Internal Logical File,内部逻辑文件)、EIF(External Interface File,外部接口文件)、EI(External Input,外部输入)、EO(External Output,外部输出)和EQ(External Inquiry,獠坎檠F渲校琁LF和EIF属于数据类型的功能点,EI、EO、EQ属于事务类型的功能点。

EI、EO、EQ的比较

    EI是处理来自应用程序边界外部的一组数据输入,它的主要目的是维护一个或多个ILF,以及/或者更改系统的行为。

    EO是输送数据到应用程序边界外部的过程。它的主要目的是通过逻辑处理过程向用户呈现信息。该处理过程必须包含至少一个数学公式或计算方法,或生成派生数据。一个EO也可以维护一个或多个ILF,并/或改变系统行为。
    EQ是向应用程序边界外发送数据基本处理的过程。其主要目的是从ILF或EIF中通过恢复数据信息来向用户呈现。该处理逻辑不包括任何数学公式或计算方法,也不会生成任何派生数据。EQ不会维护任何一个ILF,也不会改变应用程序的系统行为。
    EO和EQ的共同点是,其主要目的都是通过基本操作过程展现数据给用户。EI、EO、EQ的比较见下表。

表1 EI、EO、EQ的主要目的

目的EIEOEQ
改变应用程序的属性或行为主要目的次要目的不允许
维护一个或多个ILF主要目的次要目的不允许
显示信息给用户次要目的主要目的主要目的

表2 EI、EO、EQ的主要行为

行为EIEOEQ
数学公式或计算被执行可以至少选择一次不可以
至少一个ILF被修改至少选择一次至少选择一次不可以
至少一个ILF或EIF被引用可选可选必选
数据被重新恢复可选可选必选
派生数据被创建可选至少选择一次可选
应用程序的行为或属性被修改至少选择一次至少选择一次可选
准备或呈现信息到系统边界外可选必选必选
接受进入系统边界内的数据的能力必须可选可选

事务类型功能点的计算规则

    在IFPUG的定义中有一个重要的单词“Elementary Process”——基本处理过程。该过程对用户来说是一个有意义的、最小的活动单位,并且是一个自包含的活动。功能点的分类,EI、EO、EQ的识别都是基于“Elementary Process”基本处砉痰摹?/p>

   EI的计算规则
    1. 从应用边界之外收到数据。ITPUB个人空间N$OU!cf4k{
    2. 如果进入系统边界内的数据不是一个改变系统行为的控制信息,那么至少一个ILF应该被改变。
    3. 对于已识别的处理过程,至少满足下面三个条件之一。

  • 该基本处理过程的逻辑与本应用系统中其它基本处理过程的逻辑不同。该基本处理过程应该具有唯一性。例如:不能存在两个完全一模一样的存盘操作。
  • 在应用程序边界内,该基本处理过程所使用的这组数据应该与其他基本处理过程所使用的数据不同。
  • 在应用程序边界内,基本处理过程所引用的ILF或EIF是不同于其它基本处理过程所引用的ILF或EIF。

   EO和EQ通用计算规则
   必须全部满足以下内容才能被视为一个EO或EQ:
    1. 从外部发送数据或控制信息到应用程序边界内。 

    2. 为了识别这个过程,以下三点必须满足一个:

  • 该基本处理过程逻辑上必须是唯一的,该唯一性是指其在应用程序中与其他EO或EQ在逻辑性上保持唯一。
  • 该基本处理过程所使用的数据应该是唯一的,该唯一性是指其在应用程序中与其他EO或EQ所使用的数据不同。
  • 该基本处理过程所引用的ILF或EIF文件应该是唯一的,该唯一性是指其在应用程序中与其他EO或EQ所引用的ILF或EIF文件不同。

   EO补充的计算规则
     除了要满足上面的通用规则外,还要满足下面其中一条:

  • 在基本操作过程中至少包含一个数学公式或计算方法
  • 在基本操作过程中要产生派生数据
  • 在基本操作过程中至少要维护一个ILF
  • 在基本操作过程中要改变系统的行为。

   EQ补充的计算规则
    除了要满足上面的通用规则外,还要满足下面其中一条:

  • 基本操作过程从ILF或EIF中获取数据。
  • 基本操作过程不能包含数学公式或计算方法。
  • 基本操作过程不能生成派生数据
  • 基本操作过程不能维护任何一个ILF
  • 基本操作过程不能改变系统的行为

EI、EQ和EO的技术复杂性计算

  复杂性取决于FIRs和DETs的数量。FTR是被一个事物读取或维护的ILF,或者是被一个事物读取的EIF。

   EI中识别FTR规则

  • 每一个ILF应该算做一个FTR。
  • 通过EI读取的每个ILF或EIF都应该计算为一个FTR。
  • 既被EI维护又被读取的ILF仅计算为一个FTR。

   EI中识别DET规则

  • 在EI的过程中,以用户角度识别的、通过应用系统边界输入系统内部的非重复字段,应算作一个DET。
  • 在EI的过程中,只要没有通过系统边界输入,即使它存在于系统内的一个ILF中,也不能算为一个DET。

    例如,外贸订单系统中,订单的金额是被单价和数量自动计算的,那么金额是没有通过系统边界输入的,因此在EI操作中就不应该算做一个DET。

  • 在应用程序的EI操作时,系统提示的错误信息或完成操作的信息,应该被分别计算为一个DET。

    例如,在网站注册用户信息时,由于输入错误系统会显示提示信息,那么这些提示信息应该被逐个计算为一个DET。
    再如,当EI操作完成时系统提示并显示出来的信息,应该被计算为一个DET。

  • 在EI操作中,如果遇到主外键的字段,应该算作一个DET。

   EO和EQ计算FTR的规则
    1. 通用规则:

  • 每个在EO/EQ处理过程中读取的ILF和EIF算一个FTR

    2. EO额外的FTR计算规则

  • 在EO处理过程中每个被维护的ILF算一个FTR
  • 在EO处理过程中既被读取又被维护的ILF算一个FTR

   EO和EQ计算DET的通用规则

  • 用户可识别的非重复字段,进入应用边界并指明处理什么、何时处理或处理方式,并且由EO/EQ返回或产生,那么这样的每个字段算一个DET。

    例如,报表中的每个字段都是一个DET。

  • 在应用边界内以用户角度识别的非重复字段算一个DET。

    例如,在报表中起到解释或备注作用的文字信息,不管是一个字、一个词或一段话,都当作一个DET。
    再如,某种编号或日期,即使它被物理存储在不同字段中,但从用户角度看是一个整体的信息,因此被算作一个DET。
    还有,在饼图中百分比和分类算作不同的DET。

  • 在EO或EQ操作中,如果对系统进行输入或读取操作时,相同的字段只计算一个DET。

    例如,在报表查询时,输入的字段在报表上也有显示,那么将算作同一个DET。

  • 在应用程序的EO或EQ操作时,系统提示的错误信息或完成操作的信息,应该被计算为DET。

    例如,用户查询一个列表时被拒绝,那么拒绝的提示信息就算为一个DET。

  • 在EO或EQ操作中如果遇到主外键的字段,应该算作一个DET。
  • 在EO或EQ过程中,只要没有通过系统边界输入,就算它存在于系统内的一个ILF中,也不能算为一个DET。

    例如,在公司发工资的时候,员工对应的状态信息被更新,但这个状态信息的更新是没有通过系统边界输入的,因此也不能算做一个DET。

  • 页面的标题等类似信息不计算DET。
  • 系统字段生成的记号不能被算作一个DET。

    例如,页码、位置信息、时间、上一页和下一页等信息,都不能算作一个DET。

EI复杂度计算矩阵

 1~4个DET5~15个DET多于16个DET
0~1个FTR中等
2个FTR中等
大于2个FRT中等

EO和EQ复杂度计算矩阵

 1~5个DET6~19个DET多于20个DET
0~1个FTR中等
2~3个FTR中等
多于4个FTR中等

未调整前功能点对应矩阵
EI、EO、EQ、ILF和EIF技术复杂度对应的功能点如下表所示:

 一般
EI346
EO457
EQ346
ILF71015
EIF5710

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1. 功能分析法概论 1.1 功能分析方法的目标: 1. 功能方法的收益. 1.3. 功能分析法的步骤. 1.3.1. 决定分析的类型 1.3. 识别分析范围和应用边界 1.3.3. 确定未经调整的功能数 (Unadjusted Function Point Count -- UFPC) . 1.3.3.1 数据功能的计数 1.3.3 交易功能的计数 1.3.3.4. 确定调整系数 1.3.3.5.计算经过调整的功能 2. 分析流程. 2.1 决定分析的类型. 2.1.1 定义:功能分析的类型. 2 识别分析范围和应用边界 2.1 识别分析范围和应用边界中的定义 2 定义应用边界. 2.3 分析范围以及应用边界的规则和流程. 2.3.1 边界识别的规则. 2.3 分析范围和应用边界流程: . 2.3.3 边界识别的一些技巧: 2.4 计数数据功能 2.4.1 定义: 2.4 计数流程概述. 2.4.3 ILF 识别规则. 2.4.4 EIF 识别规则. 2.4.5 复杂度和贡献的定义和规则. 2.4.6 ILF/EIF 计数流程. 2.4.7 复杂度和贡献确定流程 2.4.8 数据功能计数技巧. 2.5 计数交易功能 2.5.1 定义 2.5.1.1 基本定义. 2.5.1 交易功能的总结: 2.5.1.3 相关术语的定义 2.5.1.4 交易功能执行的逻辑处理总结 2.5 EI,EO,EQ 计数规则 2.5.1 交易功能计数的概要流程 2.5 基本处理的识别规则 2.5.3 交易功能计数规则 2.5.3.1 EI 的主要目的描述:. 2.5.3 EI 的计数规则: 2.5.3.3 EO 和EQ 的共同主要目的描述: 2.5.3.4 EO/EQ 共享的计数规则:. 2.5.3.5 EO 计数的补充规则:. 2.5.3.6 EQ 计数的补充规则:. 2.5.3 复杂度和贡献的定义和规则. 2.5.3.1 EI 的复杂度和贡献规则 2.5.3.1.1 EI 的引用文件类型(FTR)计数规则 2.5.3.1 EI 的数据元素类型(DET)计数规则. 2.5.3 EO/EQ 的复杂度和贡献规则 2.3.5.1 EO/EQ 共享的引用文件类型(FTR)计数规则 2.3.5 EO 特定的引用文件类型(FTR)计数规则 2.3.5.3 EO/EQ 共享的数据元素类型(DET)计数规则. 2.5.4 EI,EO,EQ 的计数流程 2.5.5 复杂度和贡献确定流程. 2.5.6 交易功能计数技巧. 2.6 决定调整系数 2.6.1 调整系数的决定. 2.6 确定VAF 的流程 2.6.3 通用系统特性及其影响程度的评定. 2.6.3.1 数据通讯. 2.6.3 分布式数据处理. 2.6.3.3 性能. 2.6.3.4 使用强度高的配置. 2.6.3.5 交易速度 2.6.3.6 在线数据输入 2.6.3.7 最终用户的效率. 2.6.3.8 在线更新 2.6.3.9 复杂的处理 2.6.3.10 可重用性 2.6.3.11 安装的简易性 2.6.3.12 运行的简易性 2.6.3.13 多场地 2.6.3.14 允许变更 2.7 计算调整功能 2.7.1 开发项目功能计算. 2.7 升级项目功能计算. 2.7.3 应用功能计算. 附录A : 未经调整的功能计算表. 附录B:功能计数中的规则表. 附录C: 词汇表:.
功能(Function Point,简称FP)是一种软件算方法,通过对软件的功能进行计量和评,来算软件开发所需的工作量和时间。 功能算法的第一步是识别项目范围和数据复杂度。在这一步中,需要明确软件的功能和所涉及的数据复杂度,以便进行后续的算工作。 项目范围是指软件开发所需实现的功能的数量和种类。识别项目范围需要对软件的需求进行全面的分析,明确每个功能的具体内容和目标。这有助于在后续的算过程中,对不同功能复杂度进行合理的评。 数据复杂度是指软件所涉及的数据数量和结构的复杂程度。不同的数据复杂度会对软件开发的工作量产生不同的影响,因此在功能算中需要对数据复杂度进行评。常见的数据复杂度包括简单的输入输出、中等的数据结构和复杂的数据处理等。 在识别项目范围和数据复杂度的过程中,可以借助已有的需求文档或者与项目相关的人员进行沟通和讨论。通过详细地了解每个功能的具体内容和所需的数据复杂度,可以提高功能算的准确性和可靠性。 总之,功能算法的第一步是识别项目范围和数据复杂度。通过明确软件的功能和数据复杂度,可以为后续的功能算提供有效的依据和参考,从而更准确地算软件开发的工作量和时间。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值