「软件项目管理」一文详解软件项目进度计划

软件项目进度计划

  • 序言
  • 一、进度及任务的定义
    • 1. 进度
    • 2. 任务
    • 3. 产品和任务的关系
  • 二、任务关联关系
    • 1. 定义
    • 2. 任务(活动)之间的关系
    • 3. 任务关系矩阵
    • 4. 任务关联关系的依据
  • 三、进度管理图示
    • 1. 甘特图
    • 2. 网络图
      • (1)定义
      • (2)常用的网络图
        • Ⅰ. PDM(Precedence Diagramming Method)
        • Ⅱ. ADM(Arrow Diagramming Method)
    • 3. 里程碑图
      • (1)定义
      • (2)图例
    • 4. 资源图
      • (1)定义
      • (2)图例
    • 5. 燃尽图
      • (1)定义
      • (2)图例
    • 6. 燃起图
      • (1)定义
      • (2)图例
  • 四、任务历时估计
    • 1. 定义
    • 2. 历时估算的基本方法
    • 3. 定额估算法
      • (1)公式
      • (2)举例
    • 4. 经验导出模型
      • (1)公式
      • (2)举例
    • 5. PERT(工程评估评审技术)
      • (1)定义
      • (2)计算
      • (3)举例
      • (4)PERT的风险指标
    • 6. Jones的一阶估算准则
      • (1)定义
      • (2)幂次表
      • (3)举例
  • 五、进度计划编排
    • 1. 关键路径法
      • (1)CPM基本概念
      • (2)ES、EF、LS、LF关系图
      • (3)浮动时间
      • (4)总浮动与自由浮动
      • (5)关键路径(Critical Path)
      • (6)计算
    • 2. 时间压缩法
      • (1)定义
      • (2)方法
      • (3)应急法
        • Ⅰ. 定义
        • Ⅱ. 压缩时间与追加成本关系图
        • Ⅲ. 关于进度压缩与费用增加的关系
      • (4)进度压缩单位成本方法
        • I. 定义
        • II. 计算
        • III. 最短进度
      • (5)Charles Symons(1991)方法
        • I. 计算公式
        • II. 举例
      • (6)平行作业法
    • 3. 资源优化法
      • (1)方法
      • (2)资源平衡法
      • (3)资源平滑法
  • 六、结束语
  • 专栏传送门

序言

在软件项目中,其中尤为重要的一个内容是进度计划。比如说,某个功能模块开发的周期时间,或者是某个功能模块的开始时间和截止时间,这些都需要良好的进度计划来对其进行安排。

同时,按时完成项目是项目经历最大的挑战之一,时间是项目规划中灵活性最小的因素,且进度问题是项目冲突的主要原因

因此,学好软件项目进度计划,对于每一个开发人员来说不可或缺。

下面就开始今天文章的讲解~

一、进度及任务的定义

1. 进度

所谓进度,是对执行活动和里程碑制定的工作计划日期表

2. 任务

所谓任务,是为了完成项目的各个交付成果所必须进行的各项具体活动

3. 产品和任务的关系

产品和任务的关系如下图所示:

产品和任务的关系

二、任务关联关系

1. 定义

所谓任务关联关系,就是项目各项活动之间存在相互联系相互依赖关系。之后,根据这些关系安排任务之间的顺序

2. 任务(活动)之间的关系

任务(活动)之间的关系如下图所示:

任务之间的关系

3. 任务关系矩阵

如下图所示:

任务关系矩阵

4. 任务关联关系的依据

有以下4种关系:

  • 强制性依赖关系
  • 选择性依赖关系
  • 外部依赖关系
  • 内部依赖关系

三、进度管理图示

1. 甘特图

甘特图有两种类型,分别是:

  • 棒状甘特图

  • 三角形甘特图

2. 网络图

(1)定义

  • 网络图是活动排序的一个输出
  • 展示项目中各个活动活动之间的逻辑关系

(2)常用的网络图

Ⅰ. PDM(Precedence Diagramming Method)

PDM ,即优先图法,是一种节点法(单代号)网络图具体图例如下:

