度量术语之二:应用类和开发类生产率(实际度量案例)

一个令人震惊的事实是连生产率这种常见度量数据都没有一个简单的定义。连我们日常经常用到的公式:生产率=工作产品/工作量(工作产品可以是代码行,功能点,也可以是任何可以计数的东西,比如文档页数)都是错误的。

如果你正常尝试使用生产率做度量,那么至少应该先分为下面两种度量数据。

注意下面的例子为了便于理解使用的是代码行,但实际上这两个概念是IFPUG(国际功能点用户组)对功能点计数时做的分类。

应用类数据 Application Type

下面这段对话将产生一个应用类度量数据:

A:“这个软件有多少代码行?”

B:“等我数一下……10000行”。

A:“多少人天开发出来的?”

B:“大约100人天吧”

A:“那么生产率=10000行/100人天=100行/人天”

这种生产率是按一个应用(Application这个词汇的来历)的静态规模度量产生的生产率,过一段时间会发生戏剧性的变化:

三个月后……

B:“我们又修改了一些代码,增加了一些代码,但是也删除了一些代码”

A:“哦?”

B:“多投入了100人天,不过现在还是10000行。”

A:“那么现在的生产率是:10000行/200人天=50行/人天;如果只算二期么……0,我也帮不了你了”

B:“好吧……二期算是白忙一场”

开发类数据 Development Type

A:“这个软件有多少代码行?”

B:“一共有两期……等我数一下……第一期100人天开发了10000行……第二期也是100人天,增加2500行,删除2500行,修改5000行”。

A:“那么一期生产率=10000行/100人天=100行/人天”

B:“二期呢?”

A:“二期生产率=(增加2500+删除2500+修改5000)/100人天=10000行/100人天=100行/人天”

B:“yeah!“

A:”不过,也有的体系说二期生产率=(增加2500+删除2500/2+修改5000)/100人天=8750行/100人天=87.5行/人天

B:”啊?“

A:”等下……还有体系说二期生产率=(增加2500+删除2500/4+修改5000/2)/100人天=……这个,你自己算吧。“

B:”好吧,总算比白忙一场好。“

如何使用?

场景一:计划与绩效考核=开发类数据

由于增删改都要花费工作量,所以用开发类数据做计划和考核更加公平一些。

不过,一般采用功能点更加合理一些,比如在重构中极有可能删除大段的代码(我们曾经在15分钟左右把4000行代码重构为55行,功能不变),而实际上应用的变化并不大。如果用这种外界(客户,高层)难以感受到的“变化”来做度量元,很难得到认同。

三种体系(增删改权值相同,或/2,或/2/4)选择哪个好呢?

我也不知道,因为这三种体系都有人在用。我的建议是:

1. 如果刚刚开始做度量

随便选择一个方法就好了,但是请记录下原始数据。

也就是说,要记住有多少新增,多少删除,多少修改。

2. 数据积累比较多了

