『软件工程8』软件项目进度安排与跟踪,一招学会计算关键路径

Posted 星期一研究室

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了『软件工程8』软件项目进度安排与跟踪,一招学会计算关键路径相关的知识,希望对你有一定的参考价值。

一、项目进度安排的定义及原则

1、进度安排的定义

项目进度安排,即通过将工作量分配给特定的软件工程任务,和将所估算的工作量分布于已经计划好的项目持续时间中。

2、进度安排的基本原则

(1)划分 —— 项目被划分为若干个可管理的活动和任务

(2)相互依赖 —— 活动和任务之间的关系必须被确定为:顺序、并发、后续、独立进行;

(3)时间分配 —— 为每个任务分配工作单位(即开始和结束时间);

(4)工作量确认 —— 确保在任意时段分配到任务的人员数量不会超过项目组的人员数量;(比如:一个项目组此次预估需要有12人分配到任务才能完成此项工作,但原定人员数量为10人,那么12>10,这项任务的工作量必然超标了,所以要确保不能超过)

(5)定义责任 —— 每个被调度的任务都应该指定负责人

(6)定义结果 —— 每个被调度的任务都要有一个定义好的输出结果

(7)定义里程碑 —— 每个任务或任务组都与一个项目里程碑相关联;

二、通信开销

1、通信开销的定义

当几个人共同承担软件开发任务时,人与人之间必须通过交流来解决各自承担任务之间的接口问题,即所谓通信问题。通信需花费时间和代价,会引起软件错误增加,降低软件生产率。

2、通信路径计算

如果一个软件开发小组有 n 个人,每两人之间都需要通信,则总的通信路径有 n ( n − 1 ) 2 \\frac{n(n-1)}{2} 2n(n1) 条。

如想对通信路径有进一步了解,可到项目管理中的4P文章中的项目小组结构进行查看

3、案例分析

Q1:设一个人单独开发软件,生产率是5000行/人年。若 4 个人组成一个小组共同开发这个软件,则需要 6条通信路径。若在每条通信路径上耗费的工作量是 250 行/人年。则小组中每个人的软件生产率降低为多少?

A1:小组中每个人的软件生产率降低为 5000 - 6 4 \\frac{6}{4} 46×250 = 5000 - 375 = 4625 行/人年,所以项目组的生产率为18500。

Q2:如在上例中,到了开发后期再加入两名工程师,生产率为840行/人年,问此时项目组的生产率为?

A2:6个人所产生的的通信路径为 6 ∗ ( 6 − 1 ) 2 \\frac{6*(6-1)}{2} 26(61) = 15条;所以项目组的生产率为5000 × 4 + 840 × 2 - 15 × 250 = 17930。

从上述分析可知:

  • 一个软件任务由一个人单独开发,生产率最高;而对于一个稍大型的软件项目,一个人单独开发,时间又太长;因此软件开发小组是必要的。
  • 但是,开发小组不宜太大,成员之间要避免过多的通信路径。
  • 在开发进程中,切忌中途加人,避免不必要的的生产率损失。

三、工作量分配

1、40-20-40规则

1)在整个软件开发过程中,编码工作量仅占 20%,编码前工作量占40%,编码后工作量占 40%

2)40-20-40 规则只应用来作为一个指南,实际的工作量分配比例必须按照各项目的特点来决定。

2、工作量分配图例

用一张图来了解关于软件各阶段的工作量分配比例。
工作量分配

3、工作量分布推荐

在实际的软件开发中,一种比较推荐的工作量分布为:

  • 计划阶段planning -> 2-3% ;
  • 需求分析阶段requirements analysis -> 10-25 % ;
  • 设计阶段design -> 20-25 %;
  • 编码阶段coding -> 15-20 % ;
  • 测试和调试阶段testing and debugging -> 30-40 %

四、项目进度安排方法

1、关键路径方法(CPM,Critical Path Method)

(1)定义

在关键路径上的活动才是按时完成任务的关键。