PDM图例


下面我们来看一下 PDM 的特点:

  • 构成 PDM 网络图的基本要素是节点(BOX)
  • 节点(Box) 表示活动(任务)
  • 箭线表示各活动(任务)之间的逻辑关系
  • 可以方便的表示活动之间的各种逻辑关系

现在我们用 PDM 来演示下某个项目的流程具体如下:

PDM项目图例

Ⅱ. ADM(Arrow Diagramming Method)

ADM,即箭线法,是一种箭线法(双代号)网络图具体图例如下:

ADM图例

下面我们来看一下 ADM 的特点:

  • ADM 也称为双代号项目网络图
  • 箭线表示活动(任务)
  • 两个代号唯一确定一个任务
  • 代号表示前一任务的结束,同时也表示后一任务的开始

下面我们来了解 ADM 中的虚活动。虚活动主要用途为:

  • 为了定义活动
  • 为了表示逻辑关系
  • 不消耗资源

具体图例如下:

虚活动图例

3. 里程碑图

(1)定义

里程碑事件的定义为:

  • 时间要求为 0 的任务
  • 不是一个要实实在在完成的任务
  • 是一个标志性的任务

(2)图例

具体图例如下:

里程碑图例

4. 资源图

(1)定义

资源图,用来显示项目进展过程中资源的分配情况

(2)图例

资源图图例如下:

资源图图例

5. 燃尽图

(1)定义

燃尽图,描述随着时间的推移剩余的工作数量,可表示开发进度。

(2)图例

燃尽图图例如下:

燃尽图图例

6. 燃起图

(1)定义

燃起图,描述随着时间的推移已完成的工作数量,可表示开发进度。

(2)图例

燃起图图例如下:

燃起图图例

四、任务历时估计

1. 定义

所谓任务历时估计,即估计任务的持续时间

2. 历时估算的基本方法

历时估算的基本方法包含 4 种,分别是:

  • 定额估算法

  • 经验导出模型

  • PERT(工程评估评审技术)

  • Jones的一阶估算准则

下面将依据这几种基本方法进行一一讲解。

3. 定额估算法

(1)公式

定额估算法的公式为:T=Q/(R*S)

其中: T 为活动历时; Q 为任务工作量; R 为人力数量; S 为工作效率(贡献率)。

(2)举例

例子①:

假设Q=6人天,R=2人,S=1。所以:T=3天

例子②:

假设Q=6人天,R=2人,S=1.5。所以:T=2天

4. 经验导出模型

(1)公式

定额估算法的公式为:D=a*Eb

其中: D 为进度(已月为单位); E 为工作量(以人月为单位); a 的范围在 2-4 之间; b 的值在 1/3 左右,依赖于项目的自然属性。

(2)举例

假设: 导出模型D=3*E1/3,E=65人月,请计算出D值。

解: D=3*651/3=12月

5. PERT(工程评估评审技术)

(1)定义

  • PERT,即 Program Evaluation and Review Technique
  • 它是利用网络顺序图的逻辑关系加权历时估算来计算项目历时,适用于估计历时存在不确定时。
  • 它是基于对某项任务的乐观悲观以及最可能的概率时间来估计。

(2)计算

PERT采用加权平均得到期望值 E=(O+4M+P)/6 ,其中:

O 是最小估算值:乐观(Optimistic);

P 是最大估算值:悲观(Pessimistic);

M 是最大可能估算(Most Likely);

(3)举例

假设现有某项目,乐观值是8天,最大可能值是10天,悲观值是24天。采用 PERT 方法,计算出其加权期望值 E

解: 加权平均期望值 E8+4×10+246=12天\frac{8+4×10+24}{6}=12天68+4×10+24=12

(4)PERT的风险指标

标准差δ =(最大估算值-最小估算值)/6

方差δ2 = [(最大估算值-最小估算值)/6] 2

6. Jones的一阶估算准则

(1)定义

  • 估算项目功能点
  • 从幂次表中选择合适的幂次来将功能点升幂

(2)幂次表

