Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Simplifying Software Estimation
Search
Sponsored
·
SiteGround - Reliable hosting with speed, security, and support you can count on.
→
Pratul Kalia
July 24, 2020
Programming
270
1
Share
Simplifying Software Estimation
Presented at GDG MAD in July 2020.
Pratul Kalia
July 24, 2020
More Decks by Pratul Kalia
See All by Pratul Kalia
The special case of Mobile DevOps
pratul
2
45
Reldex: measuring the effectiveness of your app release process
pratul
0
28
Stop the security theater!
pratul
0
300
Effective and efficient mobile engineering
pratul
0
200
Designing future-proof Android applications
pratul
0
190
Android - an introduction for developers
pratul
3
260
Semantic Content Repositories
pratul
1
180
How To Become A Hacker
pratul
3
310
Other Decks in Programming
See All in Programming
How Swift's Type System Guides AI Agents
koher
0
210
Linux Kernelの1文字のミスで 権限昇格ができた話
rqda
0
2.3k
Laravel Nightwatchの裏側 - Laravel公式Observabilityツールを支える設計と実装
avosalmon
1
330
10年分の技術的負債、完済へ ― Claude Code主導のAI駆動開発でスポーツブルを丸ごとリプレイスした話
takuya_houshima
0
2.4k
Symfonyの特性(設計思想)を手軽に活かす特性(trait)
ickx
0
130
それはエンジニアリングの糧である:AI開発のためにAIのOSSを開発する現場より / It serves as fuel for engineering: insights from the field of developing open-source AI for AI development.
nrslib
1
840
「話せることがない」を乗り越える 〜日常業務から登壇テーマをつくる思考法〜
shoheimitani
4
710
AI時代のPhpStorm最新事情 #phpcon_odawara
yusuke
0
150
今からFlash開発できるわけないじゃん、ムリムリ! (※ムリじゃなかった!?)
arkw
0
190
PCOVから学ぶコードカバレッジ #phpcon_odawara
o0h
PRO
0
250
PHP 7.4でもOpenTelemetryゼロコード計装がしたい! / PHPerKaigi 2026
arthur1
1
550
PDI: Como Alavancar Sua Carreira e Seu Negócio
marcelgsantos
0
110
Featured
See All Featured
The Impact of AI in SEO - AI Overviews June 2024 Edition
aleyda
5
790
Bridging the Design Gap: How Collaborative Modelling removes blockers to flow between stakeholders and teams @FastFlow conf
baasie
0
510
Building an army of robots
kneath
306
46k
RailsConf & Balkan Ruby 2019: The Past, Present, and Future of Rails at GitHub
eileencodes
141
35k
[SF Ruby Conf 2025] Rails X
palkan
2
940
Heart Work Chapter 1 - Part 1
lfama
PRO
5
35k
Code Review Best Practice
trishagee
74
20k
Balancing Empowerment & Direction
lara
5
1k
ラッコキーワード サービス紹介資料
rakko
1
3M
Dealing with People You Can't Stand - Big Design 2015
cassininazir
367
27k
Sam Torres - BigQuery for SEOs
techseoconnect
PRO
0
240
AI: The stuff that nobody shows you
jnunemaker
PRO
5
540
Transcript
Pratul Kalia @PRXTL • OBVIOUS.IN SIMPLIFYING SOFTWARE ESTIMATION
SOFTWARE ESTIMATION STEVE MCCONNELL 2006, MICROSOFT PRESS
WHAT IS AN ESTIMATE?
LET’S DRIVE FROM ONE END OF THE CITY TO ANOTHER!
“How much time will it take to finish all these things?”
Estimates always have a probability.
Targets are not estimates!
THE TRAIN LEAVES AT 4.40 PM! “Here are a bunch
of things we have to get done by X”
Are you chasing a target or an estimate?
PRESSURE & BAD ESTIMATES
— ALL ENGINEERS “Okay, that is a bit of work
but I’m sure I can do it in 3 days.”
Stop putting yourself in unreasonable situations.
There are no prizes for getting there fast!
— PARKINSON’S LAW “Work will expand to fill all available
time.”
(that is… if teams have lots of extra time, more
work will magically get created.)
— GOLDRATT’S STUDENT SYNDROME “Given lots of time, students will
delay studying until the last possible moment”
Underestimation is worse than Overestimation! Stastically reduced chance of on-time
completion.
Engineers are too optimistic already.
OTHER SIDE EFFECTS… Poor technical foundation, worse in the long
run.
OTHER SIDE EFFECTS… Unproductive, emotionally draining behaviours.
OTHER SIDE EFFECTS… - more status meetings! - frequent re-estimation!
- interim releases!
OTHER SIDE EFFECTS… - meetings to cut scope! - fix
bugs arising from hacks!
None
THE CONE OF UNCERTAINTY
None
“As the project progresses, estimates become more accurate.”
(yes that’s quite , isn’t it.)
None
It is easily possible to do worse… but not better.
The Cone does not narrow itself.
None
None
Stop doing first-number-in-your-head estimates! It sets the wrong expectation!
⏱
Even a 15-minute estimate is exponentially better than an instant
one.
INCLUDE EVERYTHING. Some requirements are stated. Others are implied.
INCLUDE EVERYTHING. Deployment setup Maintaining build scripts Code reviews
INCLUDE EVERYTHING… Writing documentation Onboarding new team members
INCLUDE EVERYTHING! Creating test data Upgrading dependencies
FACTORS THAT INFLUENCE ESTIMATES
Size of the software! The biggest contributor to project effort
and schedule.
As size increases, effort goes up exponentially. Exponentially. Not linearly.
Programmer capability. Time constraints. Team continuity. Required reliability.
COCOMO-2 software estimation model.
IMPROVING YOUR ESTIMATES
I hope you use story points of some type.
STORY POINTS. Mark of complexity They don’t (necessarily) represent time!
STORY POINTS. (for e.g. A team using 1/2/3 points for
a project.)
STORY POINTS. A junior engineer takes 5 days to finish
a 3-point task.
STORY POINTS. A senior engineer takes 2 days to finish
a 3-point task.
The time taken is different. But the complexity is similar!
NOT COMPLEX… Create a “lint step” on the CI server
NOT COMPLEX… Add “patient has already visited” option to Overdue
list
COMPLEX? Allow Blood Pressure measurements to be deleted
The Law of Large Numbers
“If you create one Big Estimate, your error(s) will either
be completely on the high side, or the low side”
“but if you create multiple Small Estimates, some will be
on high side, some on the low side.”
“… so the errors will cancel each other out, to
some extent.”
COMPLEX? Allow Blood Pressure measurements to be deleted
None
ALSO COMPLEX Sync Protocol Drugs across all facilities and display
in the app
None
Some tricks!
TRICKS! Do a detailed task breakdown: spend some time!
TRICKS! Think of the “worst case” while estimating.
TRICKS! Compare different stories of similar complexity.
TRICKS! Use a project management tool that understands “velocity”.
TRICKS! Engineers should break down tasks and estimate them.
TRICKS! Look at past data for your team, for similar
type of work.
TRICKS! Measure yourself privately
NEGOTIATIONS & AGREEMENTS
An estimate is a conversation, and a negotiation.
Engineers “own” the estimate… but Management “owns” the target.
The goal of estimation is NOT pinpoint accuracy!
People want to understand VALUE in comparison to EFFORT.
Do t-shirt-sizing with all stakeholders.
VALUE EFFORT A: S M B: M S C: S
L D: XL M
Separate people from the problem.
Focus on interests, not on positions.
Come up with options that benefit everyone.
Either everyone wins, or everyone loses.
GO FORTH AND ESTIMATE!