DZone
Thanks for visiting DZone today,
Edit Profile
  • Manage Email Subscriptions
  • How to Post to DZone
  • Article Submission Guidelines
Sign Out View Profile
  • Post an Article
  • Manage My Drafts
Over 2 million developers have joined DZone.
Log In / Join
Refcards Trend Reports
Events Video Library
Refcards
Trend Reports

Events

View Events Video Library

Zones

Culture and Methodologies Agile Career Development Methodologies Team Management
Data Engineering AI/ML Big Data Data Databases IoT
Software Design and Architecture Cloud Architecture Containers Integration Microservices Performance Security
Coding Frameworks Java JavaScript Languages Tools
Testing, Deployment, and Maintenance Deployment DevOps and CI/CD Maintenance Monitoring and Observability Testing, Tools, and Frameworks
Culture and Methodologies
Agile Career Development Methodologies Team Management
Data Engineering
AI/ML Big Data Data Databases IoT
Software Design and Architecture
Cloud Architecture Containers Integration Microservices Performance Security
Coding
Frameworks Java JavaScript Languages Tools
Testing, Deployment, and Maintenance
Deployment DevOps and CI/CD Maintenance Monitoring and Observability Testing, Tools, and Frameworks

Low-Code Development: Leverage low and no code to streamline your workflow so that you can focus on higher priorities.

DZone Security Research: Tell us your top security strategies in 2024, influence our research, and enter for a chance to win $!

Launch your software development career: Dive head first into the SDLC and learn how to build high-quality software and teams.

Open Source Migration Practices and Patterns: Explore key traits of migrating open-source software and its impact on software development.

Related

  • Conflict Management in Technology Teams: Insights From Google's Project Aristotle
  • The Power of Refactoring: Extracting Interfaces for Flexible Code
  • How To Manage Decision Fatigue in Remote Software Development
  • Spotify Backstage: A Unifying Force for Developer Experience

Trending

  • How To Use Thread.sleep() in Selenium
  • Application Telemetry: Different Objectives for Developers and Product Managers
  • The Role of AI in Low- and No-Code Development
  • Mastering Distributed Caching on AWS: Strategies, Services, and Best Practices
  1. DZone
  2. Culture and Methodologies
  3. Methodologies
  4. Decision-Making Model: SOLVED

Decision-Making Model: SOLVED

Discover SOLVED: a decision-making model that can be used for making effective decisions throughout different stages of the software development lifecycle.

By 
Hardik Ghelani user avatar
Hardik Ghelani
·
Apr. 11, 24 · Tutorial
Like (2)
Save
Tweet
Share
1.8K Views

Join the DZone community and get the full member experience.

Join For Free

Decision-making is a critical aspect of our lives. Nothing slows down our progress like indecision. Well-thought-out decisions are instrumental in navigating complexities and achieving individual, team, and organizational desired outcomes.

In software development, decision-making is a crucial process that occurs at various stages of the development lifecycle, starting from technology stack finalization, architecture design, feature prioritization, user experience (UX) design, development methodologies and integration, security and performance considerations, testing strategies, etc. 

I have used different Decision-Making Models to support critical decision-making. In this article, I will talk about a decision model, SOLVED, which I found useful in most of the scenarios encountered during software development.SOLVED infographic

SOLVED is a 6-step decision model that not only helps in software development but also product and project management. The name SOLVED is derived from the steps involved in this model. 

S - Survey

O - Outline

L - Leverage

V - Validate

E - Engage

D - Document

Let's go through the steps. Each step also included the details about a practical example.

Step 1: Survey

  • Examine the condition and situation, and understand the problem statement.
  • Collect the different data related to the problem statement via research and analysis.

Example

There is a request to improve the performance of a page. As a part of this step, start with the following:

  1. Capture the current performance of the page during different scenarios.
  2. Understand the user behavior on the page by analyzing the statistics.
  3. Identify the probable areas where performance is potentially degraded and can be improved by refactoring the code.

Step 2: Outline

  • Outline the objective and problem statement clearly.
  • A clear, precise, and well-defined understanding of the objective or problem statement will help ensure the correctness of the decision.

Example 

For the performance improvement, outline the problem statement as improving the page performance and bringing the load time to under 2 seconds from the current load time of 10 seconds.

Step 3: Leverage

  • Use the data points collected in Step 1 and identify the probable decision path.
  • Data-driven decisions help in enhancing the probability of a decision’s success.

Example

In the same example of performance improvement, using the information captured in step 1, identify the potential changes that can be implemented to potentially improve the performance to achieve the outcome of bringing the performance to 2 seconds.

Step 4: Validate

  • Validate the decision path by small-scale execution as per the decision path in Step 3.
  • The decision can be also validated by discussing it with an SME.
  • This step ensures decisions are not based on unfounded beliefs.

Example

In the same example, perform the spike of refactoring code changes decided in Step 3 to validate the improvement in performance before implementing actual changes.

Step: 5 Engage

  • Engage with all the stakeholders to ensure the decision path covers their preferences and feedback.
  • This step ensures the decision is accepted.

Example

Share the details about the improvements to be implemented to bring the performance to 2 seconds with all the stakeholders and get the buy-in to implement the change.

Step 6: Document

  • Document the final decision and supporting information for future reference.

Example 

Document the details about approved improvements and supporting rationale behind the improvements for future reference.

Additional Practical Examples

Below is a reference of some of the other practical examples where I have used this model successfully:

  1. UX design
  2. Identifying which database to use (relational vs non-relational)
  3. Architectural design decision
  4. Automation test strategy finalization
  5. Deciding on a product planning tool 
  6. Suggestion to add a new feature to a mobile application

Summary

The SOLVED Decision-Making Model is a simple, but methodological model that helps to make a well-thought-out, effective decision. This method can be used not only in software development but also in any decision-making situation.

Design Performance improvement Project management Software development methodologies

Opinions expressed by DZone contributors are their own.

Related

  • Conflict Management in Technology Teams: Insights From Google's Project Aristotle
  • The Power of Refactoring: Extracting Interfaces for Flexible Code
  • How To Manage Decision Fatigue in Remote Software Development
  • Spotify Backstage: A Unifying Force for Developer Experience

Partner Resources


Comments

ABOUT US

  • About DZone
  • Send feedback
  • Community research
  • Sitemap

ADVERTISE

  • Advertise with DZone

CONTRIBUTE ON DZONE

  • Article Submission Guidelines
  • Become a Contributor
  • Core Program
  • Visit the Writers' Zone

LEGAL

  • Terms of Service
  • Privacy Policy

CONTACT US

  • 3343 Perimeter Hill Drive
  • Suite 100
  • Nashville, TN 37211
  • support@dzone.com

Let's be friends: