写点什么

#NoEstimates 作者问答

  • 2016-01-07
  • 本文字数:5852 字

    阅读完需:约 19 分钟

软件行业不好估算。Vasco Duarte 建议我们应该专注影响和价值而不是产量,以便使项目取得成功。在 NoEstimates:How to Measure Project Progress Without Estimating这本书中,他探讨了无估算如何帮助管理项目的同时专注价值和可预测性,如何帮助快速和频繁汇报工作进展,和基于现有数据不断调整计划。

InfoQ 有幸采访了 Vasco Duarte,关于 #NoEstimates 是如何开始的;使用估算技术试图解决什么;什么使得估算如此的困难;如何使用 #NoEstimates 计划项目和跟踪进度;并举例说明了 #NoEstimates 如何帮助专注价值和人们可以从哪里获取更多有关 #NoEstimates 的信息。

InfoQ:你能告诉我们 #NoEstimates 是从哪里以及如何开始的?

Duarte:大约 2011-2012 年,我正在为 OOP2012 准备“故事点是有害的”演讲。作为这项工作的一部分,我开始在 #estwaste 标签下发推特,并且同时 Neil Killick 和 Woody Zuill 开始发类似话题的推特。最早记录在案的有关 #NoEstimates 的推特是 Woody Zuill 发出的,并且之后这个话题在推特上瞬间起飞。我有数个有关这个话题的 Skype 讨论,Woody Zuill 就此话题通过 Skype 采访了超过 100 人。很明显人们对此话题感兴趣。我在 #EstWaste(用于估算是一种浪费)原标签下发的推特从来没有真正起飞,但是 #NoEstimates 这么一个简单的标签却在我们行业启动了一场引领需求的谈话。

从推特上仍然活跃的对话(3 年后!)中我们可以看出我们解决了软件行业一个真正的问题。到目前为止,仍然有许多人在标签 #NoEstimates 下发推特,并且许多会议仍在讨论此话题。在软件行业有一个社区聚集在这一非常重要的话题周围。

InfoQ:在你看来,项目为什么使用估算,他们试图用估算解决什么问题?

Duarte:通过使用被我们称为估算的工具解决了很多问题,就是这么简单:一个工具,没有别的。你提的问题非常重要,因为一旦我们确定了问题,或者确定了我们试图解决的问题,如果工具(估算)适合我们,我们就可以做出明智的评估。

到目前为止,我已经设计和举办了多场研讨会:“#NoEstimates:专注真正重要的事情”,并多次询问参与者这个问题。答案从明显的:“为了了解项目什么时候可以交付”到可预测的:“为了计算项目的 ROI(投资回报率)”。问题是这些答案没说全,他们忽略了使用估算作为工具来回答这些问题背后的假设。他们假设估算在大规模应用中(在整个 IT 行业)是可靠的,但是,这不符合我们看到的实际情况。被大量引用的 CHAOS 报告报道了,年复一年项目是如何延期并超出预算的。为了辩解,许多人会说:“项目不应该通过是否准时、是否符合预算进行评分,还应该有其它因素,一些更重要的变量”。我同意。按时、按预算不是项目是否成功的主要因素。在一个案例中,虽然项目被延期了 200%,但是当发布时,项目带来的影响完全改变了公司,它帮助公司开拓了新市场,创造了新的商业模式并且现在创造的收入大约占公司收入的 50%。计划很重要吗?可能,但是肯定不如公司试图交付的“价值”那么重要。最后,价值胜过准时、按预算的考量(在某点上),而这是我不断在我的 #NoEstimates 演讲和研讨会上强调的一个关键因素:专注价值,基于价值做决策而不是估算。估算不是项目是否成功的好的预测工具。

InfoQ:什么使得估算如此的困难?人们估算不好的原因是什么?

