Английская Википедия:Incremental build model
Шаблон:Software development process 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. According to the Project Management Institute, an incremental approach is an "adaptive development approach in which the deliverable is produced successively, adding functionality until the deliverable contains the necessary and sufficient capability to be considered complete."Шаблон:SfnШаблон:Rp
The product is decomposed into a number of components, each of which is designed and built separately (termed as builds).Шаблон:SfnШаблон:Rp 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.
Incremental model
The incremental model applies the waterfall model incrementally.[1]
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).[1]Шаблон:SfnШаблон:Rp
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.[2]
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.
Disadvantages[5]
- 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
Tasks involved
These tasks are common to all the models[1]
- 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.
See also
Citations
References
External links
- Methodology::Development Models Шаблон:Webarchive
- Incremental lifecycle
- What is Incremental model - advantages, disadvantages and when to use it
- Incremental Model in Software Engineering