Wirth's Law

"Software is getting slower more rapidly than hardware becomes faster." 1

Niklaus Wirth

Wirth's Law highlights a paradox: as hardware gets faster, software often becomes less efficient even more quickly. The result is that newer software can feel slower and more cumbersome than older versions. For Agile teams, this creates a silent but critical risk: delivering working software that feels slower, heavier, or more complex with every iteration.

Impact on Agile Teams and Organizations

  • Velocity illusion:
    • Teams may feel productive by pushing features rapidly, but the product grows bloated and sluggish.
  • User dissatisfaction:
    • End-users perceive declining performance, eroding trust and engagement.
  • Technical debt:
    • Constant feature delivery without attention to performance optimization accumulates inefficiencies.
  • Team morale:
    • Engineers may feel disheartened if they're asked to move fast without time to clean up or refactor.
  • Organizational cost:
    • Performance issues lead to increased support needs, infrastructure upgrades, and customer churn.

Scenario

An Agile team delivering features for a growing web application. They maintain a steady Sprint cadence, and stakeholders are thrilled with the feature throughput. However, as more features are added:

  • Page load times increase.
  • Mobile users experience lags.
  • Front-end bundles become massive
  • Support tickets rise due to performance complaints.

Eventually, users complain. The product team scrambles to "optimize performance," but there's little room in the backlog. The team now faces a backlog of both features and fixes. Sprint goals shift from value delivery to damage control.

Ways to Mitigate Wirth's Law:
  1. Embed Performance in your Definition of Done:
    • Don't ship until performance thresholds are met. Include criteria like load time, memory use, and API latency.
  2. Refactor Regularly:
    • Allocate sprint capacity for technical health. Refactoring isn't a luxury—it's a discipline.
  3. Adopt System-level Thinking:
    • Encourage teams to think beyond their feature slice. How does this change affect performance globally?
  4. Build Performance Awareness into Reviews:
    • Demo performance regressions or improvements alongside features. Make it part of the conversation.
  5. Use Metrics Early and Often:
    • Introduce observability from the start: log sizes, CPU/memory usage, and load times across environments.
  6. Limit Feature Bloat:
    • Focus on simplicity and value. Just because something can be added doesn't mean it should.
Conclusion:

Wirth's Law is a quiet but powerful force undermining Agile delivery. Without intentional checks, teams can ship "working software" that gradually performs worse despite stronger infrastructure. Agile isn't just about fast delivery, it's about sustainable, valuable delivery. Embracing Wirth's Law means respecting the long game: simplicity, efficiency, and deliberate craftsmanship.

Key Takeaways

  • Wirth's Law reminds us that performance declines unless actively managed.
  • Agile teams must balance delivery speed with architectural health.
  • Performance should be part of the backlog, not an afterthought.
  • Simplicity is a feature. Complexity breeds slowness.
  • Continuous improvement must include performance as a dimension.

Summary

Wirth's Law exposes a hidden trap for Agile organizations: software often gets slower faster than hardware gets better. Agile teams focused solely on velocity may unknowingly create bloated, inefficient systems. By embedding performance into daily practice, prioritizing technical health, and resisting unnecessary complexity, Agile teams can uphold the value of delivering working software, not just shipped software.