Jones一阶估算准则的幂次表如下表所示:

软件类型最优级平均最差级
系统软件0.430.450.48
商业软件0.410.430.46
封装商品软件0.390.420.45

(3)举例

假设现有某平均水平的商业软件,其功能点为 FP=350 。请计算出其粗略的进度。

解:粗略的进度=3500.43=12月

五、进度计划编排

1. 关键路径法

(1)CPM基本概念

  • 最早开始时间 Early start
  • 最晚开始时间 Late start
  • 最早完成时间 Early finish
  • 最晚完成时间 Late finish
  • 总浮动 Total Float
  • 自由浮动 Free Float
  • 超前 Lead
  • 滞后 Lag

(2)ES、EF、LS、LF关系图

对于 ESEFLSLF 这四个概念来说,它们之间的关系如下图所示:

ES、EF、LS、LF关系图

(3)浮动时间

浮动时间是一个任务的机动性,它是一个任务在不影响其它任务或者项目完成的情况下可以延迟的时间量

(4)总浮动与自由浮动

  • 总浮动(Total Float)是,在不影响项目最早完成时间的前提下,一个任务可以延迟的时间。

  • 自由浮动(Free Float)是,在不影响后置任务最早开始时间的前提下,一个任务可以延迟的时间

(5)关键路径(Critical Path)

  • 时间浮动为 0 (Float=0) 的路径
  • 网络图中最长的路径
  • 关键路径是决定项目完成的最短时间
  • 关键路径上的任何活动延迟,都会导致整个项目完成时间的延迟
  • 关键路径可能不止一条

(6)计算

关于关键路径的计算,查看这篇文章:软件项目进度安排与跟踪,一招学会计算关键路径

2. 时间压缩法

(1)定义

时间压缩法,即在不改变项目范围的前提下缩短项目工期的方法。

(2)方法

一般有两种方法,具体为:

  • 应急法——赶工(Crash)
  • 平行作业法——快速跟进

下面将依据这两种方法来进行一一详述。

(3)应急法

Ⅰ. 定义

  • 最小相关成本增加的条件下,压缩关键路径上的关键活动历时的方法
  • 赶工也称为时间-成本平衡方法

Ⅱ. 压缩时间与追加成本关系图

压缩时间与所追加成本的关系图如下所示:

压缩时间与追加成本的关系图

Ⅲ. 关于进度压缩与费用增加的关系

  • 进度压缩单位成本方法(时间成本平衡法)——线性关系
  • Charles Symons(1991)方法(进度压缩因子方法)——进度压缩比普通进度短的时候,费用迅速上涨

下面将依据这两种方法来进行一一讲解。

(4)进度压缩单位成本方法

I. 定义

前提条件:活动的正常与压缩

  • 项目活动的正常值 —— 正常历时和正常成本
  • 项目活动的压缩值 —— 压缩历时和压缩成本

II. 计算

计算公式: 进度压缩单位成本=(压缩成本-正常成本)/(正常进度-压缩进度)

例如: 假设现有任务A,正常进度7周,成本5万;压缩到5周的成本是6.2万。

解: 那么进度压缩单位成本为:(6.2-5)/(7-5)=6000元/周=0.6w/周

如果压缩到 6 周的成本是:5+0.6=5.6万

III. 最短进度

项目存在一个可能的最短进度,如下图所示:

最短进度

(5)Charles Symons(1991)方法

I. 计算公式

进度压缩因子=压缩进度/正常进度

压缩进度的工作量=正常工作量/进度压缩因子

II. 举例

例如: 初始进度估算是12月,初始工作量估算是78人月,如果进度压缩到10月,请计算出其进度压缩因子和压缩进度的工作量。

解: 进度压缩因子= 10/12=0.83 ,则进度压缩后的工作量是:78/ 0.83=94人月

总结: 进度缩短17%,增加21%的工作量。

研究表明: 进度压缩因子 >0.75 ,最多可以压缩 25%

(6)平行作业法

平行作业法,即改变活动间的逻辑关系,并行开展某些活动。