Duarte:我说不好什么使得估算如此困难。但是大多数人都知道确实如此。每天我们的工作中都会遇到这样的情况。多份调查统计同样支持估算很困难的主张。我们看看这个小例子。

  • “被调查的大型系统完成时,大约有 66% 的经验计划被延误 & 成本超支”,出自 Capers Jones 发表在 Crosstalk, the Journal of Defense Software Engineering 上的“Project Management Tools and Software Failures and Successes”。
  • 2011 年,CHAOS 报告中被调查项目的平均延误率是 63%。这个数字与我 2003 年在一个软件开发公司做的私人调查一致:被调查的 17 个项目的平均延误率是 62%,并且最大项目的延误率是 200%。
  • Scott Ambler 在软件行业做了一次有关项目成功率的调查。他的数据表明2013 年以来 53% 的传统项目都失败了(没有交付解决方案)或者受到挑战(项目成功满足成功标准)。

从不同渠道的其他调查中我们也能发现类似的结果。这些例子证明一件事:作为一个行业我们不善于估算。当然,有些人会声称他们是特级预测师,但是特级已经暗示大部分人都不是特级。我们需要建立一个有道德、负责任的软件开发方法,而估算不是一个好的工具,因为他们未能交付承诺(知道可接受范围内的时间 / 成本),并且在组织内催生了许多不同的功能障碍。在本书中,我解释了其中一些功能障碍,比如:估算谈判(estimate bargaining),政治游戏等等。

InfoQ:#NoEstimates 是否意味着你不该做任何估算?估算是有害的吗?

Duarte:是的也不是的。#NoEstimates 是一个原则性的方法,用来解决我们行业里的一个特定问题:为了理解和能够按照项目成本和时间工作,人们应该使用估算的替代方案。当你在特定环境中应用 #NoEstimates 原则时,你可能仍然会拿估算作为走向下一阶段 #NoEstimates 的踏脚石。我在本书中解释了这一情况,并将其描述成“走向 #NoEstimates 的 7 步旅程”。

在我的印象中,估算很少用到,即使需要它们只是指向另一个我们应该解决的功能障碍。在这种情况下,消除估算才是真正的目标。但是就像丰田公司为浪费设计的多层次方法(不必要的浪费和必要的浪费),我们也必须为估算设计一种方法。有时我们必须接受估算,但是我们应该努力设法消除估算的需求。这是有可能实现的,并且我已经帮助过许多团队和组织完全消除这种需求。在本书的后面章节中,我们将跟随 Carmen——#NoEstimates 故事中的英雄——因为她发明了一些方法可以消除估算的浪费,同时还能够回答一些客户会问的关键业务问题,比如“我们能否按时发布这一特性?”

InfoQ:你为什么强调选择最重要的工作高于基于估算的优先级项目?

Duarte:这个问题非常重要,也许值得出本书。简单来说,项目列表的优先级预先假设了列表中的所有项目都是必要的。但是事实往往并非如此。正如我们知道的许多我们最终交付的项目功能其实客户很少甚至根本没有使用过。然而,这些不必要的项目也需要时间和精力来开发,并且在某些情况下,大大增加了我们项目的风险。优先级假设 Backlog 中的所有项目都是必须的。我不会做这种假设。因此我帮助我的客户了解他们的商业模式,然后谨慎地探索如何利用或者放大成功的商业模式。要做到这一点,你需要专注选择具有重要影响力的试验(特性或者故事),而不是盲目地交付一连串详细的需求列表。这样可以一心一意专注“影响”(或者成果)而不是产量(我们能够交付多少故事),这种专注允许我们发现项目的真正价值。这就是为什么我更喜欢讨论选择影响最大的项目,并快速交付,而不是在一连串的需求列表中讨论#34 与#35 相比哪个更有优先级。

InfoQ:你如何使用 #NoEstimates“计划”项目?