(2)关键路径的相关表达

  • LS:Latest start time 最晚开始时间;
  • ES:Earliest start time 最早开始时间;
  • FT:Float Time 浮动时间;
  • 关键路径的判断:计算哪条路径最长,即为关键路径;
  • 关键路径上的节点对应的浮动时间为FT = 0,且在每个项目中,关键路径不止一条;
  • 如果关键路径上的活动开始时间推迟,将会直接影响工期;
  • 最晚开始时间 - 最早开始时间 = 浮动时间。

(3)案例分析:盖房子

表1 盖一所房子的重要阶段

阶段完成事项
1.1完成调查
1.2签发许可证
1.3完成挖掘
1.4库存材料
2.1施工地基
2.2外墙完成
2.3外部管道完成
2.4外部电力工作完成
2.5外部壁板完成
2.6外部涂装完成
2.7安装门和一些固定设施
2.8屋顶完成
3.1内部管道完成
3.2内部电力工作完成
3.3墙板就位
3.4内部涂装完成
3.5铺设地板
3.6安装门和一些固定设施

表2 盖房子相关活动的时间估计

具体活动估计时间(天)
Step1: 准备工作
完成调查3
签发许可证15
完成挖掘10
库存材料10
Step2: 构建外部
施工地基15
外墙完成20
外部管道完成10
外部电力工作完成10
外部壁板完成8
外部涂装完成5
安装门和一些固定设施6
屋顶完成9
Step3: 构建内部
内部管道完成12
内部电力工作完成15
墙板就位9
内部涂装完成18
铺设地板11
安装门和一些固定设施7

表3 任务网络图
任务网络图

:某项目的活动网络图如表3所示,每项活动所需的天数如路径上数字所示。(1)请给出计算过程确定项目的关键路径和工期。(2)设定活动1.1和1.2的最早开始时间均为第1天,给出所有活动的最早开始时间ES、最迟开始时间LS和浮动时间FT。

答案解析:

(1)从图中可以看出,该项目有8条路径可以走到终点,分别为:

  • ①start → 1.1(3) → 1.3(10) →1.4(10) → 2.1(15) → 2.2(20) → 2.3(10) → 2.4(10) → 2.5(8) → 2.6(5) → 2.7(6) → finish;
  • ②start → 1.1(3) → 1.3(10) →1.4(10) → 2.1(15) → 2.2(20) → 2.3(10) → 2.4(10) → 2.5(8) → 2.6(5) → 2.8(9) → finish;
  • ③start → 1.1(3) → 1.3(10) →1.4(10) → 2.1(15) → 2.2(20) → 3.1(12) → 3.2(15) → 3.3(9) → 3.4(18) → finish;
  • ④start → 1.1(3) → 1.3(10) →1.4(10) → 2.1(15) → 2.2(20) → 3.1(12) → 3.2(15) → 3.3(9) → 3.5(11) → 3.6(7) → finish;
  • ⑤start → 1.2(15) → 1.3(10) →1.4(10) → 2.1(15) → 2.2(20) → 2.3(10) → 2.4(10) → 2.5(8) → 2.6(5) → 2.7(6) → finish;
  • ⑥start → 1.2(15) → 1.3(10) →1.4(10) → 2.1(15) → 2.2(20) → 2.3(10) → 2.4(10) → 2.5(8) → 2.6(5) → 2.8(9) → finish;
  • ⑦start → 1.2(15) → 1.3(10) →1.4(10) → 2.1(15) → 2.2(20) → 3.1(12) → 3.2(15) → 3.3(9) → 3.4(18) → finish;
  • ⑧start → 1.2(15) → 1.3(10) →1.4(10) → 2.1(15) → 2.2(20) → 3.1(12) → 3.2(15) → 3.3(9) → 3.5(11) → 3.6(7) → finish。

