- The Agile Developer's Handbook
- Paul Flewelling
- 390字
- 2021-06-24 18:47:07
Estimates
One thing that was increasingly obvious in the software industry was that our approaches to estimating or predicting the outcome of a project were out of whack. As a software team, we were often passed detailed requirements to analyze, then do some initial design work, and provide a work breakdown with estimates.
We'd be working on one project and then at the same time asked to estimate on another. The estimates we were told would inform the decision on whether the project was viable and would be funded. Some teams tried to be sophisticated, using algorithmic estimating techniques such as Constructive Cost Model (COCOMO), COCOMO II, Source lines of code (SLOC), and Function Point. Most estimating methods incorporated rule of thumb or experience-based factors as well as factors for complexity and certainty.
Sometimes the estimates would be given by people who weren't going to work on the project. This was either because the project leadership group didn't want to disturb an existing project team, or because, without funding, the project teams weren't formed yet. This meant the involvement of someone like an architect or a technical leader who could break down the work and estimate based on the solution they devised. Most complicated problems have several solutions, so if those who had done the solution work breakdown weren't available to provide guidance on how to implement their solution, obviously this could cause trouble later on.
Either way, whoever provided the estimate would give it based on the best solution they could theorize with the information they were given. More often than not, the first estimate that was given would be used as a way to control the project, and it would be pretty much set in stone. This was a pattern that I stumbled across many times. When this continually happened, we tried to improve the accuracy of our estimates by spending time doing more upfront work. But the reality was to get an exact estimate of effort so that time frames and budget can be drawn, you pretty much have to complete all the work in the first place.
- RCNP實驗指南:構建高級的路由互聯網絡(BARI)
- 網管員典藏書架:網絡管理與運維實戰寶典
- 電子政務效益的經濟分析與評價
- Django 2 by Example
- 物聯網+BIM:構建數字孿生的未來
- Web Application Development with R Using Shiny
- HCNA網絡技術
- Getting Started with WebRTC
- 城域網與廣域網(第2版)
- TD-LTE無線網絡規劃與設計
- Scala Design Patterns.
- Getting Started with Memcached
- Microsoft Power Platform Enterprise Architecture
- 全聯網標識服務
- 移動互聯網環境下的核心網剖析及演進