Duarte:这个问题非常好,因为它清晰地揭露了 #NoEstimates 辩论中最重要的谬论之一。#NoEstimates 批评家经常说你不能计划除非先估算。当然,这完全是错误的。估算是“评估”计划大小的工具,在进行估算之前,你需要先构建计划。比如,我们不需要估算故事也可以轻易决定哪些故事应该纳入 Srpint。我工作过的许多团队都会基于目标往 Sprint 中添加故事,甚至都不评估故事大小。当他们开始执行这些故事时,他们会与 Sprint 目标进行比较,不断地重新评估他们的现状,并会向 Sprint 中添加或者删除故事,以便帮助他们完成 Sprint 目标。目标可以是:提高 X 的性能,以实现每秒 500 次的事务。这种目标没有规定“如何做”,仅仅规定了“为什么”。我们会因为目标而决定是否向 Sprint 中添加或者删除故事,而不是因为其它原因。

上面的 Sprint 案例说明了在 Sprint 阶段你如何将估算和计划分开。在项目阶段同样可以做到。许多我一起合作过的客户他们有着必须继续运行的业务或者必须达到的商业目标。与其致力于交付一组特定的特性或者故事,以实现这些目标,相反他们做持续计划。我们在一开始就定义项目的目标,定义项目的投资(预算,而不是估算),然后在约束条件内(可能是时间,金钱或者两者)持续管理范围,实现交付目标。

这种培养方案专注价值和持续交付价值,这些我会在下文进一步解释。

InfoQ:你如何使用 #NoEstimates 跟踪进度?

Duarte:在本书中,我详细描述了如何跟踪进度并对干系人透明进度。简单来说,我计算已经交付的项目数量,并与 Backlog 中的项目数量进行比较。人们常做的一个假设是,你需要知道项目清单的完成情况,从而跟踪进度。然而在实践中,除非到项目后期,我们很少能够知道“所有的项目”。范围蔓延(或者我称之为:价值发现)是任何软件开发项目的自然过程。随着我们开发项目,我们会发现更多的价值,理所当然我们也希望交付新发现的项目。

因此,我从来不认为范围是固定的,或者 Backlog 已完成。我计划(预测)未来交付率(已交付项目除以已交付项目花费的时间)并评估在剩余可用时间内我们能够交付的项目数量。不可避免地,在某个时间点 Backlog 中剩余的项目数量大于基于我们交付率能够交付的项目数量。这时,我们就要启动项目最关键的对话:我们应该交付哪些项目?我们应该从 Backlog 中移除哪些项目?我称这个过程为:持续范围管理,在这本书中我称其是软件项目管理最重要的工具。很多人会认为这是个艰难的对话,充满了艰难的期望管理。我同意,但是这种类型的对话有助于我们专注价值,持续交付价值。简单来说,与一个不可避免的脆弱的计划相比,我用这种方法促进价值交付对话,而不是度量产量。遵循计划(我们估算的结果)是一种脆弱的软件项目管理方法。如果我们希望在软件开发方法中实现敏捷,我们必须建立反脆弱的项目管理方法,而 #NoEstimates 是这些方法之一。

InfoQ:你声称 #NoEstimates 有助于团队和组织专注有价值的内容,但是在实践中它是如何实现的?

Duarte:在前面的问题中,我提到过唯一一个工具:持续范围管理,有助于我们按时交付软件项目。但是探讨为什么持续范围管理是必要的非常重要。其中一个重要原因是当我们开始开发软件时,我们能够更好地了解为了交付我们需要什么。在我们进行开发、论证和获取反馈的时候,有关正确功能的新思路出现了,比如有价值的功能。我们称这种发现的价值为“范围蔓延”,随着范围不断的攀升,当最终我们注意到的时候,我们已经遇到太多需要交付的项目。我不喜欢“范围蔓延”这个术语,因为它隐藏了现象的真正本质:在我们交付原计划的价值的过程中,我们发现了其它价值。遵循原计划(在一组明确定义的功能的基础上进行的估算),那么我们就会将价值发现看成是范围蔓延,并忽略这一价值。而且还会有一个很好的理由:接受所有的变化将会使得项目错过截止日期。在估算驱动的软件开发中,计划和时间表优于新发现的价值,而这会在估算驱动的软件开发中导致一个功能障碍。

