Occam’s Razor and the Art of Software Design
Last updated: July 16, 2024 Read in fullscreen view
- 10 Apr 2022
Agile self-organizing teams: What are they? How do they work? 30/442 - 18 Oct 2020
How to use the "Knowns" and "Unknowns" technique to manage assumptions 22/995 - 21 May 2022
"Fail Fast, Fail Often, Fail Forward" is the answer to Agile practices of software success 21/950 - 01 Oct 2020
Fail fast, learn faster with Agile methodology 15/977 - 12 Oct 2022
14 Common Reasons Software Projects Fail (And How To Avoid Them) 11/506 - 19 Oct 2021
Is gold plating good or bad in project management? 8/756 - 10 Nov 2022
Poor Code Indicators and How to Improve Your Code? 8/214 - 06 Feb 2021
Why fail fast and learn fast? 7/378 - 13 Oct 2021
Outsourcing Software Development: MVP, Proof of Concept (POC) and Prototyping. Which is better? 7/427 - 20 Nov 2022
Agile working method in software and football 7/326 - 01 Sep 2022
Facts Chart: Why Do Software Projects Fail? 7/544 - 07 Oct 2025
Case Study: Using the “Messaging House” Framework to Build a Digital Transformation Roadmap 7/55 - 01 Mar 2023
Bug Prioritization - What are the 5 levels of priority? 6/207 - 28 Jul 2022
POC, Prototypes, Pilots and MVP: What Are the Differences? 6/613 - 06 Mar 2021
4 things you need to do before getting an accurate quote for your software development 6/617 - 08 Nov 2022
4 tips for meeting tough deadlines when outsourcing projects to software vendor 6/254 - 16 Apr 2021
Insightful Business Technology Consulting at TIGO 5/379 - 05 Mar 2021
How do you minimize risks when you outsource software development? 5/318 - 14 Oct 2021
Advantages and Disadvantages of Time and Material Contract (T&M) 5/795 - 04 Oct 2022
Which ERP implementation strategy is right for your business? 5/279 - 31 Aug 2022
What are the best practices for software contract negotiations? 5/215 - 12 Dec 2021
Zero Sum Games Agile vs. Waterfall Project Management Methods 5/377 - 18 Aug 2022
What are the consequences of poor requirements with software development projects? 5/244 - 08 Oct 2022
KPI - The New Leadership 4/558 - 18 Jul 2021
How To Ramp Up An Offshore Software Development Team Quickly 4/519 - 31 Oct 2021
Tips to Fail Fast With Outsourcing 4/377 - 17 Jun 2021
What is IT-business alignment? 3/346 - 23 Sep 2021
INFOGRAPHIC: Top 9 Software Outsourcing Mistakes 3/413 - 13 Dec 2020
Move fast, fail fast, fail-safe 3/294 - 17 Feb 2022
Prioritizing Software Requirements with Kano Analysis 3/285 - 10 Apr 2021
RFP vs POC: Why the proof of concept is replacing the request for proposal 3/257 - 07 Jul 2021
The 5 Levels of IT Help Desk Support 3/381 - 28 Dec 2021
8 types of pricing models in software development outsourcing 3/419 - 28 Oct 2022
Build Operate Transfer (B.O.T) Model in Software Outsourcing 3/365 - 07 Oct 2020
How To Manage Expectations at Work (and Why It's Important) 3/273 - 04 Oct 2021
Product Validation: The Key to Developing the Best Product Possible 3/296 - 16 Feb 2021
Choose Outsourcing for Your Non Disclosure Agreement (NDA) 3/150 - 09 Mar 2022
Consultant Implementation Pricing 3/185 - 10 Dec 2023
Pain points of User Acceptance Testing (UAT) 3/418 - 01 Dec 2023
Laws of Project Management 3/250 - 05 Sep 2023
The Cold Start Problem: How to Start and Scale Network Effects 3/167 - 12 May 2024
The Pros and Cons of the Creator Economy in the Age of AI: Opportunities, Challenges, and the Gray Zone with the Gig Economy 3/233 - 03 Jul 2022
Manifesto for Agile Software Development 2/240 - 27 Oct 2020
8 principles of Agile Testing 2/1203 - 12 Oct 2020
The Agile Manifesto - Principle #8 2/449 - 19 Apr 2021
7 Most Common Time-Wasters For Software Development 2/527 - 07 Aug 2022
Things to Consider When Choosing a Technology Partner 2/255 - 07 Oct 2022
Digital Transformation: Become a Technology Powerhouse 2/220 - 01 May 2024
Warren Buffett’s Golden Rule for Digital Transformation: Avoiding Tech Overload 2/188 - 10 Jul 2025
Building AI-Driven Knowledge Graphs from Unstructured Data 1/117 - 12 Aug 2024
Understanding Google Analytics in Mumbai: A Beginner's Guide 1/85 - 01 May 2023
CTO Interview Questions 1/299 - 23 May 2024
Mastering AI: Sharpening the Axe in the Digital Age 1/182 - 26 Dec 2023
Improving Meeting Effectiveness Through the Six Thinking Hats 1/205 - 05 Jan 2024
Easy ASANA tips & tricks for you and your team 1/181 - 11 Jan 2024
What are the Benefits and Limitations of Augmented Intelligence? 1/436 - 30 Oct 2022
How Much Does MVP Development Cost in 2023? 1/173 - 09 Feb 2023
The Challenge of Fixed-Bid Software Projects 1/191 - 20 Nov 2022
Software Requirements Are A Communication Problem /234 - 01 Jun 2022
How Your Agile Development Team is Just Like a Football Team? /206 - 28 Nov 2023
Scrum Team Failure — Scrum Anti-Patterns Taxonomy (3) /228 - 01 Mar 2022
Why Does Scrum Fail in Large Companies? /245 - 09 Jan 2022
How to Bridge the Gap Between Business and IT? /165 - 16 Jul 2022
What are disadvantages of Agile Methodology? How to mitigate the disadvantages ? /354 - 14 Mar 2024
Why should you opt for software localization from a professional agency? /117 - 01 Mar 2023
How do you deal with disputes and conflicts that may arise during a software consulting project? /145 - 01 Dec 2022
Difference between Set-based development and Point-based development /298 - 06 Mar 2024
[SemRush] What Are LSI Keywords & Why They Don‘t Matter /131 - 12 Mar 2024
How do you create FOMO in software prospects? /131 - 03 Nov 2022
Top questions and answers you must know before ask for software outsourcing /265 - 09 Oct 2022
Key Advantages and Disadvantages of Agile Methodology /666 - 10 Oct 2022
Should Your Business Go Agile? (Infographic) /109 - 02 Nov 2022
Frequently Asked Questions about Agile and Scrum /373 - 19 Oct 2021
Software development life cycles /628 - 21 Oct 2022
Virtual meeting - How does TIGO save cost, reduce complexity and improve quality by remote communication? /167 - 06 Nov 2019
How to Access Software Project Size? /236 - 17 Mar 2025
IT Consultants in Digital Transformation /62
Occam's Razor, a 14th-century philosophy, emphasizes simplicity over complexity. It suggests that the simplest solution is often the best, but this is often interpreted as the "fewest assumptions" or Principle of Parsimony. The principle is based on the idea that entities should not be multiplied beyond necessity. This principle is often used in software design, where the simplest solution is often the best.
The premise of Occam’s razor is that “entities should not be multiplied without necessity”. It emphasizes choosing the solution with the fewest assumptions when faced with competing hypotheses concerning the same prediction; nevertheless, it should be noted that this is not a method of selecting amongst hypotheses that make different predictions.
It is often mistaken to advocate simplicity, but has a more nuanced recommendation, which is described by the quote “Everything should be made as simple as possible, but no simpler.”. This idea, which goes, "It is vain to do with more what can be done with fewer".
In software design, it is crucial to question the validity of assumptions and ensure that everything is done in support of project objectives. By embodying Occam's Razor and doing less, developers can improve their productivity and overall productivity.
80% of the functionality built into software application is either never, or rarely used.
Scrum and Agile methods in software development focus on delivering value to end users. This approach ensures constant assessment and re-prioritization of features and functionality, leading to stakeholder satisfaction earlier in the development process. However, this approach is not enough.
In the world of predictive models, one needs to maintain a balance between model complexity and error, that would be a sweet spot between over-generalization and over-specialization.
Software solutions are increasingly complex due to the increasing requirements of application solutions. Complexity introduces uncertainty and risk, increasing the probability of failure. Plurality, which adds entities to support conclusions, multiplies the complexity of the system. The number of entities in a software system increases as the number of entities increases, but it is crucial to ensure that changes in any one entity will not impact any other. Additionally, the system's complexity increases with the number of assumptions, which represent assumptions in Occam's view. The more assumptions a system has, the more complex it becomes, and thus the higher the probability of failure.
Key Points
Software Development and Occam's Principles
- The principles espoused by Occam are not enough to address the increasing complexity of software solutions.
- Complexity introduces uncertainty and risk, increasing the probability of failure.
- Plurality in software adds complexity, not just adding entities.
- The complexity of the system increases as the number of entities increases.
- The complexity of the system is not in the dots, but the number of lines connecting them.
The complexity of the system increases with the number of entities added. - The "what if's" represent assumptions in Occam's view, which increase with the number of entities added.
- Scrum and Agile Methods in software development focus on delivering value to end users, reducing the need for technology.
- 80% of the functionality in software applications is either never used or rarely used.
- Continuous assessment and re-prioritization of features and functionality ensures stakeholder satisfaction.
Continue reading at michaellant.com
| About the Author | Michael Lant | IT Consultant |
MICHAEL LANT: Software Archictecture, Development, Agile Methods and the Intersection of People Process and Technology.
I am an independent consultant who has been leading software teams, designing, building and delivering software for nearly three decades. It’s still as exciting and enjoyable for me today as at was when I wrote my very first Hello World program and saw it spring to life in front of me.
|










Link copied!