8条路径如下图所示:
路径展示
可以计算出,每条路径的工期分别为:

  • ①3+10+10+15+20+10+10+8+5+6=97天;

  • ②3+10+10+15+20+10+10+8+5+9=100天;

  • ③3+10+10+15+20+12+15+9+18=112天;

  • ④3+10+10+15+20+12+15+9+11+7=112天;

  • ⑤15+10+10+15+20+10+10+8+5+6=109天;

  • ⑥15+10+10+15+20+10+10+8+5+9=112天;

  • ⑦15+10+10+15+20+12+15+9+18=124天;

  • ⑧15+10+10+15+20+12+15+9+11+7=124天。

综上所述,项目的关键路径有两条,分别为⑦和⑧,即1.2 → 1.3 →1.4 → 2.1 → 2.2 → 3.1 → 3.2 → 3.3 → 3.4 和 1.2 → 1.3 →1.4 → 2.1 → 2.2 → 3.1 → 3.2 → 3.3 → 3.5 → 3.6,工期为124天。

(2)计算步骤如下:

填充关键路径的浮动时间。已知关键路径的浮动时间都为0,所以路径⑦和⑧上的所有节点的浮动时间都为0;

计算剩余节点的浮动时间。

  • 由图可得,1.1 → 1.3需要时间为13天,而关键路径1.2 → 1.3需要25天,所以1.1的浮动时间为12天;
  • 关键路径的前半部分为1.2 → 1.3 →1.4 → 2.1 → 2.2,后半部分有4个分路,⑦和⑧为关键路径,且后半部分的工期为54天;(12+15+9+18=54天,12+15+9+11+7=54天)
  • ⑤和⑥的后半部分与关键路径的差额分别为54-39=15天,54-42=12天,那么此时可以确定2.7的浮动时间为15天,2.8的浮动时间为12天;(10+8+5+6=39天,10+8+5+9=42天)
  • 由图可知,2.7和2.8都需要经过2.3 → 2.4 → 2.5 → 2.6,在这种情况下,选择与关键路径差额小的值为浮动时间,即2.3 → 2.4 → 2.5 → 2.6与2.8的浮动时间相等。

计算最早开始时间。将每一项活动前面经过的路径(不包含当前活动)进行相加,如遇到分叉口则选择有经过关键路径上的节点

计算最迟开始时间。逆推,通过公式最晚开始时间 - 最早开始时间 = 浮动时间推出最迟开始时间。

项目活动的最早开始时间ES、最迟开始时间LS和浮动时间FT如下:

活动最早开始时间最晚开始时间浮动时间
1.111312
1.2110
1.316160
1.426260
2.136360
2.251510
2.3718312
2.4819312
2.59110312
2.69911112
2.710411915
2.810411612
3.171710
3.283830
3.398980
3.41071070
3.51071070
3.61181180
Finish1241240

由上述案例可以得出,通过关键路径可以判断出:

  • 开发时哪些活动必须等待;
  • 开发时哪些活动必须按进度进行防止拖延问题发生。

2、项目(进度计划)评估和评审技术(PERT,Program Evaluation and Preview Technique)

(1)定义

项目评估和评审技术是一种关键路径分析技术,使用正态分布来判断一个活动的最早开始时间接近该活动进度时间的概率。PERT技术可以计算关键路径、找出最可能成为瓶颈的活动。

注:项目评估和评审技术 (PERT) 的内容比关键路径还更为复杂一点,大家可以先理解关键路径,待我后面深学了再补充这一块知识。或者有小伙伴想补充的也欢迎私聊我哦~

五、获得值分析

获得值分析,主要分析两个内容进度是否拖延;成本是否超出预算。基于这两个内容,对获得值分析进行以下阐述。

1、基本量

(1)计划工作的预计成本(BCWS):截止到某一时刻,计划工作的预计工作量之和。

(2)完成预算(BAC): BCWS的总量,是项目的总工作量的估计。

(3)预定完成百分比:计划工作的预计成本占预计总工作量的百分比,计算公式为: B C W S B A C \\frac{BCWS}{BAC} BACBCWS