我采取了不同的方法,我帮助团队在限定的时间和投资箱内工作,但是同时不断调整范围,以提供更多的价值。为此我们使用我在 _#NoEstimates_ 书中描述的预测方法,这样我们可以放心地改变项目范围,以实现增量交付更多价值,而不是试图遵循原计划。预测方法的副作用是它在项目初期阶段引入持续范围管理,多亏了预测技术,我们从一开始就能管理范围。另一种方法将会不断地重新评估我们发现的一切,和计划中的每个变化。这显然是一种浪费,尤其是当我在演讲中提出了另外一种方法(基于数据的预测),可以给我们接近 100% 的准确度等级的时候(这些演讲你可以在 YouTube 上找到)。

InfoQ:人们可以从哪里学到更多有关 #NoEstimates 的信息?

Duarte:如果你想开始了解更多的 #NoEstimate,这里有很多资源,Woody Zuill 在他的网站上收集了多位作者的博客列表。我也从多位作者那里收集了“入门指南”的文章集合。对于那些有兴趣深入研究如何应用 #NoEstimate 思想的人,我写了这本 _#NoEstimate_ 书籍,已经在 OikosofySeries 网站推出数字版本,不久也将在亚马逊上推出。想更多了解这本书,包括免费获得第一章,你可以进入 NoEstimatesBook.com 并注册。注册完后你将获得一个链接,用于下载本书第一章节与目录。

写这本书的时候,我意识到我不可能写一本集娱乐和资讯于一体的书籍,同时涵盖我想涵盖的 #NoEstimates 各个方面,因此我与 Tomas Rybing 和 Evan Leybourn 合作,他们写了两本有关无估算的迷你电子书指南。Tomas 写的是 capacity planning with #NoEstimates,Evan 写的是 contracts and how they define our relationship with clients in ways that either support or make difficult the use of practices like #NoEstimates

除此之外我还做了更多的工作,我针对 #NoEstimates 视频采访了 9 个人。本书包含了对其中 4 名无估算实践者的采访。我想重点强调一下 Clinton Keith 的采访,他给我们讲述了一个非常令人兴奋的故事:他是如何将以前需要 18 个月的项目变成不超过 2 周的工作量!我彻底被这个故事震惊了,并认为这个故事的一些关键见解能够帮助那些有兴趣应用 #NoEstimates 的人。

在这 9 个视频采访中,还有 2 个是对 CEO 的采访,关于在他们自己公司应用 #NoEstimates 思想。

—— Seitgeist 的 Sven Ditz:在他自己的公司中应用无估算。在他的视频中,他讲述了一个令人兴奋的故事,他是如何彻底废除投标过程的需求,甚至在没有提供投标的情况下赢得交易。

—— Biko2 的 Diego Cenzano,一位资深的 IT 创业者,讲述了一个美丽的故事:他如何使用自己的方法(不需要估算)帮助客户专注价值(预期之外的价值)。

_#NoEstimates_ 这本书旨在希望在我们行业启动一场期待已久、引领需求的讨论:我们如何持续提高工作方式,在软件领域立足方法和工具中的决策实现更好地工作。不要忘了估算不是为软件项目开发的技术。我们认识和接受这一工具可能不会应用在我们软件开发领域只是时间的问题。

关于作者

Vasco Duarte 通过关注产品开发团队,产品的端到端生命周期,致力于将产品开发组织转型到产品业务组织。Vasco 目前是 Oikosofy 的执行合伙人。产品经理、Scrum Master、项目经理、总监、敏捷教练只是他在软件开发组织中承担的部分角色。Vasco 在 1997 年就开始在软件行业工作,并且从 2004 年成为敏捷实践者。他也曾作为组织敏捷导入的敏捷教练或领袖,在小型企业、中型企业和大型企业工作。他还曾是 Avira、诺基亚和 F-Secure 公司敏捷方法和敏捷文化导入的一名领导及催化师。