请按三种方法都计算一次,然后对比一下计算结果和实际工作量的相关系数(相关系数日后会科普一下,Excel表里变有这个函数CORREL(B1:G1,B2:G2),相关系数越高表明用这种方法做估算更接近事实。

度量分析没有“理论上哪个最好”,只有数据本人才有发言权。

或者说,度量分析的本质就是消除各种理论的主观性、片面性、理想化,把发言权留给数据本身。所以自己做数据分析是免不了的事情。

场景二:需求变更控制

不过,不论有多少理由,一个软件只修改、删除功能而不增加功能,都不是一个正常的事情。

过多修改功能表明需求分析最初做的不好,而删除功能则表明做了过多的无用功能。

为了约束团队,防止他们把“改软件”当作工作,需要定期监控两者的比值:应用类/开发类,如果这个数据不断下降,表明大家都在修改之前的功能,很久没有大量增加功能了。

在小而美的产品研发中,修改功能可能是一个常态,但这不能作为开始可以不深入思考“最佳功能”的理由。

在项目开发尤其是外包项目中,只修改而不增加功能是一个灾难,因为客户多数时候不会为修改功能付费,他们认为这是因为乙方未能深入分析需求造成的。

场景三:编码有效性

也就是用多少代码能实现多少功能的问题,编码有效性越高,则所需代码越少。(日后有详细文章描述)

当然,这里的“功能”指国际标准功能点度量出来的功能,而不是我们平时所说的“个人理解不同规模也不同”的那种直觉功能。

在这种场景中,应该使用:编码有效性=总代码行/总功能点数=总代码行/应用类功能点数。

比如在之前那个例子中,第二期代码行可能还是10000行,但是如果功能点增加了,那么编码有效性实际上增高了。

完整示例

下面是一个功能点、代码行、编码有效性、应用类、开发类数据的完整应用场景。

A:“这个软件有多少代码行和功能点?”

B:“一共有两期……等我数一下……第一期100人天开发了10000行,200功能点……第二期也是100人天,增加2500行,删除2500行,修改5000行;增加50功能点,删除20功能点,修改30功能点”。

A:“那么一期代码行生产率=10000行/100人天=100行/人天,功能点生产率=200功能点/100人天=2功能点/人天”

B:“二期呢?”

A:“二期生产率=(增加2500+删除2500+修改5000)/100人天=10000行/100人天=100行/人天,功能点生产率=(增50+删20+改30)功能点/100人天=100功能点/100人天=1功能点/人天”(暂时只用第一种增删改权值算法)

B:“哪期项目做得快呢?“

A:“从代码行看,一样;从功能点看,一期项目快一倍。”

B:“以哪个为准好呢?”

A:“功能点好,比较容易给客户和领导交代”

B:“二期真烂。”

A:“也未必,你们的编码有效率提升了。”

B:“怎么讲?”

A:“二期完成后(不是二期开发本身),整个产品还是10000行,功能点却增加为300,你们现在的代码效率已经达到10000/300=33行/功能点了(越低越好,一期是10000/200=50)”

B:“生产率降低,编码有效性提高……怎么做整体评价呢?”

A:“生产率提高是终极目标,不过编码有效性的提升有利于未来的生产率和质量的提升。所以,现在总体评价是生产率下降了,未来要看你们以后是否能真正发挥编码有效率的优势了。”


怎么样?如果是我,如果能写一个由数字组成的项目报告,我才不会写一大堆模棱两可的文字呢。

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

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

相关文章

注解 @ModelAttribute 运用详细介绍

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到教程。1.ModelAttribute注释方法   例子(1),(2),(3&#x…

编程语言 IDE 对比

IDE是集成开发环境的英文缩写,所谓集成开发环境,就是将你在开发过程中所需要的工具或功能集成到了一起,比如代码编写、分析、编译、调试等功能,从而最大化地提高开发者的工作效率。每种编程语言都有一些特定的IDE,本文…

强制更新 maven 缓存

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到教程。 mvn dependency:purge-local-repository

程序员为什么那么难升职

一个有趣的现象是老程序员很难升职,如果你因为3K工资太低而要辞掉工作,你的上司宁可去外面找一个5K工资的新人,也不会来挽留你。那么程序员为什么那么难升职,这里总结了几点。你上司的问题你晋升困难,最大的主观原因在…

Docker 安装 Redis (Redis 配置)

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到教程。 获取 redis 镜像 docker pull redis 不加版本号默认获取最新版本,也可以使用 docker search redis 查看镜像来源 查看本地镜像…

百度首席科学家 Andrew Ng谈深度学习的挑战和未来

摘要:7月7日上午,百度首席科学家Andrew Ng应邀做客中国科学院自动化研究所并做了《Deep Learning:Overview and trends》的学术报告。 【编者按】人工智能被认为是下一个互联网大事件,当下,谷歌、微软、百度等知名的高…

Linux 安装 jdk ( 两种方式 )

安装jdk有两种方法:手动安装 yum安装。 方式一: yum安装 1、查询要安装jdk的版本, 命令:yum -y list java* 2、安装jdk1.8 yum install -y java-1.8.0-openjdk.x86_64 3、查询jdk版本:java -version 这样就安装成功了。默认…

在动态网络下实现分布式共享存储

摘要:本文介绍了分布式环境下实现共享内存模型会遇到的各种问题和挑战,并针对不同问题介绍多种算法的优劣性。本文是对现阶段该领域研究现状的总体介绍,通过本文能了解动态分布式共享内存研究的前沿状况、挑战与机遇。 共享内存系统是普通单…

集合拷贝通用方法、list<A> 转换成 list<B> (属性相同)

拷贝2个拥有相同属性的集合实现: 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到教程。 package com.hydbest.app.lbd.marketing.common.utils;import com.alibaba.fastjson.JSON…

Linkedln技术高管Jay Kreps:Lambda架构剖析

摘要:Jay Kreps是Linkedln的一名在线数据架构技术高管,在日常工作中,Jay Kreps经常被问及有关Lambda架构的问题,为此他结合实际经验和个人体会,针对Lambda架构进行深度剖析,分析了它的优缺点以及采用的替代…

JWT ( JSON Web Token ) 入门教程

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到教程。 一、跨域认证的问题 互联网服务离不开用户认证。一般流程是下面这样。 1、用户向服务器发送用户名和密码。 2、服务器验证通过后&#x…

优秀程序员必备的15大技能

编程是个很复杂的玩意,但是成就优秀程序员的很多因素和我们在学校中早期学到的相差无几。本文灵感来源于Robert Fulghum的《All I Really Need to Know I Learned in Kindergarten》。 1.分享 尽可能地使用开源,并且如果有能力的话也可以把自己的成果分…

注解 @Target 用法

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到教程。 Target: Target说明了Annotation所修饰的对象范围:Annotation可被用于 packages、types(类、接口、枚…

软件开发者如何准备未来?

摘要:现今,科技领域技术更新非常迅速,作为该领域幕后勤恳劳作的软件开发者要想在其中永远保持领先,跟得上时代,就需要时刻面向未来做好准备。但面对各种技术各种开发语言,软件开发者该如何做? …

java 并发包之 LongAdder 源码分析

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到教程。 LongAdder是java8中新增的原子类,在多线程环境中,它比AtomicLong性能要高出不少,特别是写多的场景。…

JAVA 内存模型 (Java Memory Model,JMM)

JAVA内存模型 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到教程。 Java内存模型(Java Memory Model,JMM) 是在硬件内存模型基础上更高层的抽象&#xf…

解决:java.lang.ArithmeticException: Non-terminating decimal expansion; no exact representable decimal

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到教程。 报错如下: java.lang.ArithmeticException: Non-terminating decimal expansion; no exact representable decimal result.…

解决:Command line is too long. In order to reduce its length classpath file can be used.

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到教程。 1. 原本可以正常运行的项目,突然出现这个错: Command line is too long. In order to reduce its length class…

性能提升利器之固态硬盘和序列化漫谈

摘要:假设我们已经构建了下一个杀手级应用,而且变得越来越受欢迎,突破负载极限,以我们目前的增长的速度,需要在3个月内将需要将性能提升10倍。我们该怎么做? 【编者按】当面对一个性能扩展问题时&#xff…

查看本机IP的方法

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到教程。 1. 打开网络和共享中心 2.更改适配器设置 3. 右键选择 状态 4.选择详情 5.找到IP