Contents
Unit 2 Software Process Page No.
2.0 Structure of the Unit 1
2.1 Unit Outcomes 1
2.2 Activities in the software process, SDLC 1
2.3 Software process models: waterfall model 4
2.4 Incremental development model 4
2.5 Integration, and configuration model 6
2.6 Software prototyping model 5
2.7 Boehm’s spiral model 7
2.8 Self-Assessment Questions 8
2.9 Multiple Choice Questions (MCQs) 9
2.10 Keys to MCQs 9
2.11 Summary of the Unit 9
2.12 Keywords 10
2.13 Recommended Reading 11
OMC204 Software Engineering 1
Unit 2
Software Process
2.0 Structure of the Unit:
2.1 Unit Outcomes
2.2 Activities in the software process,
2.3 Software process models: waterfall model
2.4 Incremental development model
2.5 Re-use oriented model
2.6 Software Prototyping Model
2.7 Boehm’s Spiral Model
2.8 Self-Assessment Questions and Activities
2.9 Multiple-Choice Questions
2.10 Keys to Multiple-Choice Questions
2.11 Summary of the Unit
2.12 Keywords
2.13 Recommended Reading
2.1 Unit Outcomes
After the successful completion of this unit, the student will be able to:
1. Discuss the software process and SDLC.
2. Explain fundamental activities in the software process.
3. Compare SDLC models.
2.2 Activities in Software Process
A software process is defined as a collection of related activities for producing quality software. The
development of software is done using standard programming languages such as C, Java, Python, etc.
A modern approach is the use of readymade tools or developed software components. Reusing the
existing software reduces a lot of time and effort. A software process consists of four activities as
given below.
1.Software Specification
2.Software Design and Implementation
3.Software Validation
4.Software Evolution
1. Software Specification: The different functions in the software and the conditions under which it
is developed are defined in his step. In this phase, the requirement engineering process
is used to develop a requirement specification document that fulfills the
detailed system specification. There are two levels high-level statement is for
OMC204 Software Engineering Page 1
end-users and clients. The detailed design is for stakeholders such as system
managers, developers, etc. In the requirements engineering process, the
various steps are:
a) Feasibility Study
b) Requirement Elicitation and Analysis
c) Requirement Specifications
d) Requirement Validation
2. Software Design and Implementation: The requirement is converted into a design and
implemented using programming language to meet the requirement specification. The structure of
the software to be implemented is given by the software design. The system components,
interfaces, database, and architecture designs are produced in this stage. The design can be top-
down, bottom-up, structured, etc. Object-oriented design and procedure-oriented designs are
prepared using standard tools and techniques. Software implementation is done using
programming languages such as C, Python, Java, C++, and other supporting packages. The
programming style is dependent on the individual programmer.
3. Software Validation: The software is verified whether it is fulfilling the requirements of the client.
Here the programs are tested using test data. Whether the developed system
is meeting the customer’s requirements or not is validated in this step. Unit
testing, system testing, and acceptance testing are some examples of
software validation steps.
4. Software Evolution: The software must get refined to meet the needs of the customers. The
software is considered flexible. The software is part of a complex system that requires continuous
modification. Software evolution refers to software maintenance or accommodating changes in
the software over time.
Along with the above-mentioned activities, the process description must include three more
important factors as given below.
a) Products: Products are the outcomes of the activities of the software process.
For example, the blueprint or architectural design of a house before
construction.
b) Roles: Roles describe the responsibilities of the people involved. For example,
project manager, software developer, maintenance engineer, etc.
c) Pre- and post-conditions: The conditions to be maintained during the
development of the software product. For example, consider office
automation software, a pre-condition is covering all the requirements of the
user and a post-condition is preparing the design using modern tools to
describe the structure or framework of the model.
There is no common software process for all the applications. The software process is complex and
creative based on the decisions taken by the people. The people involved in the software process are
clients, developers, managers, administrators, etc. The major classification of the software process is
plan-based and agile. In the plan-based software process, requirements are fixed, and plans are concrete
and not changed. In the agile software process, the software process steps are flexible and are changed
OMC204 Software Engineering Page 2
as per changes in the requirements. The architecture or framework of the software process can be
represented using various models. The activities in the software process are described using an abstract
model known as the software development life cycle (SDLC). The SDLC model includes all the stages
in software development from requirement specification to the maintenance of the software.
2.3 Software Process Models
The software process models represent the generic or partial information of a
software process. It does not depict any specific activity of programming but
shows the framework. The process models discussed in this section are:
1. The Waterfall Model
2. The Incremental Development Approach
3. Re-use-oriented SE
4. Prototyping Models
5. Boehm’s Spiral Model
The Waterfall Model
The waterfall model is developed in 1970 for representing a simple system
engineering process by a scientist Royce. In this model, there is cascading of one
phase from another like a waterfall. Another common name used for this model
is the software life cycle. The phases of the waterfall model are described as
follows:
1. The requirement definition phase: Used to collect information about what
a client wants.
2. The design phase: Used to prepare the architecture or a blueprint of the
software to be developed.
3. The implementation and unit testing: These phases are used to convert
the design into computer programs. Unit testing refers to testing small
computer program components.
4. The integration and testing phase: These phases are used to combine all
the components developed and test the complete software system.
5. Operating and maintenance phase: The last phase is where the software
system is used and tested in the customer’s workspace. The maintenance
phase is used to accommodate new requirements.
The waterfall model is depicted in Figure 2.1.
OMC204 Software Engineering Page 3
Figure 2.1 The Waterfall Model
The important characteristics of the waterfall model are:
A software development process consists of several phases in sequence.
A phase can be started only after the completion of the previous phase.
This development model is sequential; the phases do not overlap each
other.
Work can be divided, according to phases, among different classes of
experts.
Advantages: Simple and easy to understand. All phases are processed one
at a time and well documented. It is well suited for smaller software
systems. The progress can be tracked more accurately. It reduces
development and maintenance costs.
Disadvantages: The waterfall model is rigid. This is not a good model for
complex or long-ongoing software systems. If requirements change
midway, it is difficult to accommodate those in this model. There is no
working software produced till the very end of the life cycle as integration
is generally done towards the end of the software life cycle.
2.4 Incremental Development Model
The incremental development model is used to produce an initial software,
deliver it to the user, understand the user’s feedback, and then arrive at the
final product version. Incremental software development is based on agile
software development. The software is developed in parts, if there is any
mistake, it is possible to go back and correct it easily as compared to the
waterfall model. The phases of the incremental software development model
are given as follows:
1. Specification: Collect the requirements from the client and prepare system
specifications.
2. Development: Prepare a design or model of the software and complete
programming.
3. Validation: Test the developed software to ensure that the client’s
requirements are fulfilled.
OMC204 Software Engineering Page 4
Figure 2.2 Incremental Development Software Model
The versions shown in the above figure are referred to as increments. At the initial stage, urgent work
is included in the system. Then the additional functions are added based on the response given by
the customer. The important features of incremental development are given as follows.
1. Software product is developed in increments or steps.
2. First a few functions are developed to get a working model of the software. Later more
functions are added.
3. The requirements are collected using a fixed method like the Waterfall Model. But coding,
integration, and testing are done incrementally.
4. Incremental software development uses a mix of both planned and agile software processes.
5. Advantages: Users' changes can be incorporated. The most important functionality is
developed first with better quality. Time taken is less. Testing functions, error detection, and
correction are easier.
6. Drawbacks: Preparing multiple versions of the software product can be very costly.
Upgrading software many times can lead to time delay and frequency changes can corrupt the
structure. Involving clients is necessary for an incremental development model. Such kinds of
customer-developer contracts are not very usual.
2.5 Re-use-oriented Model
When the projects are similar, there is some reuse of the software. When a software development team
has already handled a similar project, they look for existing software components and tend to reuse
them. In the 21st century, software component reuse becomes official with the support of a store of
reusable software components. These components are referred to as components of off-the-shelf
systems (COTs). The reuse-oriented software development model utilizes COTs in its different
phases. For example, word processing, search options, paint palette, etc. can be used as COTs in
banking software. The reuse-based software process model is shown in Figure 2.3.
OMC204 Software Engineering Page 5
Figure 2.3 Re-use-based Software Development Model
The phases of this model are as follows:
a) Specify Requirements: Collect the requirements. Analyze Components:
b) Modify the software components as per new requirements
c) Develop the software with reusable components. If they are not available, develop originals. The
reusable components include available web services, project objects available to fit in the .net
or .java framework, or stand-alone software systems.
d) Validate the entire developed system.
2.6 Software Prototyping Model
In this model, a working prototype of the software is given to the user for comments and feedback. It
helps the user to give all their requirements in a more detailed fashion. A prototype means a starting
version of a software system. This initial version illustrates different concepts, design layouts, etc.
Based on the prototype, problems or loopholes and related remedies can be found. A prototype is an
initial version of a software system that is used to demonstrate the concepts and design of the software.
A prototyping model clarifies and validates the requirements. The design ideas and interface between
the different parts of the software design can be explored using prototypes. The prototyping model is
developed into two types.
a) Evolutionary Prototyping: In this model, a prototype is developed and used by the clients.
Based on the feedback, it is refined by including the additions. This model is modified in several
iterations. It begins with the requirements that are best understood. The different steps in the
evolutionary model are shown in Figure 2.4.
OMC204 Software Engineering Page 6
Figure 2.4 Evolutionary Prototyping Model
The important features of the evolutionary prototyping model as given below.
1 The evolutionary computing model is useful when the system specifications are now
known beforehand. Some examples include artificial intelligence, machine learning, and
user interface systems.
2 Evolutionary prototyping builds a system as a set of increments and is delivered to
customers.
3 Rapid software development with reusable components, computer-aided software
engineering (CASE) tools, and 4GL are based on evolutionary prototyping. The
interfaces are built using GUI.
4 The advantage of the evolutionary prototyping model is it gives a quick delivery of
software products. It also involves clients using the system from its initial development to
the final.
5 The drawback of the evolutionary model is it requires specialist skills to accommodate
the changes.
6 The maintenance is expensive due to continuous changes. The system structure may get
corrupt due to continuous maintenance. There are management and contractual problems
in evolutionary prototyping models.
b) Throw-away Prototyping: System requirements are derived in this model. The software process
of this type starts with requirements that are poorly understood. The prototype is developed as a
trial version and given for experimentation and then it is discarded. Thus, it is not considered a
final product. The stages of throw-away prototyping are depicted in Figure 2.5. Here the initial
version of the software is developed only temporarily to get detailed requirements from the user.
This is then thrown away and a revised version of the software is developed using the Waterfall
Model or some other model.
Figure 2.5 Throw-away Prototyping Model
The important features of the throe-away prototyping model as given below.
1. The software product delivery is fast as the throw-away prototype is developed using rapid
software development tools.
2. It clarifies requirements.
OMC204 Software Engineering Page 7
3. It includes reusable, COTS components and involves customers in the development of the
software product.
2.7 Boehm’s Spiral Model
The spiral model is developed by scientist Barry Boehm in 1986. The spiral model is also known as the
Meta Model as it is made of characteristics of different models such as waterfall, incremental and
evolutionary models. The spiral model produces the software quickly and it is flexible in accommodating
changes in requirements and design. It has good documentation control, and it satisfies customers with
risk management features. The spiral model includes four quadrants with different activities of software
development as shown in Figure 2.6.
Figure 2.6 Boehm’s Spiral Model
A spiral model is an iterative approach and there is a spiral for each phase of software development. In
each spiral or cycle, the specific activity of software engineering such as requirement specification,
design, coding, etc. takes place. This activity can be like any other model such as waterfall, prototyping,
or incremental. The spiral model is risk-driven, and it identifies and assesses risk in activities. It combines
customer satisfaction, approval, and documentation control. Each loop in the spiral model includes four
sectors as given below.
1) Objectives: Define the objectives, constraints, management plan, etc for the software product.
Identify the project risks and alternative strategies if required. This step is the starting point of the
spiral model. The objectives are concerned with the functionality and performance of the software
product.
2) Assessing and reducing risks: Assess the risks and perform a detailed analysis and steps to reduce
risks. For example, if risks are inappropriate, then develop a prototype for the system to
understand the needs. The initial model can be further used to incorporate the remaining features.
In this step, risks are resolved using activities related to information collection.
3) Development and Validation: In this step, a model is selected after the risk evaluation. Throw-
away prototyping can be used if there are risks in user interaction. A formal system model is
OMC204 Software Engineering Page 8
helpful if there are safety risks. Risks may be related o finance, new programming language,
compiler, etc.
4) Planning: In this step, based on the risk evaluation, a decision is taken on whether to continue
with the project. If the project is to be continued, then plans for the next phases are drawn. Steps
in project management related to preparing schedules, cost estimation, and manpower are planned
in this step.
The important characteristics of the spiral model are as follows.
1) The spiral model is used for large and complex projects in software engineering.
2) The phases in the spiral model are planning, analyzing risks, engineering that includes coding and
software deploying, and software evaluation by customers.
3) The spiral model is useful if there are frequent changes in requirements, unclear and complex.
4) Cost estimation is easy and software deployment is faster in the spiral model.
5) There are several advantages to the Spiral model, but it works for large projects and requires a
risk assessment. Thus, it is not suitable for small projects.
6) Documentation in the spiral model is more as there are many intermediate steps.
7) The risk assessment in the spiral model may not meet the schedule or budget of the project.
2.8 Self-Assessment Questions and Activities
1) Explain the phases of the waterfall model.[L1, 5 Marks]
2) Discuss the advantages of the software-reuse model in software development. [L2, 4 Marks]
3) How the waterfall model is different from other models? [L2, 5 Marks]
4) Discuss the drawbacks of the waterfall model. [L3, 5 Marks]
5) What are the types of prototyping models? Discuss with suitable examples. [L1, 5 Marks]
6) Explain the different sectors in the spiral model. [L1, 5 Marks]
7) Discuss the strengths and weaknesses of the spiral model.
8) What are the limitations of the waterfall model? How the spiral model addresses these issues?
2.9 Multiple Choice Questions (MCQs)
1) If a newcomer college student is assigned software development, which SDLC is suitable?[L2, 1 Mark]
A. Waterfall Model
B. Throw-away Prototyping
C. Evolutionary Prototyping
D. Spiral Model
2) Which of the following a model can be used for risk analysis? [L1, 1 Mark]
A. Spiral Model
B. Prototyping Model
C. Waterfall Model
D. None of the above
3) Waterfall model is not suitable for___ [L1, 1 Mark]
A. Accommodating changes
B. Large complex project
OMC204 Software Engineering Page 9
C. Small projects
D. Testing projects
4) Which of the following is not a phase in the software development model? [L1, 1 Mark]
A. Requirement gathering
B. Feasibility study
C. Requirement validation
D. Prototyping
5) The most fundamental model for software process is____ [L1, 1 Mark]
A. Waterfall Model
B. Evolutionary Prototyping
C. Throw-away Prototyping
D. Incremental Development
2.10 Keys to MCQs
1) Throw-away Prototyping (B)
2) Spiral Model (A)
3) Accommodating Changes (A)
4) Prototyping (D)
5) Waterfall Model (A)
2.11 Summary of the Unit
The software process is represented using abstract models known as the software development life cycle
(SDLC) model. The fundamental SDLC model is the waterfall model, used when the requirements are
well known. The SDLC models are incremental development, prototyping, spiral model, etc. The
commonly used SDLC models are the evolutionary and throw-away prototyping model, spiral model,
incremental development model, rapid application model, V model, waterfall model, etc. The spiral
model is flexible and can accommodate changes in the requirements and assess the risks. A throw-away
prototyping model is used to understand the system requirements.
2.12 Keywords
SDLC
Waterfall Model
Incremental Model
Re-use-oriented Model
Prototype Model
Spiral Model
2.13 Recommended Reading
1. https://nptel.ac.in/courses/106101061
2. Sommerville, Ian. (2010). Software Engineering, 10th Ed., Addison-Wesley
3. Jalote, Pankaj. (1997). An Integrated Approach to Software Engineering, Springer Science and
Business Media.
4. Mall Rajib. (2014), Fundamentals of Software Engineering, 4th Ed., PHI Publication.
OMC204 Software Engineering Page 10
OMC204 Software Engineering Page 11