3. 资源优化法

(1)方法

资源优化有两种方式:

  • 资源平衡法(可能会导致关键路径的改变)
  • 资源平滑法(可能无法实现所有资源的优化)

(2)资源平衡法

资源平衡法,即资源优化配置,形成最有效的利用资源。目的在于使资源闲置的时间最小化尽量避免超出资源能力

(3)资源平滑法

假设现有某项目具体活动周期如下:

活动周期

用资源平滑发分配的话,有以下两种方式:

第一种:所有活动都在同一天开始

资源平滑法第一种

第二种:活动C延迟两天进行

资源平滑法第二种

六、结束语

在上面的文章中,我们讲解了软件项目中的进度计划。从各方面剖析进度计划的各项内容。

到这里,关于本文的介绍就结束啦!如果文章对您有帮助,记得留个jio再走哦~

专栏传送门

软件项目管理👉juejin.cn/column/7024…

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/307800.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

过年烟花特效

一:前言 过年了 菜鸡杰 在这给CSDN的伙计们拜年了 这一段时间以来 我特别感谢 我的粉丝 正是因为有你们的陪伴 所以我才会很大动力 去写博客,所以我就准备了一个特效给粉丝们 现在过年不让放烟花 我就改了个代码 改成烟花特效 送给大家 二:特效描述 这…

「软件项目管理」一文详解软件项目质量计划

一文详解软件项目质量计划🎩前言👒一、质量概述1. 质量与软件质量2. 质量成本二、质量模型1. 定义2. 几种模型3. 模型解读(1)Bohem质量模型(2)McCall质量模型(3)ISO/IEC 9126质量模型…

WSL2 支持挂载物理磁盘,Windows 可直接访问 ext4

