软件需求膨胀系数

泡水膨胀球

(图片来自网络)

这是一种小玩具,干燥时拿在手里,小巧紧致。

泡在水里一段时间之后,浑圆饱满,一只手都未必能捧的住。

放在干燥通风的地方晾晒,一段时间过后,又可以恢复原本的大小。

软件需求

软件需求与泡水膨胀球也有类似之处。

一开始时看似简单明了且完备正交,后来发现越做越大,越做越多。

原本一只手能抓好几个的小球,后来变成两只手都抓不住一个。

然后的结果要么是超预算多花钱做完,要么是转嫁成本给乙方要求对方做完,要么是延期,要么是痛苦地去压缩需求。

无论哪种,都是不健康的。

膨胀系数

小球泡在水里会膨胀,暴露于干燥环境中会缩小。

这个过程可以用一个简化模型来表示:

膨胀系数 ≈ 吸水力 - 斥水力

小球体积 ≈ 初始体积 + 膨胀系数 x 时间

当吸水力大于斥水力时,膨胀系数为正数,在时间的作用下,球会膨胀。

当斥水力大于吸水力时,膨胀系数为负数,在时间的作用下,球会缩小。

当两个力接近相互平衡时,膨胀系数约等于零,在时间的作用下,小球体积趋于稳定。

我们希望看到小球体积怎样变化?

一直变肥?那不行。做软件是有成本的,时间人力都是成本。

持续变瘦?也不行。需求受到过分压抑也是不健康的。

健康的变化过程应该是:

  • 先让小球丰满起来——充分收集需求,以免后面出现始料未及的“惊喜”
  • 然后削减多余的赘肉——使用奥卡姆剃刀
  • 之后长期维持健康范围内的波动

力的阶段性施加策略

时间的流逝是不受我们控制的,因而想要控制体积就要从膨胀系数下手。

而膨胀系数又与两个力相关,因而想要控制体积就要控制吸水力与斥水力。

首先让吸水力尽情释放,这时斥水力蛰伏着静待吸水力的衰减。

之后斥水力爬坡,达到与吸水力持平的水准,二者长期和平共处。

当我们如上使用这两种力的时候,小球体积的变化就会是这样的:

总结

调研阶段积极创造环境来让吸水力得以释放,允许小球先变肥。然后施加一定的斥水力,让小球苗条下来。

到了研发阶段,由于吸水力在之前就得到了有效的释放,这时施加适量的斥水力来平衡所剩无几的吸水力就能让小球体积的波动维持在可控的范围内。

在不同的阶段有策略地利用这两种力,则可以趋近前期需求收集充分考虑各方诉求,不留大的隐患,后续研发稳定不坐过山车的目的。


文/ThoughtWorks 崔鹏飞

更多精彩洞见,请关注微信公众号:ThoughtWorks洞见

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值