Sunteți pe pagina 1din 3

The Waterfall Model was first Process Model to be introduced.

It is also referred to as a
linear-sequential life cycle model. It is very simple to understand and use. In a waterfall
model, each phase must be completed fully before the next phase can begin. This type of
model is basically used for the for the project which is small and there are no uncertain
requirements. At the end of each phase, a review takes place to determine if the project is on
the right path and whether or not to continue or discard the project. In this model the testing
starts only after the development is complete. In waterfall model phases do not overlap.

Diagram of Waterfall-model:

Advantages of waterfall model:

This model is simple and easy to understand and use.

It is easy to manage due to the rigidity of the model each phase has specific
deliverables and a review process.

In this model phases are processed and completed one at a time. Phases do not
overlap.
Waterfall model works well for smaller projects where requirements are very well
understood.

Disadvantages of waterfall model:

Once an application is in the testing stage, it is very difficult to go back and change
something that was not well-thought out in the concept stage.

No working software is produced until late during the life cycle.

High amounts of risk and uncertainty.

Not a good model for complex and object-oriented projects.

Poor model for long and ongoing projects.

Not suitable for the projects where requirements are at a moderate to high risk of
changing.

When to use the waterfall model:

This model is used only when the requirements are very well known, clear and fixed.

Product definition is stable.

Technology is understood.

There are no ambiguous requirements

Ample resources with required expertise are available freely

The project is short.

Very less customer enter action is involved during the development of the product. Once the
product is ready then only it can be demoed to the end users. Once the product is developed
and if any failure occurs then the cost of fixing such issues are very high, because we need to
update everywhere from document till the logic.

Waterfall Model Phases


The first formal declaration or description of the Waterfall model occurred in an article that
Winston W. Royce wrote in 1970. Royce defined seven phases or steps in his description,
which, although slightly renamed based on the academic or person writing about the method,
have remained consistent to this day.
Requirements: During the requirements phase, brainstorming and research regarding the
project is conducted. Ultimately, the purpose of the system or application to be developed is
determined or agreed upon.

Design (Basic): The software systems (high level) basic design is thought out and described.
However, this phase is not yet at the technical detail level. Tools such as UML and even
prototype software can be developed based on the processes in place for the project team.

Technical Design (Detailed): Functions of all software components and engineering


modules or units are determined. Technical specifications are created in this stage at the level
that can be handed off to the implementation team at the phases conclusion.

Implementation: Source code is written to implement the detailed design created in the
previous phase.

Testing (Verification): The project design is tested to ensure that it accomplishes the goals
and tasks laid out for the system. Any errors in the previous phases will arise in this stage of
the project.

Integration: The project team deploys or places the system in service once testing is
completed. For extremely large projects or systems, the integration phase can prove to be one
of the most challenging if the testing phase does not suitably simulate the deployment
environment.

Maintenance: The maintenance phase ensures that the software or system works as intended.
For modern project teams, this phase can become a project of its own based on the
development contract terms with the customer.

The Waterfall model is intended to progress to the next step in the development process
without looking backwards. The process can have a number of advantages and disadvantages
based on the goals of the development team trying to determine what process to implement.

S-ar putea să vă placă și