Incremental build model
|Paradigms and models|
|Methodologies and frameworks|
|Standards and Bodies of Knowledge|
The incremental build model is a method of software development where the product is designed, implemented and tested incrementally (a little more is added each time) until the product is finished. It involves both development and maintenance. The product is defined as finished when it satisfies all of its requirements. This model combines the elements of the waterfall model with the iterative philosophy of prototyping.
The product is decomposed into a number of components, each of which is designed and built separately (termed as builds). Each component is delivered to the client when it is complete. This allows partial utilization of the product and avoids a long development time. It also avoids a large initial capital outlay and subsequent long waiting period. This model of development also helps ease the traumatic effect of introducing a completely new system all at once.
The incremental model applies the waterfall model incrementally.
The series of releases is referred to as “increments”, with each increment providing more functionality to the customers. After the first increment, a core product is delivered, which can already be used by the customer. Based on customer feedback, a plan is developed for the next increments, and modifications are made accordingly. This process continues, with increments being delivered until the complete product is delivered. The incremental philosophy is also used in the agile process model (see agile modeling).
The Incremental model can be applied to DevOps. In DevOps it centers around the idea of minimizing risk and cost of a DevOps adoption whilst building the necessary in-house skillset and momentum.
Characteristics of Incremental Model
- System is broken down into many mini development projects.
- Partial systems are built to produce the final system.
- First tackled highest priority requirements.
- The requirement of a portion is frozen once the incremented portion is developed.
- After each iteration, regression testing should be conducted. During this testing, faulty elements of the software can be quickly identified because few changes are made within any single iteration.
- It is generally easier to test and debug than other methods of software development because relatively smaller changes are made during each iteration. This allows for more targeted and rigorous testing of each element within the overall product.
- Customer can respond to features and review the product for any needed or useful changes.
- Initial product delivery is faster and costs less.
- Resulting cost may exceed the cost of the organization.
- As additional functionality is added to the product, problems may arise related to system architecture which were not evident in earlier prototypes
- Communication: helps to understand the objective.
- Planning: required as many people (software teams) work on the same project but different function at same time.
- Modeling: involves business modeling, data modeling, and process modeling.
- Construction: this involves the reuse software components and automatic code.
- Deployment: integration of all the increments.
- Pressman, Roger (2010). Software Engineering: A Practitioner's Approach. Boston: McGraw Hill. pp. 41–42. ISBN 9780073375977.
- Kim, Gene (22 January 2013). "DevOps distilled, Part 1: The three underlying principles" (PDF). IBM DeveloperWorks.
- www.softdevteam.com/ Incremental- lifecycle.asp
- What is Incremental model - advantages, disadvantages and when to use it
- Methodology:: Development Methods