查看英文原文: Q&A with Vasco Duarte on the #NoEstimates Book

2016-01-07 16:001206
用户头像

发布了 92 篇内容, 共 25.9 次阅读, 收获喜欢 4 次。

关注

评论

发布
暂无评论
发现更多内容

你知道敏捷团队的迭代目标达成率该是多少吗?

爱吃鱼的小雨

Scrum 敏捷开发 研发管理 内容合集 迭代管理

和12岁小同志搞创客开发:手撕代码,做一款温湿度检测器

不脱发的程序猿

少儿编程 智能硬件 温度传感器 创客开发 Arduino

Go语言学习查缺补漏ing Day5

恒生LIGHT云社区

golang 编程语言

百度智能云与英特尔携手举办2021 EdgeX中国挑战赛成功落幕

百度大脑

人工智能

ReactiveNetwork库时如何实现网络状态监听的

Changing Lin

12月日更

MySQL锁的分析实战

卢卡多多

28天写作 MySQL 数据库 锁分析 签约计划第二季 12月日更

五分钟,让你明白MySQL是怎么选择索引《死磕MySQL系列 六》

咔咔

MySQL MySQL高级 索引选择而

Python Qt GUI设计:如何调整组件布局比例?(拓展篇—1)

不脱发的程序猿

Python PyQt GUI设计 上位机 调整组件布局比例

元宇宙与电信运营商

CECBC

数据大屏rem适配方案

CRMEB

新思科技推动DevSecOps落地,帮助企业走出“安全孤岛”

InfoQ_434670063458

DevSecOps 新思科技 软件安全

国产分布式数据库StarDB核心技术大揭秘 一:内核分解之数据分片

京东科技开发者

数据库

库存管理系统到底有什么作用?

低代码小观

CRM 企业管理系统 ERP 库存 CRM系统

6000字,详解数据仓库明星产品背后的技术奥秘

百度开发者中心

数据库 大数据

Web3.0时代的社交网络会有哪些新变化?

CECBC

如何避免产品Backlog的这七个常见错误

爱吃鱼的小雨

Scrum 敏捷开发 研发管理 需求管理 内容合集

2022年,RPA的5大发展趋势

金小K

区块链 AI RPA 机器人流程自动化 人工智能「

开源demo| 智慧协同让企业更便利

anyRTC开发者

音视频 智慧协同 开源demo 远程协助 远程勘查

Android C++系列:Linux网络(一)网络模型

轻口味

android 28天写作 12月日更

AfterShip APP 项目数据驱动的演进

AfterShip

数据库 数据 数据驱动

消费医疗门诊的数字化运营

boshi

随笔杂谈

WAVE SUMMIT+2021为开发者准备的“小心思”,你get到了吗

科技热闻

基于云的技术架构设计实践-第4篇

hackstoic

运维 云原生 签约计划第二季 业务运维

WePack —— 助力企业渐进式 DevOps 转型

CODING DevOps

统一管理 WePack 制品管理 研发构建产物 安全管控

和12岁小同志搞创客开发:手撕代码,做一款密室自动门

不脱发的程序猿

少儿编程 传感器 智能硬件 创客开发 Arduino

Linux一学就会之Centos8系统进程管理 ps管理进程

学神来啦

Linux 运维 linux一学就会 uptime centos8

国产分布式数据库StarDB核心技术大揭秘二:智能运维管控

京东科技开发者

数据库

架构训练营-模块一作业

伊静西蒙

Camtasia混音教程

淋雨

Camtasia

以容器的方式运行极狐GitLab Runner

极狐GitLab

Docker runner 极狐GitLab

底层逻辑:变化背后的不变

石云升

读书笔记 28天写作 12月日更

#NoEstimates作者问答_语言 & 开发_Ben Linders_InfoQ精选文章