The lie of the 80%: why software progress charts don't work
Picture the ideal burndown chart. A clean diagonal line, descending steadily from "all the points" down to zero by the end of the sprint. Beautiful. Reassuring. Shareable in a stakeholder meeting.
Now picture an actual sprint you've lived through. Did the line ever look like that?
I'm going to guess: no. And not because your team was bad. Not because you're undisciplined. Not because the estimates were off. The reason no real burndown ever matches the ideal one is more fundamental: software isn't built like that.
Charts of progress assume a model of how software gets made that doesn't reflect reality. And once you see it, you can't unsee it.
Software isn't a brick wall
The mental model behind every progress chart — burndown, burnup, Gantt, percent-complete, you name it — is the same: development is a stack of bricks. You add one brick at a time. The wall gets taller. Eventually, it reaches the height you wanted, and you're done.
This metaphor is comforting and almost entirely wrong.
Real software development looks more like this: you build half a wall. You realize the foundation is in the wrong place. You tear the wall down. You build a different wall. You realize the room is in the wrong place. You spend three days reading and thinking and not laying any bricks at all. Then on day four, you build the entire wall in six hours because you finally understood the problem.
This isn't a failure mode. This is what software development is. Exploration, dead ends, tear-downs, breakthroughs. The progress is non-linear because the work is non-linear. Any chart that assumes a smooth descent from "not done" to "done" is lying about the shape of the work itself.
The 80% lie
Here's the most universally-told lie in software:
"It's basically done. Just need to finish that last 20%."
Every developer has said this. Every developer has heard this. And every developer has been on the receiving end of that 20% turning out to be 80% of the actual work.
It's not that we're all liars. It's that the way development actually unfolds — exploration phase, implementation phase, polish phase — doesn't map cleanly onto percentages. When you say "I'm 80% done", what you usually mean is "I've done a lot, and I have a vague sense that the remaining stuff is smaller than the stuff I did". That's not a measurement. That's a feeling.
The "remaining 20%" often contains:
- The integration with the system you haven't talked to yet
- The edge case that surfaces only when you wire it up end-to-end
- The performance problem that shows up only at production scale
- The thing the PM forgot to mention until you demoed
None of these are visible from where you stand at the supposed 80% mark. They're not in the chart. They can't be in the chart. They haven't been discovered yet.
Every metric is biased by who produces it
Here's a quieter problem with progress charts: the person reporting the metric always has a stake in what the metric says.
If you want to look productive, you inflate. If you want to avoid getting more work assigned to you, you deflate. If you're protecting a teammate, you smooth. If you're frustrated with management, you let the truth show through harder than it should.
This isn't dishonesty. It's people responding rationally to incentives. The metric isn't a mirror — it's a message. Once you understand that progress charts are a form of communication, not measurement, you stop expecting them to reflect reality. They reflect the politics of the team's relationship with whoever's reading the chart.
The fix isn't "be more honest". The fix is recognizing that any metric whose value depends on the reporter's interpretation will be shaped by the reporter's incentives. Always. Every time.
The fallacy of uniform effort
Charts also assume that everyone on the team is contributing in roughly the same way at roughly the same time. Sprint velocity. Points completed per developer. Burndown lines that smoothly descend.
Real teams don't work like that. Real teams have weeks where the frontend dev ships forty CMS templates because the work happened to be parallelizable, while the backend dev appears to be drinking mate and playing ping pong for two weeks. And then the next sprint flips: the backend ships a complex migration that took weeks to design, while the frontend dev waits, tests, and unblocks.
That's not dysfunction. That's how interdependent work looks.
If your chart shows uneven contribution and your interpretation is "the backend dev didn't pull their weight", your chart has lied to you. Maybe the backend dev was the reason the frontend could ship forty templates without blockers. Maybe they were doing the design work that makes next sprint possible. Maybe they were unblocking three other teams off-camera.
Charts can't see any of that. They show throughput per person and call it productivity. It isn't.
So who do these charts actually serve?
Once you've internalized all of the above, the question becomes hard to avoid: if these charts don't reflect the work, don't predict the future, and don't measure productivity — why do we still draw them?
The honest answer: because somebody with money needs to see them.
Stakeholders need a deliverable. Steering committees need slides. Procurement needs evidence the contract is being honored. Investors want a sense that the burn is producing output. None of these audiences are going to read the codebase. None of them are going to sit in your standup. They need a representation, and the chart is what we hand them.
That's fine. That's the corporate game, and pretending it can be opted out of is naive. But let's stop pretending the chart is a tool for the team. It isn't. It's a tool for the people the team has to report to. Calling it "project management" obscures what it actually is: status theater, dressed in the language of measurement.
The team doesn't need the chart to know how the project is going. The team knows. They're the ones doing it.
What actually works
If charts are theater, what's the alternative? Three things, in this order:
1. Demos over charts. The only honest measurement of progress is working software. Last week the product looked like this. This week it looks like this. Did it move? Did it move in the right direction? That's the question, and no chart in the world answers it as well as a five-minute demo. If you can't show anything that works, you're not progressing — no matter what the burndown says.
2. Narrative over numbers. Replace "we're 73% done" with "we explored approach A, it didn't pan out, we're now on approach B and we expect to know if it works by Thursday". This is harder than producing a chart, because it requires the reporter to actually understand the work. That's a feature, not a bug. The narrative forces honest engagement; the chart allows comfortable distance.
3. Output metrics as complement, not substitute. What did the user actually receive? Deploys to production. Features released. Bugs closed in the wild. These can be counted because they're real events with real artifacts. The user doesn't lie. The git log doesn't lie. Process metrics — story points completed, sprint percentage, velocity trends — measure the appearance of work. Output metrics measure work that left the building.
And if a stakeholder genuinely needs a number — sometimes they do, and that's fair — give them one. Just be honest about what it is. "Let's invent a number over a beer" is a more accurate framing than "based on our velocity-weighted forecast of remaining story points". They're often the same number. The first one tells the truth about its origins.
The elephant: but the stakeholders want the chart
I'm not naive. I know that in many companies, you can't just stop producing burndowns. The contract requires it. The PMO requires it. The CFO has a slide template with that chart shape on it and changing the slide is harder than changing the moon.
So produce the chart. Hand it over. Smile at the meeting.
But internally, don't let the team start believing the chart. That's where the real damage happens — when developers start optimizing for the line on the screen instead of for the product. When the chart becomes the goal, the chart will start telling you the team is doing great while the codebase is rotting in ways no chart can show.
The worst version of this is the team building its own charts. When developers start producing the very theater that's being used to manage them, the gap between "what we say is happening" and "what is happening" stops being a stakeholder problem and starts being an internal one. That's how you end up with teams that look productive on paper and ship nothing of value for two quarters.
The bottom line
A chart never built a product.
The people who build great software don't do it by staring at burndowns. They do it by talking to their teammates, watching the product grow, adjusting direction when something isn't working, and being honest with each other about what they don't yet understand. The chart is, at best, a translation layer between that work and the people who fund it.
Translation layers aren't bad. But they aren't the work, and they aren't where the work happens.
If you're a manager: the chart is for your audience, not your team. Don't manage by it.
If you're a developer: the chart is theater. Produce it if you have to, but don't let it shape how you actually think about the project.
And if you're at a company where the chart is the project — where decisions are made off the line on the screen and the actual code is invisible to everyone above the team lead — that's not a measurement problem. That's a much deeper one, and no better chart will fix it.
If your team genuinely needs a burndown chart to know how the project is going, the problem isn't the chart. It's that nobody is actually talking about the project.
What does your team use to track progress? Charts you trust, charts you tolerate, or something else entirely? I'd love to hear it in the comments.
Top comments (3)
This perfectly explains why software progress feels less like building a wall and more like archaeology mixed with chaos engineering. 😂
The “80% done” section was painfully accurate — somehow that last 20% always contains hidden APIs, edge cases, production bugs, and existential crises.
I really liked the point that demos and narratives are often more honest than beautifully descending burndown charts, because working software tells the truth faster than spreadsheets do.
At this point, most progress charts feel like fitness trackers for projects: technically active, emotionally comforting, and occasionally disconnected from reality. 😅
"Fitness trackers for projects" — I'm stealing that one 😂. It's exactly the failure mode: the chart keeps moving, everyone feels productive, and somewhere a senior engineer is quietly realizing the architecture needs to be rethought.
The archaeology comparison is sharper than it sounds, too. Most of the "last 20%" isn't new work — it's discovery. You're finding what was always there: the edge case the PM didn't mention, the API that lies about its rate limits, the assumption baked into a library three layers down. The chart can't show that because the chart doesn't know it exists yet.
Which is why demos win. A burndown describes what we intended to build. A demo shows what we actually built. Those are rarely the same thing, and the gap between them is where all the interesting engineering lives.
Hi, how’s work been lately?
Your profile looks really impressive.
I’m also trying to move into a new direction, and I’ve realized that handling everything alone — clients, projects, delivery, and constant communication — is not really scalable.
I’ve been working in AI and software development, and I think we could combine our experience to land stronger, better-fit projects together.
My idea is to build a solid, professional account (freelancer.com and upwork.com) with a clear strategy for attracting clients, then split responsibilities based on our strengths so we work more efficiently as a team.
Long-term, we could even collaborate on building our own product if things go well.
What do you think about this idea?
Can I get your Whatsapp or Telegram ID?
Some comments have been hidden by the post's author - find out more