2013
By : Ms.Pintukumari Bera
There are various software development approaches defined and designed which
are used/employed during development process of software, these approaches are
also referred as "Software Development Process Models".
Each process model follows a particular life cycle in order to ensure success
in process of software development.
1. WATERFALL MODEL
Waterfall approach was first Process Model to be introduced and followed widely
in Software Engineering to ensure success of the project. In "The Waterfall"
approach, the whole process of software development is divided into separate
process phases.
System & Software Design: Before a starting for actual coding, it is highly
important to understand what we are going to create and what it should look
like? The requirement specifications from first phase are studied in this phase
and system design is prepared. System Design helps in specifying hardware and
CH:5 SDLC MODELS Date: Aug.2013
By : Ms.Pintukumari Bera
system requirements and also helps in defining overall system architecture. The
system design specifications serve as input for the next phase of the model.
Implementation & Unit Testing: On receiving system design documents, the work
is divided in modules/units and actual coding is started. The system is first
developed in small programs called units, which are integrated in the next phase.
Each unit is developed and tested for its functionality; this is referred to as Unit
Testing. Unit testing mainly verifies if the modules/units meet their specifications.
Integration & System Testing: As specified above, the system is first divided in
units which are developed and tested for their functionalities. These units are
integrated into a complete system during Integration phase and tested to check if
all modules/units coordinate between each other and the system as a whole
behaves as per the specifications. After successfully testing the software, it is
delivered to the customer.
Operations & Maintenance: This phase of "The Waterfall Model" is virtually never
ending phase (Very long). Generally, problems with the system developed (which
are not found during the development life cycle) come up after its practical use
starts, so the issues related to the system are solved after deployment of the
system. Not all the problems come in picture directly but they arise time to time
and needs to be solved; hence this process is referred as Maintenance.
Advantages
The advantage of waterfall development is that it allows for departmentalization
and managerial control. A schedule can be set with deadlines for each stage of
development and a product can proceed through the development process like a
car in a carwash, and theoretically, be delivered on time. Development moves
CH:5 SDLC MODELS Date: Aug.2013
By : Ms.Pintukumari Bera
from concept, through design, implementation, testing, installation,
troubleshooting, and ends up at operation and maintenance. Each phase of
development proceeds in strict order, without any overlapping or iterative steps.
Disadvantages
The disadvantage of waterfall development is that it does not allow for much
reflection or revision. 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. Alternatives to the waterfall model include joint application development
(JAD), rapid application development (RAD), synch and stabilize, build and fix,
and the spiral model.
Well, at least that's the way it's supposed to work theoretically. In reality, there are
a number of problems with this theoretical model, and these can cause delays and
knock-on errors in the rest of the process. This article discusses some of the more
CH:5 SDLC MODELS Date: Aug.2013
By : Ms.Pintukumari Bera
common problems that project managers experience during this phase, and
suggests possible solutions.
Possibly the most common problem in the requirements analysis phase is that
customers have only a vague idea of what they need, and it's up to you to ask the
right questions and perform the analysis necessary to turn
this unstructured vision into a formally-documented
software requirements specification that can, in turn, be used as the basis for both
a project plan and an engineering architecture.
Ensure that you spend sufficient time at the start of the project on
understanding the objectives, deliverables and scope of the project.
Make visible any assumptions that the customer is using, and critically
evaluate both the likely end-user benefits and risks of the project.
Attempt to write a concrete vision statement for the project, which
encompasses both the specific functions or user benefits it provides and the
overall business problem it is expected to solve.
Get your customer to read, think about and sign off on the completed
software requirements specification, to align expectations and ensure that
both parties have a clear understanding of the deliverable.
2. Iterative Model
An iterative lifecycle model does not attempt to start with a full specification of
requirements. Instead, development begins by specifying and implementing just
part of the software, which can then be reviewed in order to identify
further requirements. This process is then repeated, producing a new version of
CH:5 SDLC MODELS Date: Aug.2013
By : Ms.Pintukumari Bera
the software for each cycle of the model. Consider an iterative lifecycle model
which consists of repeating the following four phases in sequence:
A Requirements phase, in which the requirements for the software are gathered
and analyzed. Iteration should eventually result in a requirements phase that
produces a complete and final specification of requirements.
An Implementation and Test phase, when the software is coded, integrated and
tested.
A Review phase, in which the software is evaluated, the current requirements are
reviewed, and changes and additions to requirements proposed.
For each cycle of the model, a decision has to be made as to whether the software
produced by the cycle will be discarded, or kept as a starting point for the next
cycle (sometimes referred to as incremental prototyping). Eventually a point will
be reached where the requirements are complete and the software can be
CH:5 SDLC MODELS Date: Aug.2013
By : Ms.Pintukumari Bera
delivered, or it becomes impossible to enhance the software as required, and a
fresh start has to be made.
3. V-Model
Verification Phases
1. Requirements analysis:
2. System Design:
3. Architecture Design:
This phase can also be called as high-level design. The baseline in selecting
the architecture is that it should realize all which typically consists of the
list of modules, brief functionality of each module, their interface
relationships, dependencies, database tables, architecture diagrams,
technology details etc. The integration testing design is carried out in this
phase.
CH:5 SDLC MODELS Date: Aug.2013
By : Ms.Pintukumari Bera
4. Module Design:
This phase can also be called as low-level design. The designed system is
broken up in to smaller units or modules and each of them is explained so
that the programmer can start coding directly. The low level design
document or program specifications will contain a detailed functional logic
of the module, in pseudo code - database tables, with all elements,
including their type and size - all interface details with complete API
references- all dependency issues- error message listings- complete input
and outputs for a module. The unit test design is developed in this stage.
4. Spiral Model
CH:5 SDLC MODELS Date: Aug.2013
By : Ms.Pintukumari Bera
Figure:
History
The spiral model was defined by Barry Boehm in his 1988 article A Spiral Model
of Software Development and Enhancement. This model was not the first model
to discuss iterative development, but it was the first model to explain why the
iteration matters. As originally envisioned, the iterations were typically 6 months
to 2 years long. Each phase starts with a design goal and ends with the client
(who may be internal) reviewing the progress thus far. Analysis and engineering
efforts are applied at each phase of the project, with an eye toward the end goal
of the project.
The spiral model, also known as the spiral lifecycle model, is a systems
development method (SDM) used in information technology (IT). This model of
development combines the features of the prototyping model and the
waterfall model. The spiral model is intended for large, expensive, and
complicated projects.
Advantages
CH:5 SDLC MODELS Date: Aug.2013
By : Ms.Pintukumari Bera
1. Estimates (i.e. budget, schedule, etc.) become more realistic as work
progresses, because important issues are discovered earlier.
2. It is more able to cope with the (nearly inevitable) changes that software
development generally entails.
3. Software engineers (who can get restless with protracted design processes)
can get their hands in and start working on a project earlier.
Disadvantages
The Big Bang model is SDLC model where we do not follow any specific process.
The development just starts with the required money and efforts as the input, and
the output is the software developed which may or may not be as per customer
requirement.
Usually this model is followed for small projects where the development teams
are very small.
CH:5 SDLC MODELS Date: Aug.2013
By : Ms.Pintukumari Bera
This model is ideal for small projects with one or two developers working
together and is also useful for academic or practice projects. It.s an ideal model
for the product where requirements are not well understood and the final release
date is not given.
However the Big Bang model is a very high risk model and changes in the
requirements or misunderstood requirements may even lead to complete reversal
or scraping of the project. It is ideal for repetitive or small projects with minimum
risks.
Following table lists out the pros and cons of Big Bang Model:
Pros Cons
Little or no planning
Not a good model for complex and
6. Prototyping Model
Requirements gathering
Quick decision
Customer evolution
CH:5 SDLC MODELS Date: Aug.2013
By : Ms.Pintukumari Bera
Customer suggestions accepted by cust.
Design
Implement
Test
Maintain