(4)完成工作的预计成本(BCWP):截止到某一时刻,完成工作的预计工作量之和。

(5)完成百分比:完成工作的预计成本占预计总工作量的百分比,计算公式为: B C W P B A C \\frac{BCWP}{BAC} BACBCWP

(6)所完成工作的实际成本(ACWP):截止到某一时刻,已完成的工作任务的实际工作量之和。

2、进度指示计算公式

(1)进度性能指标(SPI) = B C W P B C W S \\frac{BCWP}{BCWS} BCWSBCWP

(2)进度偏差(SV) = BCWP - BCWS;

(3)成本性能指标(CPI) = B C W P A C W P \\frac{BCWP}{ACWP} ACWPBCWP

(4)成本偏差(CV) = BCWP - ACWP。

总结:

  • 当SPI > 1,SV > 0,进度超前;
  • 当SPI = 1,SV = 0,进度正好;
  • 当SPI < 1,SV < 0,进度落后;
  • 当CPI > 1,CV > 0,成本节省;
  • 当CPI = 1,CV = 0,成本正好;
  • 当CPI < 1,CV < 0,成本超出预算。

3、案例分析

(1)案例一

下图是某工程的实际完成表。

工作任务估计工作量实际工作量估计完成日期实际完成日期(月日年)
15101/25/212/1/21
225202/15/212/15/21
3120802/25/21
440504/15/214/1/21
560507/1/21
680709/1/21

Question:在该工程实施过程中,截止到21年4月1号,进度是否拖延?工期是否超出预算?

Answer:

截止到21年4月1号,计划完成任务1、2,实际完成了1、2、4,由此可计算出 BCWSBCWPACWPBAC 的值。

  • 计划工作的预计成本 BCWS 为:5 + 25 = 30

  • 完成工作的预计成本 BCWP 为:5 + 25 + 40 = 70

  • 所完成工作的实际成本 ACWP 为:10 + 20 + 50 = 80

  • 完成预算 BAC 为:5 + 25 + 120 + 40 + 60 + 80 = 330

  • 那么预定完成百分比为: B C W S B A C = 30 330 \\frac{BCWS}{BAC} = \\frac{30}{330} BACBCWS=33030

  • 实际完成百分比为: B C W P B A C = 70 330 \\frac{BCWP}{BAC} = \\frac{70}{330} BACBCWP=33070

  • 进度性能指标 SPI 为: S P I = B C W P B C W S = 70 30 > 1 SPI = \\frac{BCWP}{BCWS} = \\frac{70}{30} > 1 SPI=BCWSBCWP=3070>1

  • 进度偏差 SV 为: S V = B C W P − B C W S = 70 − 30 = 40 > 0 SV = BCWP - BCWS = 70 - 30 = 40 > 0 SV=BCWPBCWS=7030=40>0

  • 成本性能指标 CPI 为: C P I = B C W P A C W P = 70 80 < 1 CPI = \\frac{BCWP}{ACWP} = \\frac{70}{80} < 1 CPI=ACWPBCWP=8070<1

  • 成本偏差 CV 为: C V = B C W P − A C W P = 70 − 80 = − 10 < 0 CV = BCWP - ACWP = 70 - 80 = -10 < 0 CV=BCWPACWP=7080=10<0

综上所述,因为 SPI > 1,SV > 0CPI < 1,CV < 0 ,所以截止到21年4月1日,该工程进度超前,成本超出预算。

(2)案例二

工作任务估计工作量实际工作量估计完成日期实际完成日期(月日年)
150701/25/212/1/21
235202/15/212/15/21
320405/15/213/1/21
440404/15/214/1/21
560106/1/21
680207/1/21

Question:若考察点在21年5月1日,此时任务完成进度如上图所示,问进度是否拖延?工期是否超出预算?

Answer:

截止到21年5月1号,计划完成任务1、2、3、4,实际完成了1、2、3、4,由此可计算出 BCWSBCWPACWPBAC 的值。