喜欢就关注我们吧!最新的 Windows Insiders Preview Build 为 WSL2 的命令行程序增加了新功能:wsl --mount,这个新参数支持在 WSL2 添加和挂载物理磁盘,用户通过它能访问 Windows 没有原生支持的 Linux 文件系统(例如 …

2招解决并发问题,省几百万设备费用!说穿了很简单...

经大佬介绍,接了个技术顾问的私活儿,3天搞定报酬8000,Mark一下,也分享下经验心得。(经大家要求,文末增加了一段接私活儿经验)背景交代甲方是广东某国企信息部,美其名曰是邀请技术顾问…

「软件项目管理」一文详解软件配置管理计划

一文详解软件配置管理计划前言一、配置管理概述1. 配置管理(SCM)定义2. 软件配置项目(SCI)3. 基线4. 软件配置控制委员会(SCCB)二、软件配置管理过程1. 管理过程2. 管理过程解析(1)配置项标识、跟踪I. 定义II. SPM项目要求&#x…

Kubernetes探针踩坑记

1. 荒腔走板最近一两个月生产K8s集群频繁出现短时503 Service Temporarily Unavailable,还不能主动复现,相当郁闷,压力山大。HTTP 5xx响应状态码用于定义服务端错误。500 Internal Server Error:所请求的服务器遇到意外的情况并阻…

「软件项目管理」一文了解软件项目团队计划

一文了解软件项目团队计划序言一、人力资源计划1. 团队定义2. 项目组织结构(1)职能型(2)项目型(3)矩阵型3. 责任分配矩阵二、项目干系人计划1. 干系人定义2. 干系人识别3. 干系人参与分类4. 干系人参与评估…

leetcode40. 组合总和 II

一:题目 二:上码 class Solution { public:/**思路:1.题目中说的每个数字只在每个组合中使用一次的话 我们可以考虑 在递归遍历的时候 index1不断缩小范围(因为这也是在一个大的集合中挑选小的集合,所以是需要记录index的)2.但是我们在填写…

DDD:架构思想的旧瓶新酒?阿里等大厂却对它趋之若鹜!

4月,InfoQ 发布了软件架构与设计的趋势报告。在报告中可以看出,微服务、领域驱动设计等已经非常流行,并成为目前软件开发行业的主流趋势。大家都知道,微服务划分的一个重要理论基础就是领域驱动设计。但由于 DDD 门槛高、概念多&a…

「软件项目管理」一文浅谈软件项目风险计划

一文浅谈软件项目风险计划序言一、风险基本概念1. 风险的定义及特性2. 风险三要素3. 风险图示3. 风险类型(1)预测角度(2)范围角度二、风险管理过程三、风险识别1. 定义2. 风险识别方法3. 风险条目检查表之七个条目四、风险评估1. …

.NET Core 下使用 gRPC

gRPC 是一种与语言无关的高性能远程过程调用 (RPC) 框架。https://grpc.io/docs/guides/https://github.com/grpc/grpc-dotnethttps://docs.microsoft.com/zh-cn/aspnet/core/grpc“gRPC 的主要优点现代高性能轻量级 RPC 框架。协定优先 API 开发,默认使用协议缓冲区…

leetcode93. 复原 IP 地址

一:每日论语解读 follow me !! 君子坦荡荡 小人常威威 二:题目 三:上码 class Solution { public:/**思路:1.分析题意本题依然是切割字符串(我们需要对要分割的字符串做出处理 需要判断我们截取的字符串是否合法)2。关于‘.’的处理 我们是在原字符串的基础上进…

ASP.NET Core整合Zipkin链路跟踪

前言在日常使用ASP.NET Core的开发或学习中,如果有需要使用链路跟踪系统,大多数情况下会优先选择SkyAPM。我们之前也说过SkyAPM设计确实比较优秀,巧妙的利用DiagnosticSource诊断跟踪日志,可以做到对项目无入侵方式的集成。其实还…

探秘react,一文弄懂react的基本使用和高级特性

一文详解react的基本使用、高级特性和周边插件⏰序言📝一、React的基本使用1、JSX基本使用(1)变量、表达式(2)class和style(3)子元素和组件(4)原生 html2、条件判断&…

使用React hooks,些许又多了不少摸鱼时间

一文详解react-hooks🎙️前言一、📻概述1、关于React Hooks2、认识React Hooks(1)回顾React函数式组件(2)函数组件的特点(3)class组件的问题(4)React 组件二、…

手把手教学之如何设计财务对账系统

在设计一个对账系统前,我们先想清楚,对账目的、方式、对账场景、使用对象。其次就是和财务了解一下,他们所期望的效果,毕竟他们是使用方。财务对账是一个琐碎而复杂的工作,极需要工作耐心和细心,还要求对账…

不平凡的2021,末流普本生秋招上岸大厂的历程

📻叮! 2021年接近尾声,周一也开始拾起了年终总结。 回顾2021,有喧嚣,也有欢呼;有奔溃,也有快乐。 但好在✏️ 对待一件又一件的小事上,始终保持着对自己的要求📊 不…

leetcode491. 递增子序列

一&#xff1a;论语 二:题目 三&#xff1a;上码 class Solution { public:vector<vector<int> >ans;vector<vector<int> >ans1;vector<int> path;void backstacking(vector<int>& nums,int index) {if(path.size() > 2) {ans.pus…

送福利 | 送书5本《ASP.NET Core项目开发实战入门》带你走进ASP.NET Core开发

《ASP.NET Core项目开发实战入门》从基础到实际项目开发部署带你走进ASP.NET Core开发。ASP.NET Core项目开发实战入门是基于ASP.NET Core 3.1 所写&#xff0c;后续ASP.NET Core 5也会对应更新。简介本书共14章&#xff0c;深入浅出地介绍了ASP.NET Core基础及项目开发方面的知…

海有舟可渡、山有路可循‍‍ —— 大学四年圆满落幕

⛺️前言 仅以此篇文章记录我的大学四年&#xff01; 回忆大学四年&#xff0c;有惊喜、有快乐、有崩溃、有欢呼&#xff1b; 有过无数个为了赶策划、赶ddl的熬夜&#xff0c;更有凌晨2点做志愿活动、凌晨5点赶项目的通宵达旦。 梳理下大学四年的大事件&#xff1a; 大一 …