Software Process Model:
A software process model represents the order in which the activities of software development
will be undertaken.
It describes the sequence in which the phases of the software lifecycle will be performed.
A software process model is a simplified representation of a software process.
Software process models:
Waterfall Model
Incremental development
Reuse-oriented software engineering
Waterfall Model:
• The waterfall model is a sequential approach, where each fundamental activity of a
process is represented as a separate phase, arranged in linear order.
• In the waterfall model, you must plan and schedule all of the activities before starting
working on them (plan-driven process).
• Plan-driven process is a process where all the activities are planned first, and the progress is
measured against the plan.
The phases of the waterfall model are:
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 clearly defined and 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.
Incremental Development:
Incremental development is based on the idea of developing an initial implementation, exposing this to user
feedback, and evolving it through several versions until an acceptable system has been developed.
The activities of a process are not separated but interleaved with feedback involved across those activities.
Each system increment reflects a piece of the functionality that is needed by the customer. Generally, the early
increments of the system should include the most important or most urgently required functionality.
Incremental Vs Waterfall Model
• Incremental software development is better than a waterfall approach for most businesses, e-
commerce, and personal systems.
• By developing the software incrementally, it is cheaper and easier to make changes in the software as it
is being developed.
Compared to the waterfall model, incremental development has three important benefits:
• The cost of accommodating changing customer requirements is reduced. The amount of analysis and
documentation that has to be redone is much less than what's required with the waterfall model.
• It’s easier to get customer feedback on the work done during development than when the system is
fully developed, tested, and delivered.
• More rapid delivery of useful software is possible even if all the functionality hasn’t been included.
Customers are able to use and gain value from the software earlier than it’s possible with the waterfall
model.
Disadvantages of Incremental development:
• Needs good planning and design.
• Needs a clear and complete definition of the whole system before it can be broken down and built
incrementally.
• Total cost is higher than waterfall.
Reuse-oriented Software Engineering:
It’s attempting to reuse an existing design or code (probably also tested) that’s similar to what’s required. It’s
then modified, and incorporated to the new system.
Although the initial “requirements specification” phase and the “validation ” phase are comparable with other
software processes, the intermediate phases in a reuse-oriented process are different.
These phases are:
• Component analysis: A search is made for the components to implement the given requirements
specification. Usually, there’s no exact match, and components may only provide some of the
functionality required.
• Requirements modification: During this phase, the requirements are analyzed using information
about the components that have been discovered. They are then modified to reflect the available
components. If the modifications are impossible, the component analysis activity may be re-
entered to search for alternative solutions.
• System design with reuse: During this phase, the framework of the system is designed or an
existing framework is reused. The designers take into account the components that are reused
and they will organize the framework accordingly. Some new software has to be designed if some
reusable components are not available.
• Development and integration: The components are integrated to create the new system. System
integration, in this model, maybe part of the development process rather than a separate activity.
There are basically three types of software components that can be used in a reuse-oriented
process:
• Web services that are developed according to well-known service standards and which will
become available for remote invocation.
• Collections of objects that are developed as a package to be integrated with a component
framework such as .NET or Java EE.
• Standalone software systems that are configured for use in a particular environment.
Advantages:-
1. It can reduce the overall cost of software development as compared to other model.
2. It can reduce the risk.
3. It can save the time of software development. b/c testing of component is minimize.
4. Faster delivery of software.
Disadvantages:-
1. Reuse-oriented model is not always practical in its pure form.
2. Compromises in Requirement may lead to a system that does not meet the real requirement of the user.
3.Organization using the reusable component, are not able to control the new version of component, this may lead to lost control over the system
evolution.
Software Process Activities:
The four basic process activities of specification, development, validation, and evolution are organized
differently in different development processes.
In the waterfall model, they are organized in sequence, whereas in incremental development they are
interleaved.
These activities are carried out depending on the type of software being developed, the experience and
competence of the developers, and the type of organization developing the software.
Software specification:
• Software specification or requirements engineering is the process of understanding and defining what
services are required from the system and identifying the constraints on the system’s operation and
development.
• Requirements engineering is a particularly critical stage of the software process, as mistakes made at this
stage inevitably lead to later problems in the system design and implementation.
• System developers need a more detailed system specification.
There are three main activities in the requirements engineering
process:
• Feasibility study: An estimate is made of whether the identified can be achieved using the current
software and hardware technologies, under the current budget, etc. The feasibility study should be
cheap and quick; it should inform the decision of whether or not to go ahead with the project.
• Requirements elicitation and analysis This is the process of deriving the system requirements through
observation of existing systems, discussions with potential users and procurers, task analysis, and so
on. This may involve the development of one or more system models and prototypes. These help you
understand the system to be specified.
• Requirements specification Requirements specification is the activity of translating the information
gathered during requirements analysis into a document that defines a set of requirements. Two types
of requirements may be included in this document. User requirements and system requirements.
• Requirements validation This activity checks the requirements for realism, consistency, and
completeness. During this process, errors in the requirements document are inevitably discovered. It
must then be modified to correct these problems.
Software Design And Implementation:
A software design is a description of the structure of the software to be implemented, data models, interfaces
between system components, and maybe the algorithms used.
Here’s an abstract model of the design process showing the inputs, activities, and documents to be produced
as output.
We’ve shown four main activities that may be part of the design process for information systems, and
they are:
Architectural design: It defines the overall structure of the system, the main components, their
relationships.
Interface design: It defines the interfaces between these components. The interface specification must
be clear. Therefore, a component can be used without having to know it’s implemented. Once the
interface specification is agreed upon, the components can be designed and developed concurrently.
Component design: Take each component and design how it will operate, with the specific design left to
the programmer, or a list of changes to be made to a reusable component.
Database design: The system data structures are designed and their representation in a database is
defined. This depends on whether an existing database is to be reused or a new database to be created.
These activities lead to a set of design outputs. The detail and representation vary based on the system
being developed.
Software Verification And Validation:
• Software validation is intended to show that a system both conforms to its specification and that it meets the
expectations of the customer.
• Validation may also involve checking processes, such as inspections or reviews at each stage of the software
process, from defining the requirements to the software development.
Testing has three main stages:
• Development (or component) testing: The components making up the system are tested by the people
developing the system. Each component is tested independently, without other system components.
• System testing: System components are integrated to create a complete system. This process is concerned
with finding errors that result from interactions between components. It is also concerned with showing that
the system meets its functional and non-functional requirements.
• Acceptance testing: This is the final stage in the testing process before the system is accepted for
operational use. The system is tested with data supplied by the system customer rather than using simulated
test data. It may reveal errors in the system requirements definition.
Software Evolution:
• Requirements are always changing, even after the system has been put into its operating
environment.
• There has always been a split between the process of software development and the process of
software evolution (software maintenance).
• This distinction is increasingly irrelevant, and it makes much more sense to see development and
maintenance as a continuum.
• It is more realistic to think of software engineering as an evolutionary process where software is
continually changed over its lifetime in response to changing requirements and customer needs.
Prototyping
• A prototype is a version of a system or part of the system that’s developed quickly to check the
customer’s requirements or feasibility of some design decisions.
• In prototyping, the client is involved throughout the development process, which increases the
likelihood of client acceptance of the final implementation.
• While some prototypes are developed with the expectation that they will be discarded, it is possible in
some cases to evolve from prototype to working system.
A software prototype can be used:
[1] In the requirements engineering, a prototype can help with the elicitation and validation of system
requirements.
[2] In the system design, a prototype can help to carry out design experiments to check the feasibility of
a proposed design.
The process of prototype development:
The phases of a prototype are:
• Establish objectives: The objectives of the prototype should be made explicit from the start of the process. Is
it to validate system requirements, or demonstrate feasibility, etc.
• Define prototype functionality: Decide what are the inputs and the expected output from a prototype. To
reduce the prototyping costs and accelerate the delivery schedule, you may ignore some functionality, such
as response time and memory utilization unless they are relevant to the objective of the prototype.
• Develop the prototype: The initial prototype is developed that includes only user interfaces.
• Evaluate the prototype: Once the users are trained to use the prototype, they then discover requirements
errors. Using the feedback both the specifications and the prototype can be improved. If changes are
introduced, then a repeat of steps 3 and 4 may be needed.
Incremental delivery:
• Incremental delivery is an approach to software development where some of the developed increments are
delivered to the customer and deployed for use in their working environment.
• In an incremental delivery process, customers define which of the services are most important and which are
least important to them.
• The allocation of services to increments depends on the service priority, with the highest priority services
implemented and delivered first.
• Once an increment is completed and delivered, it is installed in the customer’s normal working environment.
• They can experiment with the system, and this helps them clarify their requirements for later system
increments. As new increments are completed, they are integrated with existing increments so that system
functionality improves with each delivered increment.
Advantages
• It generates working software quickly during the software life cycle.
• The incremental model is more flexible; it will charge less cost to change scope and requirements.
• Very easy to handle, test and operate during the development life cycle.
• It has an opportunity for customers to respond to each and every build; provides flexibility in decision
making.
• Delivery cost is less than other software development methodologies.
• Easy to manage the total risk; risk management is incremental.
• Easy to change if there is anything wrong. That is due to smaller percentage of scope.
Disadvantages
• To obtain good results its needed proper planning and designing skills. Lack of skills will lead to gain losses
from development of software.
• Needs very clear definition before starting the division of whole system.
• It requires more customer involvement than the other linear approaches.
• Problems may occur due to integration between iteration.
Boehm’s Spiral Model:
• The spiral model is risk-driven where the process is represented as a spiral rather than a sequence of activities.
• It was designed to include the best features from the waterfall and prototyping models, and introduces a new
component; risk assessment.
• Each loop (from review till service — see figure below) in the spiral represents a phase. Thus the first loop might be
concerned with system feasibility, the next loop might be concerned with the requirements definition, the next
loop with system design, and so on.
Each loop in the spiral is split into four sectors:
• Objective setting: The objectives and risks for that phase of the project are defined.
• Risk assessment and reduction: For each of the identified project risks, a detailed analysis is conducted,
and steps are taken to reduce the risk. For example, if there’s a risk that the requirements are
inappropriate, a prototype may be developed.
• Development and validation: After risk evaluation, a process model for the system is chosen. So if the
risk is expected in the user interface then we must prototype the user interface. If the risk is in the
development process itself then use the waterfall model.
• Planning: The project is reviewed and a decision is made whether to continue with a further loop or
not.
The spiral model has been very influential in helping people think about iteration in software processes
and introducing the risk-driven approach to development.
Agile Software Development
• They involve customers in the development process to propose requirements changes.
• They minimize documentation by using informal communications rather than formal meetings with written
documents.
• They are best suited for applications where the requirements change rapidly during the development process.
• There are a number of different agile methods available such as: Scrum, Crystal, Agile Modeling (AM), Extreme
Programming (XP), etc.
Plan-driven and agile development
• Plan-driven development
-Separate, sequential development stages.
- Output from one stage is used to plan the next stage
- Can be incremental: each increment is planned up front.
• Agile development
- Specification, design, implementation in each cycle
- The primary output is the code itself.
- May still have some elements of more formal processes.
Requirements Engineering:
• The process of establishing the services that the customer requires from
a system and the constraints under which it operates and is developed.
• The requirements themselves are the descriptions of the system
services and constraints that are generated during the requirements
engineering process.
Types of requirements:
User requirements
• Statements in natural language plus diagrams of the services the system
provides and its operational constraints. Written for customers.
System requirements
• A structured document setting out detailed descriptions of the system’s
functions, services and operational constraints. Defines what should be
implemented so may be part of a contract between client and contractor.
Readers of different types of requirements
specification
Chapter 4 Requirements engineering 32
• Functional requirements
Statements of services the system should provide, how the system should react to particular inputs
and how the system should behave in particular situations.
• May state what the system should not do.
• Non-functional requirements
• Constraints on the services or functions offered by the system such as timing constraints, constraints
on the development process, standards, etc.
• Often apply to the system as a whole rather than individual features or services.
Functional requirements
• Describe functionality or system services.
• Depend on the type of software, expected users and the type of system where the software is
used.
• Functional user requirements may be high-level statements of what the system should do.
• Functional system requirements should describe the system services in detail.
Functional requirements for the MHC-PMS
• A user shall be able to search the appointments lists for all clinics.
• The system shall generate each day, for each clinic, a list of patients who are expected to attend
appointments that day.
• Each staff member using the system shall be uniquely identified by his or her 8-digit employee
number.
Non-functional requirements:
• These define system properties and constraints e.g. reliability, response time and storage
requirements. Constraints are I/O device capability, system representations, etc.
• Process requirements may also be specified mandating a particular IDE, programming language or
development method.
• Non-functional requirements may be more critical than functional requirements. If these are not
met, the system may be useless.
Types of nonfunctional requirement
Chapter 4 Requirements engineering 36
Non-functional classifications
• Product requirements
• Requirements which specify that the delivered product must behave in a particular way e.g.
execution speed, reliability, etc.
• Organisational requirements
• Requirements which are a consequence of organisational policies and procedures e.g.
process standards used, implementation requirements, etc.
• External requirements
• Requirements which arise from factors which are external to the system and its development
process e.g. interoperability requirements, legislative requirements, etc.
Chapter 4 Requirements engineering 37
Examples of nonfunctional requirements in
the MHC-PMS
Product requirement
The MHC-PMS shall be available to all clinics during normal working
hours (Mon–Fri, 0830–17.30). Downtime within normal working hours
shall not exceed five seconds in any one day.
Organizational requirement
Users of the MHC-PMS system shall authenticate themselves using
their health authority identity card.
External requirement
The system shall implement patient privacy provisions as set out in
HStan-03-2006-priv.
Chapter 4 Requirements engineering 38
The software requirements document
• The software requirements document is the official statement of what
is required of the system developers.
• Should include both a definition of user requirements and a
specification of the system requirements.
• It is NOT a design document. As far as possible, it should set of WHAT
the system should do rather than HOW it should do it.
Chapter 4 Requirements engineering 39
Users of a requirements document
Chapter 4 Requirements engineering 40
The structure of a requirements
document
Chapter Description
Preface This should define the expected readership of the document and describe
its version history, including a rationale for the creation of a new version
and a summary of the changes made in each version.
Introduction This should describe the need for the system. It should briefly describe the
system’s functions and explain how it will work with other systems. It
should also describe how the system fits into the overall business or
strategic objectives of the organization commissioning the software.
Glossary This should define the technical terms used in the document. You should
not make assumptions about the experience or expertise of the reader.
User requirements Here, you describe the services provided for the user. The nonfunctional
definition system requirements should also be described in this section. This
description may use natural language, diagrams, or other notations that
are understandable to customers. Product and process standards that
must be followed should be specified.
System architecture This chapter should present a high-level overview of the anticipated
system architecture, showing the distribution of functions across system
modules. Architectural components that are reused should be highlighted.
Chapter 4 Requirements engineering 41
The structure of a requirements document
Chapter Description
System This should describe the functional and nonfunctional requirements in more
requirements detail. If necessary, further detail may also be added to the nonfunctional
specification requirements. Interfaces to other systems may be defined.
System models This might include graphical system models showing the relationships between
the system components and the system and its environment. Examples of
possible models are object models, data-flow models, or semantic data models.
System evolution This should describe the fundamental assumptions on which the system is
based, and any anticipated changes due to hardware evolution, changing user
needs, and so on. This section is useful for system designers as it may help them
avoid design decisions that would constrain likely future changes to the system.
Appendices These should provide detailed, specific information that is related to the
application being developed; for example, hardware and database descriptions.
Hardware requirements define the minimal and optimal configurations for the
system. Database requirements define the logical organization of the data used
by the system and the relationships between data.
Index Several indexes to the document may be included. As well as a normal
alphabetic index, there may be an index of diagrams, an index of functions, and
so on.
Chapter 4 Requirements engineering 42
Requirements specification
• The process of writing don the user and system requirements in a
requirements document.
• User requirements have to be understandable by end-users and
customers who do not have a technical background.
• System requirements are more detailed requirements and may
include more technical information.
• The requirements may be part of a contract for the system
development
• It is therefore important that these are as complete as possible.
Chapter 4 Requirements engineering 43
Ways of writing a system requirements
specification
Notation Description
Natural language The requirements are written using numbered sentences in natural
language. Each sentence should express one requirement.
Structured natural The requirements are written in natural language on a standard form or
language template. Each field provides information about an aspect of the
requirement.
Design description This approach uses a language like a programming language, but with more
languages abstract features to specify the requirements by defining an operational
model of the system. This approach is now rarely used although it can be
useful for interface specifications.
Graphical notations Graphical models, supplemented by text annotations, are used to define the
functional requirements for the system; UML use case and sequence
diagrams are commonly used.
Mathematical These notations are based on mathematical concepts such as finite-state
specifications machines or sets. Although these unambiguous specifications can reduce
the ambiguity in a requirements document, most customers don’t
understand a formal specification. They cannot check that it represents what
they want and are reluctant to accept it as a system contract
Chapter 4 Requirements engineering 44
Requirements engineering processes
• The processes used for RE vary widely depending on the application
domain, the people involved and the organisation developing the
requirements.
• However, there are a number of generic activities common to all
processes
• Requirements elicitation;
• Requirements analysis;
• Requirements validation;
• Requirements management.
• In practice, RE is an iterative activity in which these processes are
interleaved.
Chapter 4 Requirements engineering 45
A spiral view of the requirements engineering
process
Chapter 4 Requirements engineering 46
Requirements elicitation and analysis
• Software engineers work with a range of system stakeholders to find
out about the application domain, the services that the system should
provide, the required system performance, hardware constraints,
other systems, etc.
• Stages include:
• Requirements discovery,
• Requirements classification and organization,
• Requirements prioritization and negotiation,
• Requirements specification.
Chapter 4 Requirements engineering 47
The requirements elicitation and analysis
process
Chapter 4 Requirements engineering 48
Process activities
• Requirements discovery
• Interacting with stakeholders to discover their requirements. Domain requirements are also
discovered at this stage.
• Requirements classification and organisation
• Groups related requirements and organises them into coherent clusters.
• Prioritisation and negotiation
• Prioritising requirements and resolving requirements conflicts.
• Requirements specification
• Requirements are documented and input into the next round of the spiral.
Requirements validation
• Concerned with demonstrating that the requirements define the
system that the customer really wants.
• Requirements error costs are high so validation is very important
• Fixing a requirements error after delivery may cost up to 100 times the cost of
fixing an implementation error.
Chapter 4 Requirements engineering 50
Requirements checking
• Validity. Does the system provide the functions which best support the
customer’s needs?
• Consistency. Are there any requirements conflicts?
• Completeness. Are all functions required by the customer included?
• Realism. Can the requirements be implemented given available budget and
technology
• Verifiability. Can the requirements be checked?
Chapter 4 Requirements engineering 51
Requirements validation techniques
• Requirements reviews
• Systematic manual analysis of the requirements.
• Prototyping
• Using an executable model of the system to check requirements. Covered in
Chapter 2.
• Test-case generation
• Developing tests for requirements to check testability.
Chapter 4 Requirements engineering 52
Requirements management
• Requirements management is the process of managing changing requirements
during the requirements engineering process and system development.
• New requirements emerge as a system is being developed and after it
has gone into use.
• You need to keep track of individual requirements and maintain links
between dependent requirements so that you can assess the impact
of requirements changes. You need to establish a formal process for
making change proposals and linking these to system requirements.
Chapter 4 Requirements engineering 53
Requirements management planning
• Establishes the level of requirements management detail that is
required.
• Requirements management decisions:
• Requirements identification Each requirement must be uniquely
identified so that it can be cross-referenced with other requirements.
• A change management process This is the set of activities that assess
the impact and cost of changes. I discuss this process in more detail in
the following section.
• Traceability policies These policies define the relationships between
each requirement and between the requirements and the system
design that should be recorded.
• Tool support Tools that may be used range from specialist requirements
management systems to spreadsheets and simple database systems.
Chapter 4 Requirements engineering 54
Requirements change management
• Deciding if a requirements change should be accepted
• Problem analysis and change specification
• During this stage, the problem or the change proposal is analyzed to check that it is valid.
This analysis is fed back to the change requestor who may respond with a more specific
requirements change proposal, or decide to withdraw the request.
• Change analysis and costing
• The effect of the proposed change is assessed using traceability information and general
knowledge of the system requirements. Once this analysis is completed, a decision is
made whether or not to proceed with the requirements change.
• Change implementation
• The requirements document and, where necessary, the system design and
implementation, are modified. Ideally, the document should be organized so that
changes can be easily implemented.
Chapter 4 Requirements engineering 55
Requirements change management
Chapter 4 Requirements engineering 56