KEMBAR78
Software Engeering | PDF | Software Development | Feasibility Study
0% found this document useful (0 votes)
434 views120 pages

Software Engeering

The document discusses the software engineering crisis, with 53% of projects going over budget, 31% being cancelled, and failures costing companies significant money. It notes that software has become more complex as problems have increased in size. Traditional software development faces challenges like unclear requirements, difficulty measuring progress, and an inability to find all errors before release. The document introduces software engineering as a way to systematically develop reliable software on time and budget through practices like documentation, defined processes, and open collaboration on code. However, common myths persist around the misconceptions that software is easy to change or will work perfectly the first time. Overall, the document outlines the problems in traditional software development and introduces software engineering principles as an approach to addressing these challenges

Uploaded by

Sanjana Sharma
Copyright
© Attribution Non-Commercial (BY-NC)
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as DOC, PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
434 views120 pages

Software Engeering

The document discusses the software engineering crisis, with 53% of projects going over budget, 31% being cancelled, and failures costing companies significant money. It notes that software has become more complex as problems have increased in size. Traditional software development faces challenges like unclear requirements, difficulty measuring progress, and an inability to find all errors before release. The document introduces software engineering as a way to systematically develop reliable software on time and budget through practices like documentation, defined processes, and open collaboration on code. However, common myths persist around the misconceptions that software is easy to change or will work perfectly the first time. Overall, the document outlines the problems in traditional software development and introduces software engineering principles as an approach to addressing these challenges

Uploaded by

Sanjana Sharma
Copyright
© Attribution Non-Commercial (BY-NC)
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as DOC, PDF, TXT or read online on Scribd
You are on page 1/ 120

[CHAPTER 1]

 Why Software Engineering


 Change in nature & complexity of
software
 Concept of one “guru” is over
 We all want improvement
Ready for change

 The Evolving Role of Software


Software industry is in Crisis!
• Failure 31%
• Success 16%
• Over budget53%

failure
success
over budget

 The Evolving Role of Software


This is the sorry state of software
engineering today!
a) Completed Late, over budget,
and/or with features missing-49%

1
b) Successful-28%
c)Cancelled-23%
L [Data on 28,000 projects
Completed in 2000]

ca
nce
lle
d

su
cce
ssfu
l

com p
leted
la
te,o
ve rb
udg
et

As per the IBM report, “31% of the project gets


cancelled before they are completed, 53%
overrun their cost estimates by an average of
189% and for every 100 projects, and there are
94 restarts”
 The Evolving Role of Software

2
Relative cost of Hardware and Software

 The Evolving Role of Software


• Unlike Hardware
-Moore’s law: processor
speed/memory capacity doubles every
two years

 The Evolving Role of Software


Managers and Technical Persons are
asked:
 Why does it take so long to get
the program finished?

3
 Why are costs so high?
 Why can not we find all errors
before release?
 Why do we have difficulty in
measuring progress of software
development?
 Factors Contributing to the
Software Crisis
• Larger problems,
• Lack of adequate training in software
engineering,
• Increasing skill shortage,
• Low productivity improvements.

 Some Software failures


A simple fix took care of the problem…but the
programmers decided to see if they could
come up with a systematic way to eliminate
these generic sorts of bugs in the future. A
random group of programmers applied this
system to the fuel dump module and other
modules.
[Seventeen additional, previously
unknown problems surfaced!]
 Some Software failures
Financial Software
Many companies have experienced failures in
their accounting system due to faults in the

4
software itself. The failures range from
producing the wrong information to the whole
system crashing.
 Some Software failures
Windows XP
 Microsoft released Windows XP on October
25, 2001.
 On the same day company posted 18 MB
of compatibility patches on the website for
bug fixes, compatibility updates, and
enhancements.
 Two patches fixed important security
holes.
This is Software Engineering.

 Documentation consists of
different types of manuals are
1. Analysis (a) Formal
/Specification Specification

(b ) Context-
Diagram

(c) Data Flow

5
Diagrams

(a) Flow Charts

2. Design (b) Entity-


Relationship
Diagram
Documentation
Manuals
(a) Source
Code
3. Implementation Listings

(b) Cross-
Reference
Listing

4. Testing (a) Test Data

(b) Test
Results

List of documentation manuals

 Documentation consists of
different types of manuals are

(a) System
Overview

6
1)User (b) Beginner’s
Guide
Manuals Tutorial
(c)
Reference Guide

Operating
Procedures
(a)
Installation Guide

2) Operational
Manuals
(b) System
Administrati
on Guide

List of operating procedure manuals

 Software Product
• Software products may be developed for a
particular customer or may be developed for a
general market
• Software products may be
–Generic - developed to be sold to a range of
different customers
–Bespoke (custom) - developed for a single
customer according to their specification

7
 Software Characteristics:
Comparison of constructing a bridge vis-à-
vis writing a program.
Sr. Constructing a Writing a program
No bridge

1 The problem is well Only some parts of the


understood problem are
understood, others are not
2 There are many Every program is different
existing bridges and designed for special
applications.
3 The requirement for a Requirements typically
bridge typically do change during all phases of
not change much development.
during construction
4 The strength and Not possible to calculate
stability of a bridge correctness of a program
can be calculated with existing methods.
with reasonable
precision
5 When a bridge When a program fails, the
collapses, there is a reasons are often
detailed investigation unavailable or even
and report deliberately concealed.
6 Engineers have been Developers have been
constructing bridges writing programs for 50
for thousands of years or so.
years

8
7 Materials (wood, Hardware and software
stone, and iron, steel) changes rapidly.
and techniques
(making joints in
wood, carving stone,
and casting iron)
change slowly.
 What is software engineering?
Software engineering is an engineering
discipline which is concerned with all aspects of
software production
Software engineers should
– adopt a systematic and organized approach
to their work
– use appropriate tools and techniques
depending on
• The problem to be solved,
• The development constraints and
– use the resources available
 What is software engineering?
At the first conference on software engineering
in 1968, Fritz Bauer defined software
engineering as “The establishment and use of
sound engineering principles in order to obtain
economically developed software that is
reliable and works efficiently on real
machines”.
Stephen Schach defined the same as “A
discipline whose aim is the production of
quality software, software that is delivered on

9
time, within budget, and that satisfies its
requirements”.
Both the definitions are popular and acceptable
to majority.
However, due to increase in cost of maintaining
software, objective is now shifting to produce
quality software that is maintainable, delivered
on time, within budget, and also satisfies its
requirements.
 Software Process
The software process is the way in which we
produce software.
Why is it difficult to improve software process ?
• Not enough time
• Lack of knowledge
 The Changing Nature of Software
Trend has emerged to provide source code to
the customer and organizations.
Software where source codes are available are
known as open source software.
Examples
Open source software: LINUX, MySQL, PHP,
Open office, Apache webserver etc.
 Software Myths (Management
Perspectives)
Management may be confident about good
standards and clear procedures of the
company.
[But the taste of any food item is in the eating;
not in the Recipe !]

10
Company has latest computers and state-of-
the-art software tools, so we shouldn’t worry
about the quality of the product.
[The infrastructure is only one of the several
factors that determine the quality of the
product!]
Software is easy to change
[The reality is totally different.]
Computers provide greater reliability than the
devices they replace [This is not always true.]
 Software Myths (Customer Perspectives)
A general statement of objectives is sufficient
to get started with the development of
software. Missing/vague requirements can
easily be incorporated/detailed out as they get
concretized.
[If we do so, we are heading towards a
disaster.]
Software with more features is better software
Software can work right the first time
[Both are only myths!]
 Software Myths (Developer Perspectives)
Once the software is demonstrated, the job is
done.
[Usually, the problems just begin!]
Software quality can not be assessed before
testing.
[However, quality assessment techniques
should be used through out the software
development life cycle.]

11
The only deliverable for a software
development project is the tested code.
[Tested code is only one of the deliverable!]
Aim is to develop working programs
[Those days are over. Now objective is to
develop good quality maintainable programs!]
 Some Terminologies
1. Deliverables and Milestones
Different deliverables are generated during
software development.
The examples are source code, user manuals,
operating procedure manuals etc.
The milestones are the events that are used to
ascertain the status of the project. Finalization
of specification is a milestone. Completion of
design documentation is another milestone.
The milestones are essential for project
planning and management.
2. Product and Process
Product: What is delivered to the customer is
called a product. It may include source code,
specification document, manuals,
documentation etc. Basically, it is nothing but a
set of deliverables only.
Process: Process is the way in which we
produce software. It is the collection of
activities that leads to (a part of) a product. An
efficient
process is required to produce good quality
products.

12
If the process is weak, the end product will
undoubtedly suffer, but an obsessive over
reliance on process is also dangerous.
3. Measures, Metrics and Measurement
A measure provides a quantitative indication of
the extent, dimension, size, capacity,
efficiency, productivity or reliability of some
attributes of a product or process.
Measurement is the act of evaluating a
measure.
A metric is a quantitative measure of the
degree to which a system, component or
process possesses a given attribute.
4. Software Process and Product
Metrics
Process metrics quantify the attributes of
software development process and
environment; whereas product metrics are
measures for the software product. Examples
Process metrics: Productivity, Quality,
Efficiency etc.
Product metrics: Size, Reliability, Complexity
etc.
5. Productivity and Effort
Productivity is defined as the rate of output, or
production per unit of effort, i.e. the output
achieved with regard to the time taken but
irrespective of the cost incurred.

13
Hence most appropriate unit of effort is Person
Months (PMs), meaning thereby number of
persons involved for specified months.
So, productivity may be measured as LOC/PM
(lines of code produced/person month)
6. Module and Software Components
There are many definitions of the term module.
They range from “a module is a FORTRAN
subroutine” to “a module is an Ada
Package”, to “Procedures and functions of
PASCAL and C”, to
“C++ Java classes” to “Java packages” to “a
module is a work assignment for an individual
developer”. All these definition are correct. The
term subprogram is also used sometimes in
place of module.
7. “An independently deliverable piece of
functionality providing access to its
services through interfaces”.
“A component represents a modular,
deployable, and replaceable part of a system
that encapsulates implementation and exposes
a set of interfaces”.
8. Generic and Customized Software
Products
Generic products are developed for anonymous
customers. The target is generally the entire
world and many copies are expected to be
sold. Infrastructure software like operating

14
system, compilers, analyzers, word processors,
CASE tools etc. are covered in this category.
The customized products are developed for
particular customers. The specific product is
designed and developed as per customer
requirements. Most of the development
projects (say about 80%) comes under this
category

[CHAPTER 2]
 Software Life Cycle Models
The goal of Software Engineering is to provide
models and processes that lead to the
production of well-documented maintainable
software in a manner that is predictable.
 Software Life Cycle Models
“The period of time that starts when a software
product is conceived and ends when the
product is no longer available for use. The
software life cycle typically includes a
requirement phase, design phase,
implementation phase, test phase, installation
and check out phase, operation and
maintenance phase, and sometimes retirement
phase”.
Build & Fix Model
• Product is constructed without
specifications or any attempt at design
• Adhoc approach and not well defined

15
• Simple two phase model

 Build & Fix Model


• Suitable for small programming exercises
of 100 or 200 lines
• Unsatisfactory for software for any
reasonable size
• Code soon becomes unfixable &
unenhanceable
• No room for structured design
• Maintenance is practically not possible
 Waterfall Model
This model is named “waterfall model”
because its diagrammatic representation
resembles a cascade of waterfalls.

16
 Waterfall Model
This model is easy to understand and
reinforces the notion of “define before design”
and “design before code”.
The model expects complete & accurate
requirements early in the process, which is
unrealistic
 Waterfall Model
Problems of waterfall model:-
i. It is difficult to define all requirements at the
beginning of a project
ii. This model is not suitable for
accommodating any change
iii. A working version of the system is not seen
until late in the project’s life
iv. It does not scale up well to large projects.
v. Real projects are rarely sequential.
 Incremental Process Models
They are effective in the situations where
requirements are defined precisely and there is

17
no confusion about the functionality of the final
product.
After every cycle a useable product is given to
the customer.
Popular particularly when we have to quickly
deliver a limited functionality system.
 Iterative Enhancement Model
This model has the same phases as the
waterfall model, but with fewer restrictions.
Generally the phases occur in the same order
as in the waterfall model, but they may be
conducted in several cycles. Useable product is
released at the end of the each cycle, with
each release providing additional functionality.
• Customers and developers specify as many
requirements as possible and prepare a
SRS document.
• Developers and customers then prioritize
these requirements
• Developers implement the specified
requirements in one or more cycles of
design, implementation and test based on
the defined priorities

 Iterative Enhancement Model

18
The Rapid Application Development
(RAD) Model
 Developed by IBM in 1980
 User participation is essential

The requirements The developers


specification was understood it in
defined like this that way

19
This is how the This is how the
problem was problem is
solved before. solved now

That is the program This is how the


program
after debugging is described by
marketing
department

This, in fact, is what


the

20
customer wanted …

 The Rapid Application Development


(RAD) Model
 Build a rapid prototype
 Give it to user for evaluation & obtain
feedback
 Prototype is refined

 The Rapid Application Development (RAD)


Model
Not an appropriate model in the absence of
user participation.
Reusable components are required to reduce
development time.
Highly specialized & skilled developers are
required and such developers are not easily
available.
Evolutionary Process Models
Evolutionary process model resembles iterative
enhancement model. The same phases as
defined for the waterfall model occur here in a
cyclical fashion. This model differs from
iterative enhancement model in the sense that

21
this does not require a useable product at the
end of each cycle. In evolutionary
development, requirements are implemented
by category rather than by priority.
This model is useful for projects using new
technology that is not well understood. This is
also used for complex projects where all
functionality must be delivered at one time,
but the requirements are unstable or not well
understood at the beginning.
 Evolutionary Process Model

Prototyping Model
 The prototype may be a usable program
but is not suitable as the final software
product.
 The code for the prototype is thrown away.
However experience gathered helps in
developing the actual system.

22
 The development of a prototype might
involve extra cost, but overall cost might
turnout to be lower than that of an
equivalent system developed using the
waterfall model.

• Linear model
• “Rapid”
 Spiral Model
Models do not deal with uncertainly which is
inherent to software projects.
Important software projects have failed
because project risks were neglected & nobody
was prepared when something unforeseen
happened.

23
Barry Boehm recognized this and tired to
incorporate the “project risk” factor into a life
cycle model.
The result is the spiral model, which was
presented in 1986.

 Spiral Model

 Spiral Model
The radial dimension of the model represents
the cumulative costs.
Each path around the spiral is indicative of
increased costs. The angular dimension
represents the progress made in completing
each cycle. Each loop of the spiral from X-axis
clockwise through 360o represents one phase.

24
One phase is split roughly into four sectors of
major activities.
 Planning: Determination of objectives,
alternatives & constraints.
 Risk Analysis: Analyze alternatives and
attempts to identify and resolve the risks
involved.
 Development: Product development and
testing product.
 Assessment: Customer evaluation

 Spiral Model
 An important feature of the spiral model is
that each phase is completed with a
review by the people concerned with the
project (designers and programmers)
 The advantage of this model is the wide
range of options to accommodate the
good features of other life cycle models.
 It becomes equivalent to another life cycle
model in appropriate situations.
The spiral model has some difficulties that
need to be resolved before it can be a
universally applied life cycle model. These
difficulties include lack of explicit process
guidance in determining objectives,
constraints, alternatives; relying on risk
assessment expertise; and provides more
flexibility than required for many applications.

25
 The Unified Process
• Developed by I.Jacobson, G.Booch and
J.Rumbaugh.
• Software engineering process with the goal of
producing good quality maintainable software
within specified time and budget.
• Developed through a series of fixed length
mini projects called iterations.
• Maintained and enhanced by Rational
Software Corporation and thus referred to as
Rational Unified Process (RUP).

Phases of the Unified Process

 Initial development & Evolution


Cycles

26
 Phases of the Unified Process
• Inception: defines scope of the project.
• Elaboration
- How do we plan & design the project?
- What resources are required?
- What type of architecture may be suitable?
• Construction: the objectives are translated in
design & architecture documents.
• Transition: involves many activities like
delivering, training, supporting, and
maintaining the product.
Iterations & Workflow of Unified
Process

27
Inception Phase
The inception phase has the following
objectives:
 Gathering and analyzing the
requirements.
 Planning and preparing a business
case and evaluating alternatives
for risk management, scheduling
resources etc.
 Estimating the overall cost and
schedule for the project.
 Studying the feasibility and
calculating profitability of the
project.
 Outcomes of Inception Phase

28
Elaboration Phase
The elaboration phase has the following
objectives:
 Establishing architectural foundations.
 Design of use case model.
 Elaborating the process, infrastructure &
development environment.
 Selecting component.
 Demonstrating that architecture support
the vision at reasonable cost & within
specified time.
Outcomes of Elaboration Phase

29
Construction Phase
The construction phase has the following
objectives:
 Implementing the project.
 Minimizing development cost.
 Management and optimizing resources.
 Testing the product
 Assessing the product releases against
acceptance criteria

 Outcomes of Construction Phase

30
 Transition Phase
The transition phase has the following
objectives:
 Starting of beta testing
 Analysis of user’s views.
 Training of users.
 Tuning activities including bug fixing and
enhancements for performance & usability
 Assessing the customer satisfaction.
 Outcomes of Transition Phase

Selection of a Life Cycle Model


Selection of a model is based on:
a) Requirements
b) Development team
c) Users

31
d) Project type and associated risk

Chapter [3]
Requirement Engineering
Requirements describe
What not How
Produces one large document written in natural
language contains a description of what the system
will do without describing how it will do it.
Crucial process steps
Quality of product
Process that creates it
Without well written document
 Developers do not know what to build
 Customers do not know what to expect
 What to validate

32
 Requirement Engineering
Requirement Engineering is the disciplined
application of proven principles, methods, tools, and
notations to describe a proposed system’s intended
behavior and its associated constraints.
SRS may act as a contract between developer and
customer.
State of practice
Requirements are difficult to uncover
• Requirements change
• Over reliance on CASE Tools
• Tight project Schedule
• Communication barriers
• Market driven software development
• Lack of resources

33
Example : - A University wish to develop a software
system for the student result management of its
M.Tech. Programme. A problem statement is to be
prepared for the software development company. The
problem statement may give an overview of the
existing system and broad expectations from the new
software system.
Types of Requirements
 Known Requirements
 Unknown Requirements
 Undreamed Requirements
Stakeholder: Anyone who should have some direct or
indirect influence on the system requirements.
--- User
--- Affected persons
Requirements
 Functional
 Non-Functional
Functional requirements describe what the software
has to do. They are often called product features.
Non Functional requirements are mostly quality
requirements. That stipulate how well the software
does, what it has to do.
a) For Users b) For Developers
1) Availability 1) Maintainability
2) Reliability 2) Portability
3) Usability 3) Testability
4) Flexibility

34
 Types of Requirements
User and system requirements
• User requirement are written for the users and
include functional and non functional requirement.
• System requirement are derived from user
requirement.
• The user system requirements are the parts of
software requirement and specification (SRS)
document.
 Types of Requirements
Interface Specification
• Important for the customers.
TYPES OF INTERFACES
• Procedural interfaces (also called Application
Programming Interfaces (APIs)).
• Data structures
• Representation of data.
 Feasibility Study
Is cancellation of a project a bad news?
As per IBM report, “31% projects get cancelled before
they are completed, 53% over-run their cost estimates
by an average of 189% & for every 100 projects, there
are 94 restarts.
How do we cancel a project with the least
work?
 CONDUCT A FEASIBILTY STUDY
 Feasibility Study
Technical feasibility

35
• Is it technically feasible to provide direct
communication connectivity through space from one
location of globe to another location?
• Is it technically feasible to design a programming
language using “Sanskrit”?
 Feasibility Study
Feasibility depends upon non technical Issues like:
• Are the project’s cost and schedule assumption
realistic?
• Does the business model realistic?
• Is there any market for the product?
 Feasibility Study
Purpose of feasibility study:-
“evaluation or analysis of the potential impact of a
proposed project or program.”
Focus of feasibility studies
• Is the product concept viable?
• Will it be possible to develop a product that matches
the project’s vision statement?
• What are the current estimated cost and schedule
for the project?
 Feasibility Study
Focus of feasibility studies
• How big is the gap between the original cost &
schedule targets & current estimates?
• Is the business model for software justified when the
current cost & schedule estimate are considered?
• Have the major risks to the project been identified &
can they be surmounted?

36
• Is the specifications complete & stable enough to
support remaining development work?
 Feasibility Study
Focus of feasibility studies
• Have users & developers been able to agree on a
detailed user interface prototype? If not, are the
requirements really stable?
• Is the software development plan complete &
adequate to support further development work?
Requirements Analysis
We analyze, refine and scrutinize requirements to
make consistent & unambiguous requirements.
Steps:-

 Requirements Analysis
Data Flow Diagrams
DFD show the flow of data through the system.
--All names should be unique
-- It is not a flow chart
-- Suppress logical decisions
-- Defer error conditions & handling until the end of
the analysis
Leveling

37
DFD represent a system or software at any level of
abstraction.
A level 0 DFD is called fundamental system model or
context model represents entire software element as
a single bubble with input and output data indicating
by incoming & outgoing arrows.
Data Dictionaries
DFD – DD
Data Dictionaries are simply repositories to store
information about all data items defined in DFD.
Includes :-
Name of data item
Aliases (other names for items)
Description/Purpose
Related data items
Range of values
Data flows
Data structure definition
Entity-Relationship Diagrams
It is a detailed logical representation of data for an
organization and uses three main constructs.
 Entities
 Relationships
 Attributes
Entities:-
Fundamental thing about which data may be
maintained. Each entity has its own identity.

38
Entity Type is the description of all entities to which a
common definition and common relationships and
attributes apply.
Consider an insurance company that offers both
home and automobile insurance policies .These
policies are offered to individuals and businesses.
POLICY CUSTOMER
Home individual
Automobile businesses
Relationships
A relationship is a reason for associating two entity
types.
Binary relationships involve two entity types
A CUSTOMER is insured by a POLICY. A POLICY
CLAIM is made against a POLICY.
Relationships are represented by diamond notation in
a ER diagram.
CUSTOMER
Insured by
POLICY
Made Against
POLICY CLAIM
 Entity-Relationship Diagrams
A training department is interested in tracking which
training courses each of its employee has completed.
EMPLOYEE
completes
COURSE
(Many-to-Many relationship)

39
Each employee may complete more than one course ,
and each course may be completed by more than one
employee.
Degree of relationship
It is the number of entity types that participates in that
relationship.
Unary
Binary
Ternary
Unary relationship
Person
Is Married to
One to One
Employee
Manages
One to many

 Attributes
Each entity type has a set of attributes associated
with it.
An attribute is a property or characteristic of an entity
that is of interest to organization.
A candidate key is an attribute or combination of
attributes that uniquely identifies each instance of an
entity type.
Student _ ID Candidate Key
If there are more candidate keys, one of the
key may be chosen as the Identifier.
It is used as unique characteristic for an entity type.

40
Identifier
Approaches to problem analysis
1. List all inputs, outputs and functions.
2. List all functions and then list all inputs and outputs
associated with each function.
Structured requirements definition (SRD)
Step1
Define a user level DFD. Record the inputs and
outputs for each individual in a DFD.
Step2
Define a combined user level DFD.
Step3
Define application level DFD.
Step4
Define application level functions.
Requirements Documentation
This is the way of representing requirements in a
consistent format
SRS serves many purpose depending upon who is
writing it.
-- written by customer
-- written by developer
Serves as contract between customer & developer.
Nature of SRS
Basic Issues
• Functionality

41
• External Interfaces
• Performance
• Attributes
• Design constraints imposed on an Implementation
SRS Should
-- Correctly define all requirements
-- not describe any design details
-- not impose any additional constraints
Characteristics of a good SRS
An SRS Should be
_ Correct
_ Unambiguous
_ Complete
_ Consistent
_ Ranked for important and/or stability
_ Verifiable
_ Modifiable
_ Traceable

Correct
An SRS is correct if and only if every requirement
stated therein is one that the software shall meet.
Unambiguous
An SRS is unambiguous if and only if, every
requirement stated therein has only one
interpretation.
Complete

42
An SRS is complete if and only if, it includes the
following elements
(i) All significant requirements, whether related
to functionality, performance, design
constraints, attributes or external interfaces.
(ii) Responses to both valid & invalid inputs.
(iii) Full Label and references to all figures, tables and
diagrams in the SRS and definition of all terms and
units of measure.
Consistent
An SRS is consistent if and only if, no subset of
individual requirements described in it conflict.
Ranked for importance and/or Stability
If an identifier is attached to every requirement to
indicate either the importance or stability of that
particular requirement.
Verifiable
An SRS is verifiable, if and only if, every requirement
stated therein is verifiable.
Modifiable
An SRS is modifiable, if and only if, its structure and
style are such that any changes to the requirements
can be made easily, completely, and consistently
while retaining structure and style.
Traceable
An SRS is traceable, if the origin of each of the
requirements is clear and if it facilitates the

43
referencing of each requirement in future
development or enhancement documentation.
Organization of the SRS
IEEE has published guidelines and standards to
organize an SRS.
First two sections are same. The specific tailoring
occurs in section-3.
1. Introduction
1.1 Purpose
1.2 Scope
1.3 Definition, Acronyms and abbreviations
1.4 References
1.5 Overview
2. The Overall Description
2.1 Product Perspective
2.1.1 System Interfaces
2.1.2 Interfaces
2.1.3 Hardware Interfaces
2.1.4 Software Interfaces
2.1.5 Communication Interfaces
2.1.6 Memory Constraints
2.1.7 Operations
2.1.8 Site Adaptation Requirements
2.2 Product Functions
2.3 User Characteristics
2.4 Constraints
2.5 Assumptions for dependencies
2.6 Apportioning of requirements
3. Specific Requirements
3.1 External Interfaces
44
3.2 Functions
3.3 Performance requirements
3.4 Logical database requirements
3.5 Design Constraints
3.6 Software System attributes
3.7 Organization of specific requirements
3.8 Additional Comments.
Check the document for:
_ Completeness & consistency
_ Conformance to standards
_ Requirements conflicts
_ Technical errors
_ Ambiguous requirements
Requirements Validation
Problem actions
• Requirements clarification
• Missing information
• find this information from stakeholders
• Requirements conflicts
• Stakeholders must negotiate to resolve this
conflict
• Unrealistic requirements
• Stakeholders must be consulted
• Security issues
• Review the system in accordance to security
standards
Review Checklists
_ Redundancy
_ Completeness
_ Ambiguity

45
_ Consistency
_ Organization
_ Conformance
_ Traceability
Prototyping
Validation prototype should be reasonably complete &
efficient & should be used as the required system.
Requirements Management
• Process of understanding and controlling changes to
system requirements.
ENDURING & VOLATILE REQUIREMENTS
 Enduring requirements: They are core
requirements & are related to main activity of the
organization.
Example: issue/return of a book, cataloging etc.
 Volatile requirements: likely to change during
software development lifer cycle or after delivery
of the product
Requirements Management
Planning
• Very critical.
• Important for the success of any project.
Requirements Change Management
• Allocating adequate resources
• Analysis of requirements
• Documenting requirements
• Requirements traceability
• Establishing team communication

46
• Establishment of baseline

Chapter [4]
 Software Project Planning
After the finalization of SRS, we would like to
estimate size, cost and development time of
the project. Also, in many cases, customer may
like to know the cost and development time
even prior to finalization of the SRS.
In order to conduct a successful software
project, we must understand:
 Scope of work to be done
 The risk to be incurred
 The resources required
 The task to be accomplished
 The cost to be expended
 The schedule to be followed
Software planning begins before technical work
starts, continues as the software evolves from
concept to reality, and culminates only when
the software is retired.

47
 Size Estimation

Lines of Code (LOC)


If LOC is simply a count of the number of lines
then figure shown below contains 18 LOC .
When comments and blank lines are ignored,
the program in figure 2 shown below contains
17 LOC.
 Software Project Planning
Furthermore, if the main interest is the size of
the program for specific functionality, it may be
reasonable to include executable statements.
The only executable statements in figure
shown above are in lines 5-17 leading to a
count of
13. The differences in the counts are 18 to 17
to 13. One can easily see the potential for
major discrepancies for large programs with
many comments or programs written in
language that allow a large number of

48
descriptive but non-executable statement.
Conte has defined lines of code as:
 Software Project Planning
“A line of code is any line of program text that
is not a comment or blank line, regardless of
the number of statements or fragments of
statements on the line. This specifically
includes all lines containing program header,
declaration, and executable and non-
executable statements”.
This is the predominant definition for lines of
code used by researchers. By this definition,
figure shown above has 17 LOC.

 Software Project Planning


Function Count
Alan Albrecht while working for IBM, recognized
the problem in size measurement in the 1970s,
and developed a technique (which he called
Function Point Analysis), which appeared to be
a solution to the size measurement problem.
 Software Project Planning
The principle of Albrecht’s function point
analysis (FPA) is that a system is decomposed
into functional units.
• Inputs : information entering
the system

49
• Outputs : information leaving
the system
• Enquiries : requests for instant
access to Information
• Internal logical files :
information held within the
system
• External interface files:
information held by other
system that is used by the
system being analyzed.
 Software Project Planning
The five functional units are divided in two
categories:
(i) Data function types:-
 Internal Logical Files (ILF): A user
identifiable group of logical related
data or control information maintained
within the system.
 External Interface files (EIF): A user
identifiable group of logically related
data or control information referenced
by the system, but maintained within
another system. This means that EIF
counted for one system, may be an
ILF in another system.
(ii) Transactional function types
 External Input (EI): An EI processes data or
control information that comes from

50
outside the system. The EI is an
elementary process, which is the smallest
unit of activity that is meaningful to the
end user in the business.
 External Output (EO): An EO is an
elementary process that generate data or
control information to be sent outside the
system.
 External Inquiry (EQ): An EQ is an
elementary process that is made up to an
input-output combination that results in
data retrieval.
Special features
 Function point approach is independent of
the language, tools, or methodologies used
for implementation; i.e. they do not take
into consideration programming languages,
data base management systems,
processing hardware or any other data
base technology.
 Function points can be estimated from
requirement specification or design
specification, thus making it possible to
estimate development efforts in early
phases of development.
 Function points are directly linked to the
statement of requirements; any change of
requirements can easily be followed by a
re-estimate.

51
 Function points are based on the system
user’s external view of the system , non-
technical users of the software system
have a better understanding of what
function points are measuring.
Cost Estimation
A number of estimation techniques have been
developed and are having following attributes
in common :
 Project scope must be established in advance
 Software metrics are used as a basis from which
estimates are made
 The project is broken into small pieces which are
estimated individually
To achieve reliable cost and schedule
estimates, a number of options arise:
 Delay estimation until late in project
 Use simple decomposition techniques to
generate project cost and schedule estimates
 Develop empirical models for estimation
 Acquire one or more automated estimation tools

52
Static, Single Variable Models
Methods using this model use an equation to
estimate the desired values such as cost, time,
effort, etc. They all depend on the same
variable used as predictor (say, size). An
example of the most common equations is :
C = a L b (i)
C is the cost, L is the size and a, b are
constants
E = 1.4 L0.93
DOC = 30.4 L0.90
D = 4.6 L0.26
Effort (E in Person-months), documentation
(DOC, in number of pages) and duration (D, in
months) are calculated from the number of
lines of code (L, in thousands of lines) used as
a predictor.
 Static, Multivariable Models
These models are often based on equation (i),
they actually depend on several variables
representing various aspects of the software
development environment, for example
method used, user participation, customer
oriented changes, memory constraints, etc.
E = 5.2 L0.91
D = 4.1 L0.36
The productivity index uses 29 variables which
are found to be highly correlated to
productivity as follows:
 Software Project Planning

53
 The Constructive Cost Model
(COCOMO)

Basic Model
Basic COCOMO model takes the form
E = a b (KLOC) bb
D = c b (E) b d
where E is effort applied in Person-Months, and
D is the development time in months. The

54
coefficients ab, bb, cb and db are given in table
4 (a).
When effort and development time are known,
the average staff size to complete the project
may be calculated as:
Average staff size (SS) = E Persons
D
When project size is known, the productivity
level may be calculated as:
Productivity (P) = KLOC KLOC/ PM
E
Example: 4.5
Suppose that a project was estimated to be
400 KLOC.
Calculate the effort and development time for
each of the three modes i.e., organic,
semidetached and embedded.
 Solution
The basic COCOMO equation take the form:
E = a b (KLOC) bb
D = c b (KLOC) db
Estimated size of the project = 400 KLOC
(i) Organic mode
E = 2.4(400)1.05 = 1295.31 PM
D = 2.5(1295.31)0.38 = 38.07 PM
 Intermediate Model
Cost drivers
(i) Product Attributes
_ Required s/w reliability
_ Size of application database

55
_ Complexity of the product
(ii) Hardware Attributes
_ Run time performance constraints
_ Memory constraints
_ Virtual machine volatility
_ Turnaround time
(iii) Personal Attributes
_ Analyst capability
_ Programmer capability
_ Application experience
_ Virtual m/c experience
_ Programming language experience
(iv) Project Attributes
_ Modern programming practices
_ Use of software tools
_ Required development Schedule
 Intermediate COCOMO equations
E= ai(KLOC)bi * EAF
D = c i (E) di
 Detailed COCOMO Model
Detailed COCOMO
Phase-Sensitive effort multipliers
Cost drivers
Design & test
Three level product hierarchy
Modules subsystem
System level
Manpower allocation for each phase
Software Project Planning
 Development Phase

56
Plan / Requirements
EFFORT : 6% to 8%
DEVELOPMENT TIME : 10% to 40%
% depend on mode & size
Design
Effort : 16% to 18%
Time : 19% to 38%
Programming
Effort : 48% to 68%
Time : 24% to 64%
Integration & Test
Effort : 16% to 34%
Time : 18% to 34%
Distribution of software life cycle:
1. Requirement and product design
(a)Plans and requirements
(b)System design
2. Detailed Design
(a)Detailed design
3. Code & Unit test
(a)Module code & test
4. Integrate and Test
(a) Integrate & Test
Software Project Planning
1. Requirement and product design
(a)Plans and requirements
(b)System design
2. Detailed Design
(a)Detailed design
3. Code & Unit test

57
(a)Module code & test
4. Integrate and Test
(a) Integrate & Test
 Software Project Planning
Example: 4.7
A new project with estimated 400 KLOC
embedded system has to be developed. Project
manager has a choice of hiring from two pools
of developers: Very highly capable with very
little experience in the programming language
being used
Or
Developers of low quality but a lot of
experience with the programming language.
What is the impact of hiring all developers from
one or the other pool ?
 Software Project Planning
Software Risk Management
 We Software developers are
extremely optimists.
 We assume, everything will go
exactly as planned.
Other view
not possible to predict what is going to
happen ?
Software surprises
Never good news
Risk management is required to reduce this
surprise factor

58
Dealing with concern before it becomes a
crisis.
Quantify probability of failure & consequences
of failure.
What is risk ?
Tomorrow’s problems are today’s risks.
“Risk is a problem that may cause some loss or
threaten the success of the project, but which
has not happened yet”.
Risk management is the process of identifying
addressing and eliminating these problems
before they can damage the project.
Current problems &
Potential Problems
Capers Jones has identified the top five risk
factors that threaten projects in different
applications.
1. Dependencies on outside agencies or
factors.
Typical Software Risk
• Availability of trained, experienced persons
• Inter group dependencies
• Customer-Furnished items or information
• Internal & external subcontractor
relationships
2. Requirement issues
Uncertain requirements
Wrong product
or
Right product badly

59
Either situation results in unpleasant surprises
and unhappy customers.
• Lack of clear product vision
• Unprioritized requirements
• Lack of agreement on product requirements
• New market with uncertain needs
• Rapidly changing requirements
• Inadequate Impact analysis of requirements
changes
3. Management Issues
Project managers usually write the risk
management plans, and most people do not
wish to air their weaknesses in public.
• Inadequate planning
• Inadequate visibility into actual project status
• Unclear project ownership and decision
making
• Staff personality conflicts
• Unrealistic expectation
• Poor communication
4. Lack of knowledge
• Inadequate training
• Poor understanding of methods, tools, and
techniques
• Inadequate application domain experience
• New Technologies
• Ineffective, poorly documented or neglected
processes
5. Other risk categories
• Unavailability of adequate testing facilities

60
• Turnover of essential personnel
• Unachievable performance requirements
• Technical approaches that may not work
Identification of risks
Risk Assessment
Risk analysis involves examining how project
outcomes might change with modification of
risk input variables.
Risk prioritization focus for severe risks.
Risk exposure: It is the product of the
probability of incurring a loss due to the risk
and the potential magnitude of that loss.
Another way of handling risk is the risk
avoidance. Do not do the risky things! We may
avoid risks by not undertaking certain projects,
or by relying on proven rather than cutting
edge technologies.
Risk Control
Risk Management Planning produces a plan for
dealing with each significant risks.
 Record decision in the plan.
Risk resolution is the execution of the plans of
dealing with each risk.

Chapter [5]
 Software Design
More creative than analysis

61
_ Problem solving activity
WHAT IS DESIGN
‘HOW’
Software design document (SDD)
Conceptual design answers :
 Where will the data come from ?
 What will happen to data in the
system?
 How will the system look to users?
 What choices will be offered to users?
 What is the timings of events?
 How will the reports & screens look like?
Technical design describes :
 Hardware configuration
 Software needs
 Communication interfaces
 I/O of the system
 Software architecture
 Network architecture
 Any other thing that translates the
requirements in to a solution to the
customer’s problem.
The design needs to be
 Correct & complete
 Understandable
 At the right level
 Maintainable
 Software Design

62
• Informal design outline
• Informal design
• Finished design
The transformation of an informal design to a
detailed design.
 Software Design
MODULARITY
There are many definitions of the term module.
Range is from :
i. Fortran subroutine
ii. Ada package
iii. Procedures & functions of PASCAL & C
iv. C++ / Java classes
v. Java packages
vi. Work assignment for an individual
programmer
 Software Design
All these definitions are correct. A modular
system consist of well defined manageable
units with well defined interfaces among the
units.
 Software Design
Properties :
i. Well defined subsystem
ii. Well defined purpose
iii. Can be separately compiled and stored in a
library.
iv. Module can use other modules
v. Module should be easier to use than to build
vi. Simpler from outside than from the inside.

63
Modularity is the single attribute of software
that allows a program to be intellectually
manageable.
It enhances design clarity, which in turn eases
implementation, debugging, testing,
documenting, and maintenance of software
product.
 Software Design
Data coupling
The dependency between module A and B is
said to be data coupled if their dependency is
based on the fact they communicate by only
passing of data. Other than communicating
through data, the two modules are
independent.
Stamp coupling
Stamp coupling occurs between module A and
B when complete data structure is passed from
one module to another.
Control coupling
Module A and B are said to be control coupled
if they communicate by passing of control
information. This is usually accomplished by
means of flags that are set by one module and
reacted upon by the dependent module.
Common coupling
With common coupling, module A and module
B have shared data. Global data areas are
commonly found in programming languages.
Making a change to the common data means

64
tracing back to all the modules which access
that data to evaluate the effect of changes.
Content coupling
Content coupling occurs when module A
changes data of module B or when control is
passed from one module to the middle of
another. In Fig. 9, module B branches into D,
even though D is supposed to be under the
control of C.
Module Cohesion
Cohesion is a measure of the degree to which
the elements of a module are functionally
related.
Cohesion=Strength of relations within
modules
Types of cohesion
_ Functional cohesion
_ Sequential cohesion
_ Procedural cohesion
_ Temporal cohesion
_ Logical cohesion
_ Coincident cohesion
 Functional Cohesion: A and B are part
of a single functional task. This is very good
reason for them to be contained in the same
procedure.
 Sequential Cohesion: Module A
outputs some data which forms the input to B.

65
This is the reason for them to be contained in the
same procedure.
 Procedural Cohesion: Procedural
Cohesion occurs in modules whose instructions
although accomplish different tasks yet have
been combined because there is a specific order
in which the tasks are to be completed.
 Temporal Cohesion: Module exhibits
temporal cohesion when it contains tasks that are
related by the fact that all tasks must be executed
in the same time-span.
 Logical Cohesion: Logical cohesion
occurs in modules that contain instructions that
appear to be related because they fall into the
same logical class of functions.
 Coincidental Cohesion: Coincidental
cohesion exists in modules that contain
instructions that have little or no relationship to
one another.
Relationship between Cohesion &
Coupling
If the software is not properly modularized, a
host of seemingly trivial enhancement or
changes will result into death of the project.
Therefore, a software engineer must design the
modules with goal of high cohesion and low
coupling.

66
View of cohesion and coupling

 Software Design
STRATEGY OF DESIGN
A good system design strategy is to organize
the program modules in such a way that are
easy to develop and latter to, change.
Structured design techniques help developers
to deal with the size and complexity of
programs. Analysts create instructions for the
developers about how code should be written
and how pieces of code should fit together to
form a program. It is important for two
reasons:
_ First, even pre-existing code, if any, needs to
be understood, organized and pieced together.
_ Second, it is still common for the project
team to have to write some code and produce
original programs that support the application
logic of the system.
Bottom-Up Design
These modules are collected together in the
form of a “library”.

67
Bottom-up tree structure
Top-Down Design
A top down design approach starts by
identifying the major modules of the system,
decomposing them into their lower level
modules and iterating until the desired level of
detail is achieved. This is stepwise refinement;
starting from an abstract design, in each step
the design is refined to a more concrete level,
until we reach a level where no more
refinement is needed and the design can be
implemented directly.
Hybrid Design
For top-down approach to be effective, some
bottom-up approach is
essential for the following reasons:
_ To permit common sub modules.
_ Near the bottom of the hierarchy, where the intuition
is simpler, and the need for bottom-up testing is

68
greater, because there are more number of modules
at low levels than high levels.
_ In the use of pre-written library modules, in
particular, reuse of modules.
FUNCTION ORIENTED DESIGN
Function Oriented design is an approach to
software design where the design is
decomposed into a set of interacting units
where each unit has a clearly defined function.
Thus, system is designed from a functional
viewpoint.
We continue the refinement of each module
until we reach the statement level of our
programming language. At that point, we can
describe the structure of our program as a tree
of refinement as in design top-down structure.
Design reusable structure
If a program is created top-down, the modules
become very specialized.
As one can easily see in top down design
structure, each module is used by at most one
other module, its parent. For a module,
however, we must require that several other
modules as in design reusable structure.
Design Notations
Design notations are largely meant to be used during
the process of design and are used to represent
design or design decisions.

69
For a function oriented design, the design can be
represented graphically or mathematically by the
following:
_ Data flow diagrams
_ Data Dictionaries
_ Structure Charts
_ Pseudocode
Structure Chart
It partition a system into block boxes. A black
box means that functionality is known to the
user without the knowledge of internal design.
(Hierarchical format of a structure chart)
Purpose of an SDD
The SDD shows how the software system will be
structured to satisfy the requirements identified in the
SRS. It is basically the translation of requirements into
a description of the software structure, software
components, interfaces, and data necessary for the
implementation phase. Hence, SDD becomes the
blue print for the implementation activity.
_ Design Description Information Content
_ Introduction
_ Design entities
_ Design entity attributes
Software Design
The attributes and associated information items are
defined in the following subsections:
a) Identification
b) Type

70
c) Purpose
d) Function
e) Subordinates
f) Dependencies
g) Interface
h) Resources
i) Processing
j) Data
Design Description Organization
Each design description writer may have a different
view of what are considered the essential aspects of a
software design. The organization of SDD is given in
table 1. This is one of the possible ways to organize
and format the SDD.
A recommended organization of the SDD into
separate design views to facilitate information access
and assimilation.
Object Oriented Design
Object oriented design is the result of focusing
attention not on the function performed by the
program, but instead on the data that are to do
manipulated by the program. Thus, it is orthogonal to
function oriented design.
Object Oriented Design begins with an examination of
the real world “things” that are part of the problem to
be solved. These things (which we will call objects)
are characterized individually in terms of their
attributes and behavior.

71
Basic Concepts
Object Oriented Design is not dependent on any
specific implementation language. Problems are
modeled using objects.
Objects have:
_ Behavior (they do things)
_ State (which changes when they do things)
 The various terms related to object
design are:
i. Objects:-
The word “Object” is used very frequently and
conveys different meaning in different
circumstances. Here, meaning is an entity able to
save a state (information) and which offers a
number of operations (behavior) to either examine
or affect this state. An object is characterized by
number of operations and a state which remembers
the effect of these operations.
ii. Messages:-
Objects communicate by message passing.
Messages consist of the identity of the target object,
the name of the requested operation and any other
operation needed to perform the function. Messages
are often implemented as procedure or function calls.
ii. Abstraction:-
In object oriented design, complexity is managed
using abstraction.

72
Abstraction is the elimination of the irrelevant and the
amplification of the essentials.
iv. Class
In any system, there shall be number of objects.
Some of the objects may have common
characteristics and we can group the objects
according to these characteristics. This type of
grouping is known as a class. Hence, a class is a set
of objects that share a common structure and a
common behavior.
We may define a class “car” and each object that
represent a car becomes an instance of this class. In
this class “car”, Indica , Santro , Maruti , Indigo are
instances of this class.
v. Attributes
An attributes is a data value held by the objects in a
class. The square class has two attributes: a colour
and array of points. Each attributes has a value for
each object instance. The attributes are shown as
second part of the class.
vi. Operations
An operation is a function or transformation that may
be applied to or by objects in a class. In the square
class, we have two operations: set colour() and
draw(). All objects in a class share the same
operations.

73
An object “knows” its class, and hence the right
implementation of the operation. Operations are
shown in the third part of the class.
vii. Inheritance
Imagine that, as well as squares, we have triangle
class.

The triangle class

 Difference between triangle and squares


classes.
For example, at a high level of abstraction, we might
want to think of a picture as made up of shapes and
to draw the picture , we draw each shape in turn. We
want to eliminate the irrelevant details: we do not care
that one shape is a square and the other is a triangle
as long as both can draw themselves.
To do this, we consider the important parts out of
these classes in to a new class called Shape.

74
This sort of abstraction is called inheritance. The low
level classes (known as subclasses or derived
classes) inherit state and behavior from this high level
class (known as a super class or base class).
viii. Polymorphism
When we abstract just the interface of an operation
and leave the implementation to subclasses it is
called a polymorphic operation and process is called
polymorphism.
ix. Encapsulation (Information Hiding)
Encapsulation is also commonly referred to as
“Information Hiding”. It consists of the separation of
the external aspects of an object from the internal
implementation details of the object.
x. Hierarchy
Hierarchy involves organizing something according to
some particular order or rank. It is another
mechanism for reducing the complexity of software by
being able to treat and express sub-types in a generic
way.

Hierarchy

75
Steps to Analyze and Design Object Oriented
System
i. Create use case model
First step is to identify the actors interacting with the
system. We should then write the use case and draw
the use case diagram.
ii. Draw activity diagram (If required)
Activity Diagram illustrate the dynamic nature of a
system by modeling the flow of control form activity to
activity. An activity represents an operation on some
class in the system that results in a change in the
state of the system.
iii. Draw the interaction diagram
An interaction diagram shows an interaction,
consisting of a set of objects and their relationship,
including the messages that may be dispatched
among them. Interaction diagrams address the
dynamic view of a system.
Steps to draws interaction diagrams are as under:
a) Firstly, we should identify that the objects with
respects to every use case.
b) We draw the sequence diagrams for every use
case.
d) We draw the collaboration diagrams for every use
case.

76
iv. Draw the class diagram
The class diagram shows the relationship amongst
classes. There are four types of relationships in class
diagrams.
a) Association are semantic connection
between classes. When an association connects
two classes, each class can send messages to
the other in a sequence or a collaboration
diagram. Associations can be bi-directional or
unidirectional.
b) Dependencies connect two classes.
Dependencies are always unidirectional and show
that one class, depends on the definitions in another
class.
c) Aggregations are stronger form of association.
An aggregation is a relationship between a whole and
its parts.
d) Generalizations are used to show an
inheritance relationship between two classes.
v. Design of state chart diagrams
A state chart diagram is used to show the state space
of a given class, the event that cause a transition from
one state to another, and the action that result from a
state change. A state transition diagram for a “book”
in the library system is given in fig.

77
Transition chart for “book” in a library system.
vi. Draw component and development diagram
Component diagrams address the static
implementation view of a system they are related to
class diagrams in that a component typically maps to
one or more classes, interfaces or collaboration.
Deployment Diagram Captures relationship between
physical components and the hardware.

Chapter [6]

 Software Metrics: What and Why ?


1. How to measure the size of a software?
2. How much will it cost to develop a software?
3. How many bugs can we expect?
4. When can we stop testing?
5. When can we release the software?
6. What is the complexity of a module?
7. What is the module strength and coupling?

78
8. What is the reliability at the time of release?
9. Which test technique is more effective?
10. Are we testing hard or are we testing smart?
11. Do we have a strong program or a week test suite?
 Software Metrics
 Pressman explained as “A measure provides
a quantitative indication of the extent, amount,
dimension, capacity, or size of some attribute of
the product or process”.
Measurement is the act of determine a measure
 The metric is a quantitative measure of the
degree to which a system, component, or
process possesses a given attribute.
 Fenton defined measurement as “ it is the
process by which numbers or symbols are
assigned to attributes of entities in the real world
in such a way as to describe them according to
clearly defined rules”.
Definition
Software metrics can be defined as “The
continuous application of measurement based
techniques to the software development
process and its products to supply meaningful
and timely management information, together
with the use of those techniques to improve
that process and its products”.
Areas of Applications
The most established area of software metrics is cost
and size estimation techniques.

79
The prediction of quality levels for software, often in
terms of reliability, is another area where software
metrics have an important role to play.
The use of software metrics to provide quantitative
checks on software design is also a well established
area.
Problems During Implementation
_ Statement : Software development is to complex;
it cannot be managed like other parts of the
organization.
Management view : Forget it, we will find
developers and managers who will manage that
development.
_ Statement : I am only six months late with project.
Management view : Fine, you are only out of a job.
_ Statement : I am only six months late with project.
Management view : Fine, you are only out of a job.
_ Statement : But you cannot put reliability
constraints in the contract.
Management view : Then we may not get the
contract.
Categories of Metrics
i. Product metrics: describe the characteristics
of the product such as size, complexity, design
features, performance, efficiency, reliability,
portability, etc.

80
ii. Process metrics: describe the effectiveness
and quality of the processes that produce the
software product. Examples are:
• effort required in the process
• time to produce the product
• effectiveness of defect removal during development
• number of defects found during testing
• maturity of the process
ii. Project metrics: describe the project
characteristics and execution. Examples are :
• number of software developers
• staffing pattern over the life cycle of the software
• cost and schedule
• productivity
Token Count
The size of the vocabulary of a program, which
consists of the number of unique tokens used to build
a program is defined as:
n = n1+ n2
n : vocabulary of a program
where n1 : number of unique operators
n2 : number of unique operands
The length of the program in the terms of the total
number of tokens used is
N = N1+N2
N : program length
Where N1 : total occurrences of operators
N2 : total occurrences of operands

81
 Volume
V = N * log2 n
The unit of measurement of volume is the common
unit for size “bits”. It is the actual size of a program if a
uniform binary encoding for the vocabulary is used.
Program Level
L = V* / V
The value of L ranges between zero and one, with
L=1 representing a program written at the highest
possible level (i.e., with minimum size).
 Program Difficulty
D=1/L
As the volume of an implementation of a program
increases, the program level decreases and the
difficulty increases.
Thus, programming practices such as redundant
usage of operands, or the failure to use higher-level
control constructs will tend to increase the volume as
well as the difficulty.
Effort
E=V/L=D*V
The unit of measurement of E is elementary mental
discriminations.
 Software Metrics
The Usage of Data within a Module
 Live Variables
Definitions :

82
1. A variable is live from the beginning of a procedure
to the end of the procedure.
2. A variable is live at a particular statement only if it
is referenced a certain number of statements before
or after that statement.
3. A variable is live from its first to its last references
within a procedure.
Variable spans
The size of a span indicates the number of
statements that pass between successive uses of a
variables.
Program Weakness
A program consists of modules. Using the average
number of live Variables (LV ) and average life
variables(γ ) , the module weakness has been
defined as
WM = LV *γ

A program is normally a combination of various


modules, hence program weakness can be a useful
measure and is defined as:
WP=
where, WMi : weakness of ith module
WP : weakness of the program
m : number of modules in the
program
Example-

83
Consider a program for sorting and searching. The
program sorts an array using selection sort and than
search for an element in the sorted array. The
program is given in fig. 8. Generate cross reference
list for the program and also calculate and WM for the
program.
Information Flow Metrics
 Component : Any element identified by
decomposing a (software) system into its
constituent parts.
 Cohesion : The degree to which a
component performs a single function.
 Coupling : The term used to describe the
degree of linkage between one component
to others in the same system.
The Basic Information Flow Model
Information Flow metrics are applied to the
Components of a system design. Afragment of such a
design, and for component ‘A’ we can define three
measures, but remember that these are the simplest
models of IF.
1. ‘FAN IN’ is simply a count of the number of other
Components that can call, or pass control, to
Component A.
2. ‘FANOUT’ is the number of Components that are
called by Component A.
3. This is derived from the first two by using the
following formula.

84
We will call this measure the INFORMATION FLOW
index of
Component A, abbreviated as IF(A).
IF(A) = [FAN IN(A) x FAN OUT (A)]2
 The following is a step-by-step guide to
deriving these most simple of IF metrics.
1. Note the level of each Component in the system
design.
2. For each Component, count the number of calls so
that
Component – this is the FAN IN of that Component.
Some organizations allow more than one Component
at the highest level in the design, so for Components
at the highest level which should have a FAN IN of
zero, assign a FAN IN of one. Also note that a simple
model of FAN IN can penalize reused Components.
3. For each Component, count the number of calls
from the Component. For Component that call no
other, assign a FAN OUT value of one.
4. Calculate the IF value for each Component using
the above formula.
5. Sum the IF value for all Components within each
level which is called as the LEVEL SUM.
6. Sum the IF values for the total system design which
is called the SYSTEM SUM.
7. For each level, rank the Component in that level
according to FAN IN, FAN OUT and IF values. Three

85
histograms or line plots should be prepared for each
level.
8. Plot the LEVEL SUM values for each level using a
histogram or line plot.
Metrics Analysis
 Problems with metric data:
• Normal Distribution
• Outliers
• Measurement Scale
• Multicollinearity
Common pool of data:
• The selection of projects should be representative
and not all come from a single application domain or
development styles.
• No single very large project should be allowed to
dominate the pool.
• For some projects, certain metrics may not have
been collected.
Pattern of Successful Applications:
•Any metric is better then none.
• Automation is essential.
• Empiricism is better then theory.
• Use multifactor rather then single metrics.
• Don’t confuse productivity metrics with complexity
metrics.
• Let them mature.
• Maintain them.
• Let them die.

86
Chapter [7]
What is Software Reliability?
“Software reliability means operational reliability. Who
cares how many bugs are in the program?
As per IEEE standard: “Software reliability is defined
as the ability of a system or component to perform its
required functions under stated conditions for a
specified period of time”.
Software reliability is also defined as the probability
that a software system fulfills its assigned task in a
given environment for a predefined number of input
cases, assuming that the hardware and the inputs are
free of error.
“It is the probability of a failure free operation of a
program for a specified time in a specified
environment”.
Failures and Faults
A fault is the defect in the program that, when
executed under particular conditions, causes a failure.
The execution time for a program is the time that is
actually spent by a processor in executing the
instructions of that program. The second kind of time
is calendar time. It is the familiar time that we
normally experience.
There are four general ways of characterising failure
occurrences in time:
1. time of failure,

87
2. time interval between failures,
3. cumulative failure experienced up to a given time,
4. failures experienced in a time interval.
Failure behavior is affected by two principal factors:
_ the number of faults in the software being
executed.
_ the execution environment or the operational
profile of execution.

Mean Value & failure intensity functions.


Uses of Reliability Studies
There are at least four other ways in which software
reliability measures can be of great value to the
software engineer, manager or user.
1. You can use software reliability measures to
evaluate software engineering technology
quantitatively.
2. Software reliability measures offer you the
possibility of evaluating development status during the
test phases of a project.

88
3. One can use software reliability measures to
monitor the operational performance of software and
to control new features added and design changes
made to the software.
4. A quantitative understanding of software quality
and the various factors influencing it and affected by it
enriches into the software product and the software
development process.
Software Quality
Different people understand different meanings of quality
like:
 conformance to requirements
 fitness for the purpose
 level of satisfaction

1. Reliability: The extent to which a software


performs its intended functions without failure.

89
2. Correctness: The extent to which a software
meets its specifications.
3. Consistency & precision: The extent to which a
software is consistent and give results with
precision.
4. Robustness: The extent to which a software
tolerates the unexpected problems.
5. Simplicity: The extent to which a software is
simple in its operations.
6. Traceability: The extent to which an error is
traceable in order to fix it.
7. Usability: The extent of effort required to learn,
operate and understand the functions of the
software
8. Accuracy: Meeting specifications with precision.
9. Clarity & Accuracy of documentation: The extent
to which documents are clearly & accurately
written.
10. Conformity of operational environment: The
extent to which a software is in conformity of
operational environment.
11. Completeness: The extent to which a
software has specified functions.
12. Efficiency: The amount of computing
resources and code required by software to
perform a function.

90
13. Testability: The effort required to test a
software to ensure that it performs its intended
functions.
14. Maintainability: The effort required to locate
and fix an error during maintenance phase.
15. Modularity: It is the extent of ease to
implement, test, debug and maintain the
software.
16. Readability: The extent to which a software
is readable in order to understand.
17. Adaptability: The extent to which a software
is adaptable to new platforms & technologies.
18. Modifiability: The effort required to modify a
software during maintenance phase.
19. Expandability: The extent to which a
software is expandable without undesirable side
effects.
20. Portability: The effort required to transfer a
program from one platform to another platform.
ISO 9000
The SEI capability maturity model initiative is an
attempt to improve software quality by improving the
process by which software is developed.
ISO-9000 series of standards is a set of document
dealing with quality systems that can be used for
quality assurance purposes.
ISO-9000 series is not just software standard. It is a
series of five related standards that are applicable to

91
a wide variety of industrial activities, including design/
development, production, installation, and servicing.
Within the ISO 9000 Series, standard ISO 9001 for
quality system is the standard that is most applicable
to software development.
Mapping ISO 9001 to the CMM
1. Management responsibility
2. Quality system
3. Contract review
4. Design control
5. Document control
6. Purchasing
7. Purchaser-supplied product
8. Product identification and traceability
9. Process control
10. Inspection and testing
11. Inspection, measuring and test equipment
12. Inspection and test status
13. Control of nonconforming product
14. Corrective action
15. Handling, storage, packaging and delivery
16. Quality records
17. Internal quality audits
18. Training
19. Servicing
20. Statistical techniques
Contrasting ISO 9001 and the CMM
There is a strong correlation between ISO 9001 and
the CMM, although some issues in ISO 9001 are not

92
covered in the CMM, and some issues in the CMM
are not addressed in ISO 9001.
The biggest difference, however, between these two
documents is the emphasis of the CMM on
continuous process improvement.
The biggest similarity is that for both the CMM and
ISO 9001, the bottom line is “Say what you do;
do what you say”.

Chapter [8]
 What is Testing ?
Many people understand many definitions of testing:-
1. Testing is the process of demonstrating that errors
are not present.
2. The purpose of testing is to show that a program
performs its intended functions correctly.
3. Testing is the process of establishing confidence
that a program does what it is supposed to do.
These definitions are incorrect.
A more appropriate definition is:
“Testing is the process of executing a program
with the intent of finding errors.”
 Why should We Test ?
Although software testing is itself an expensive
activity, yet launching of software without testing may
lead to cost potentially much higher than that of

93
testing, specially in systems where human safety is
involved.
In the software life cycle the earlier the errors are
discovered and removed, the lower is the cost of their
removal.
 Who should Do the Testing ?
o Testing requires the developers to find errors from
their software.
o It is difficult for software developer to point out
errors from own creations.
o Many organisations have made a distinction
between development and testing phase by making
different people responsible for each phase.
 What should We Test ?
We should test the program’s responses to every
possible input. It means, we should test for all valid
and invalid inputs. Suppose a program requires two 8
bit integers as inputs. Total possible combinations are
28x28. If only one second it required to execute one
set of inputs, it may take 18 hours to test all
combinations. Practically, inputs are more than two
and size is also more than 8 bits. We have also not
considered invalid inputs where so many
combinations are possible. Hence, complete testing is
just not possible, although, we may wish to do so.

94
Control flow graph

People make errors. A good synonym is mistake.


This may be a syntax error or misunderstanding of
specifications. Sometimes, there are logical errors.
When developers make mistakes while coding, we
call these mistakes “bugs”.
Some Terminologies
Error, Mistake, Bug, Fault and
Failure
A fault is the representation of an error, where
representation is the mode of expression, such as
narrative text, data flow diagrams, ER diagrams,
source code etc. Defect is a good synonym for fault.
A failure occurs when a fault executes. A particular
fault may cause different failures, depending on how it
has been exercised.
Test, Test Case and Test Suite

95
Test and Test case terms are used
interchangeably. In practice, both are same and are
treated as synonyms. Test case describes an input
description and an expected output description.
The set of test cases is called a test suite. Hence
any combination of test cases may generate a test
suite.
Software Testing
Verification is the process of evaluating a system
or component to determine whether the products of a
given development phase satisfy the conditions
imposed at the start of that phase.
Verification and Validation
Validation is the process of evaluating a system or
component during or at the end of development
process to determine whether it satisfies the specified
requirements .
Testing= Verification+Validation
Alpha, Beta and Acceptance Testing
The term Acceptance Testing is used when the
software is developed for a specific customer. A
series of tests are conducted to enable the customer
to validate all requirements. These tests are
conducted by the end user / customer and may range
from adhoc tests to well planned systematic series of
tests.

96
The terms alpha and beta testing are used when the
software is developed as a product for anonymous
customers.
Alpha Tests are conducted at the developer’s site
by some potential customers. These tests are
conducted in a controlled environment. Alpha testing
may be started when formal testing process is near
completion.
Beta Tests are conducted by the customers / end
users at their sites.
Unlike alpha testing, developer is not present here.
Beta testing is conducted in a real environment that
cannot be controlled by the developer.
 Functional Testing

Black box testing


Integration Testing
The purpose of unit testing is to determine that each
independent module is correctly implemented. This
gives little chance to determine that the interface
between modules is also correct, and for this reason
integration testing must be performed. One specific
target of integration testing is the interface: whether

97
parameters match on both sides as to type,
permissible ranges, meaning and utilization.
System Testing
Of the three levels of testing, the system level is
closet to everyday experiences.
We test many things; a used car before we buy it, an
on-line cable network service before we subscribe,
and so on. A common pattern in these familiar forms
is that we evaluate a product in terms of our
expectations; not with respect to a specification or a
standard. Consequently, goal is not to find faults, but
to demonstrate performance. Because of this we tend
to approach system testing from a functional
standpoint rather than from a structural one. Since it
is so intuitively familiar, system testing in practice
tends to be less formal than it might be, and is
compounded by the reduced testing interval that
usually remains before a delivery deadline.
Petschenik gives some guidelines for choosing test
cases during system testing.
Validation Testing
o It refers to test the software as a complete product.
o This should be done after unit & integration testing.
o Alpha, beta & acceptance testing are nothing but
the various ways of involving
customer during testing.
Validation Testing

98
o IEEE has developed a standard (IEEE standard
1059-1993) entitled “ IEEE guide for software
verification and validation “ to provide specific
guidance about planning and documenting the tasks
required by the standard so that the customer may
write an effective plan.
o Validation testing improves the quality of software
product in terms of functional capabilities and quality
attributes.
The Art of Debugging
The goal of testing is to identify errors (bugs) in the
program. The process of testing generates symptoms,
and a program’s failure is a clear symptom of the
presence of an error. After getting a symptom, we
begin to investigate the cause and place of that error.
After identification of place, we examine that portion
to identify the cause of the problem. This process is
called debugging.
Debugging Techniques
Pressman explained few characteristics of bugs that
provide some clues.
1. “The symptom and the cause may be
geographically remote. That is, the symptom may
appear in one part of a program, while the cause may
actually be located in other part. Highly coupled
program structures may complicate this situation.
2. The symptom may disappear (temporarily) when
another error is corrected.

99
3. The symptom may actually be caused by non
errors (e.g. round off inaccuracies).
4. The symptom may be caused by a human error
that is not easily traced.
5. The symptom may be a result of timing problems
rather than processing problems.
6. It may be difficult to accurately reproduce input
conditions (e.g. a real time application in which input
ordering is indeterminate).
7. The symptom may be intermittent. This is
particularly common in embedded system that couple
hardware with software inextricably.
8. The symptom may be due to causes that are
distributed across a number of tasks running on
different processors”.
Induction approach
_ Locate the pertinent data
_ Organize the data
_ Devise a hypothesis
_ Prove the hypothesis
Deduction approach
_ Enumerate the possible causes or hypotheses
_ Use the data to eliminate possible causes
_ Refine the remaining hypothesis
_ Prove the remaining hypothesis

100
The inductive debugging
process
Testing Tools
One way to improve the quality & quantity of testing is
to make the process as pleasant as possible for the
tester. This means that tools should be as concise,
powerful & natural as possible.
The two broad categories of software testing tools are :
_Static _ Dynamic
There are different types of tools available and some
are listed below:
1. Static analyzers, which examine programs
systematically and automatically.
2. Code inspectors, who inspect programs
automatically to make sure they adhere to minimum
quality standards.
3. standards enforcers, which impose simple rules on
the developer.
4. Coverage analysers, which measure the extent of
coverage.
5. Output comparators, used to determine whether
the output in a program is appropriate or not.

101
6. Test file/ data generators, used to set up test
inputs.
7. Test harnesses, used to simplify test operations.
8. Test archiving systems, used to provide
documentation about programs.

Chapter [9]
What is Software Maintenance?
Software Maintenance is a very broad activity that
includes error corrections, enhancements of
capabilities, deletion of obsolete capabilities, and
optimization.
Categories of Maintenance
 Corrective maintenance:- This refer to
modifications initiated by defects in the
software.
 Adaptive maintenance:- It includes modifying
the software to match changes in the ever
changing environment.
 Perfective maintenance:-It means improving
processing efficiency or performance, or
restructuring the software to improve
changeability. This may include
enhancement of existing system
functionality, improvement in computational
efficiency etc.

102
 Other types of maintenance:-There are long
term effects of corrective, adaptive and
perfective changes.
This leads to increase in the complexity of the
software, which reflect deteriorating structure. The
work is required to be done to maintain it or to reduce
it, if possible. This work may be named as preventive
maintenance.
 Software Maintenance
Problems During Maintenance
 Often the program is written by another
person or group of persons.
 Often the program is changed by person
who did not understand it clearly.
 Program listings are not structured.
 High staff turnover.
 Information gap.
 Systems are not designed for change.
Maintenance is Manageable
A common misconception about maintenance is that it
is not manageable.
Report of survey conducted by Lientz & Swanson
gives some interesting observations:
Emergency debugging 12.4%
Routine debugging 9.3%
Data environment adaptation 17.3%
Changes in hardware and OS 6.2%
Enhancements for users 41.8%

103
Documentation Improvement 5.5%
Code efficiency improvement 4.0%
Others 3.5%
Potential Solutions to Maintenance Problems
 Budget and effort reallocation
 Complete replacement of the system
 Maintenance of existing system
 Software Maintenance
 Program Understanding
The first phase consists of analyzing the program in
order to understand.
 Generating Particular Maintenance Proposal
The second phase consists of generating a particular
maintenance
proposal to accomplish the implementation of the
maintenance objective.
 Ripple Effect
The third phase consists of accounting for all of the
ripple effect as a
consequence of program modifications.
 Software Maintenance
 Modified Program Testing:-The fourth phase
consists of testing the modified program to ensure
that the modified program has at least the same
reliability level as before.
 Maintainability:-Each of these four phases and their
associated software quality attributes are critical to

104
the maintenance process. All of these factors must
be combined to form maintainability.
 Software Maintenance(Maintenance
Models)
_ Quick-fix Model
This is basically an adhoc approach to maintaining
software. It is a fire fighting approach, waiting for the
problem to occur and then trying to fix it as quickly as
possible.

Iterative Enhancement Model


_ Analysis
_ Characterization of proposed modifications
_ Redesign and implementation
Software Maintenance
Reuse Oriented Model
The reuse model has four main steps:
1. Identification of the parts of the old system that are
candidates for reuse.
2. Understanding these system parts.
3. Modification of the old system parts appropriate to
the new requirements.

105
4. Integration of the modified parts into the new
system.
Reverse Engineering
Reverse engineering is the process followed in order
to find difficult, unknown and hidden information about
a software system.
Scope and Tasks
The areas there reverse engineering is applicable
include (but not limited to):
1. Program comprehension
2. Redocumentation and/ or document generation
3. Recovery of design approach and design details at
any level of abstraction
4. Identifying reusable components
5. Identifying components that need restructuring
6. Recovering business rules, and
7. Understanding high level system description
Reverse Engineering encompasses a wide array of
tasks related to understanding and modifying software
system. This array of tasks can be broken into a
number of classes.
Mapping between application and program domains

106
 Mapping between concrete and abstract levels
 Rediscovering high level structures
 Finding missing links between program syntax and
semantics
 To extract reusable component
Levels of Reverse Engineering
Reverse Engineers detect low level implementation
constructs and replace them with their high level
counterparts.
The process eventually results in an incremental
formation of an overall architecture of the program.
 Redocumentation:-
Redocumentation is the recreation
of a semantically equivalent representation within the
same relative abstraction level.
 Design recovery:-
Design recovery entails identifying
and extracting meaningful higher level abstractions
beyond those obtained directly from examination of

107
the source code. This may be achieved from a
combination of code, existing design documentation,
personal experience, and knowledge of the problem
and application domains.
Software RE-Engineering
Software re-engineering is concerned with taking
existing legacy systems and re-implementing them to
make them more maintainable.
The critical distinction between re-engineering and
new software development is the starting point for the
development.
 Study code well before attempting changes
 Concentrate on overall control flow and not
coding
 Heavily comment internal code
 Create Cross References
 Build Symbol tables
 Use own variables, constants and declarations
to lcalize the effect
 Keep detailed maintenance document
The following suggestions may be useful for the
modification of the legacy code:
 Use modern design techniques
Source Code Translation
1. Hardware platform update: The
organization may wish to change its standard
hardware platform. Compilers for the original
language may not be available on the new platform.

108
2. Staff Skill Shortages: There may be lack of
trained maintenance staff for the original language.
This is a particular problem where programs were
written in some non standard language that has now
gone out of general use.
3. Organizational policy changes: An
organization may decide to standardize on a
particular language to minimize its support software
costs. Maintaining many versions of old compilers can
be very expensive.
Program Restructuring
1. Control flow driven restructuring: This
involves the imposition of a clear control structure
within the source code and can be either inter
modular or intra modular in nature.
2. Efficiency driven restructuring: This
involves restructuring a function or algorithm to make
it more efficient. A simple example is the replacement
of an IF-THEN-ELSE-IF-ELSE construct with a CASE
construct.
3. Adaption driven restructuring:This
involves changing the coding style in order to adapt
the program to a new programming language or new
operating environment, for instance changing an
imperative program in PASCAL into a functional
program in LISP.
Configuration Management

109
The process of software development and
maintenance is controlled is called configuration
management. The configuration management is
different in development and maintenance phases of
life cycle due to different environments.
Configuration Management Activities
The activities are divided into four broad categories.
1. The identification of the components and changes
2. The control of the way by which the changes are
made
3. Auditing the changes
4. Status accounting recording and documenting all
the activities that have take place
The following documents are required for
these activities
_ Project plan
_ Software requirements specification document
_ Software design description document
_ Source code listing
_ Test plans / procedures / test cases
_ User manuals
 Software Maintenance
Software Versions
Two types of versions namely revisions (replace) and
variations (variety).
Version Control :
A version control tool is the first stage towards being
able to manage multiple versions. Once it is in place,

110
a detailed record of every version of the software
must be kept. This comprises the
_ Name of each source code component, including
the variations and
revisions
_ The versions of the various compilers and linkers
used
_ The name of the software staff who constructed the
component
_ The date and the time at which it was constructed
Change Control Process
Change control process comes into effect when the
software and associated documentation are delivered
to configuration management change request form
which should record the recommendations regarding
the change.
Documentation
Software documentation is the written record of the
facts about a software system recorded with the intent
to convey purpose, content and clarity.

System Documentation
It refers to those documentation containing all facets
of system, including analysis, specification, design,
implementation, testing, security, error diagnosis and
recover.

111
Chapter [10]
 What is certification?
 Why should we really need it?
 Who should carry out this activity?
 Where should we do such type of
certification?
To whom should we target
 People
 Process
 Product
We have seen many certified developers
(Microsoft certified, Cisco certified, JAVA
certified), certified processes (like ISO or CMM)
and certified products.
There is no clarity about the procedure of
software certification.
 People
Industry specific
 Process
Industry specific
 Product
For the customer directly and helps
to select a particular product

The individual obtaining certification receives


the following values:

112
 Recognition by peers
 Increased confidence in personal
capabilities
 Recognition by software industry for
professional achievement
 Improvement in processes
 Competences maintained through
recertification
Certification is employees initiated
improvement process which improves
competence in quality assurances methods &
techniques.
Professional level of competence in the
principles & practices of software quality
assurance in the software industry can be
achieved by acquiring the designation of:
 Certified Software Quality Analyst (CSQA)
 Certified Software Tester (CSTE)
 Certified Software Project Manager (CSPM)
Some company specific certifications are also
very popular like
Microsoft Office Specialist (MOS) certifications
in Word, Excel and PowerPoint.
MOS is far best known computer skills
certification for administrator.
The most popular process certification
approaches are:
 ISO 9000
 SEI-CMM

113
One should always be suspicious about the
quality of end product, however, certification
reduces the possibility of poor quality products.
Any type of process certification helps to
produce good quality and stable software
product.
 This is what is required for the customer.
 There is no universally accepted product
certification scheme.
 Aviation industry has a popular certification
“RTCA DO-
178B”.
 The targeted certification level is either A,
B, C, D, or E.
 These levels describe the consequences of
a potential failure of the software :
catastrophic, hazardous severe, major,
minor or no effect.
Certification of Products
DO-178B Records
Software Development Plan
Software Verification Plan
Software Configuration Management Plan
Software Quality Assurance Plan
Software Requirements Standards
Software Design Document
Software Verification Test Cases & Products
DO-178B Documents
Software Verification Results
Problem Report

114
Software Configuration Management Records
Software Quality Assurance Records
DO-178B certification process is most
demanding at higher levels.
DO-178B level A will:
1. Have largest potential market
2. Require thorough labour intensive
preparation of most of
the items on the DO-178B support list.
DO-178B Level E would:
1. Require fewer support item and
2. Less taxing on company resources.
Certification of Products
We don’t have product certification in most of
the areas. RTOS (real time operating system) is
the real-time operating system certification &
marked as “LinuxOS-178”.
The establishment of independent agencies is
a viable option.
 Third Party Certification for
Component base Software
Engineering
Weyukar has rightly said “For Component
based Software Development (CBO) to
revolutionalize software development,
developers must be able to produce software
significantly cheaper and faster than they
otherwise could, even as the resulting software
meets the same sort of high reliability
standards while being easy to maintain”.

115
Bill council has also given his views as
“Currently, there is a little evidences that
component based software engineering (CBSE)
is revolutionizing software development, and
lots of reasons to believe otherwise. I believe
the primary reason is that the community is
not showing how to develop trusted
components”.
Contractor:
• Gives the standard
• Directs any variations in specification
• Define patterns
• Allowable tolerances
• Fix the date of delivery
Third party certification is a method to ensure
software components conform to well defined
standards, based on this certification, trusted
assemblies of components can be constructed
Third party certification is based on UL 1998,
2nd ed., UL standard for safety for software in
programmable component.
 S Software Definitions:-
i. Design entity. An element (Component) of a
design that is structurally and functionally distinct from
other elements and that is separately named and
referenced.
ii. Design View. A subset of design entity attribute
information that is specifically suited to the needs of a
software project activity.

116
iii. Entity attributes. A named property or
characteristics of a design entity. It provides a
statement of fact about the entity.
iv. Software design description (SDD). A
representation of a software system created to
facilitate analysis, planning, implementation and
decision making.
Software metrics can be defined as “The
continuous application of measurement based
techniques to the software development
process and its products to supply meaningful
and timely management information, together
with the use of those techniques to improve
that process and its products”.
What is Software Reliability?
“Software reliability means operational reliability. Who
cares how many bugs are in the program?
As per IEEE standard: “Software reliability is defined
as the ability of a system or component to perform its
required functions under stated conditions for a
specified period of time”.
Software reliability is also defined as the probability
that a software system fulfills its assigned task in a
given environment for a predefined number of input
cases, assuming that the hardware and the inputs are
free of error.
“It is the probability of a failure free operation of a
program for a specified time in a specified
environment”.

117
A more appropriate definition is:“Testing is the
process of executing a program with the intent
of finding errors.”
 o Counting rules for C language
1. Comments are not considered.
2. The identifier and function declarations are not
considered.
3. All the variables and constants are considered
operands.
4. Global variables used in different modules of the
same program are counted as multiple occurrences of
the same variable.
5. Local variables with the same name in different
functions are counted as unique operands.
6. Functions calls are considered as operators.
7. All looping statements e.g., do {…} while ( ), while
( ) {…}, for ( ) {…}, all control statements e.g., if ( )
{…}, if ( ) {…} else {…}, etc. are considered as
operators.
8. In control construct switch ( ) {case:…}, switch as
well as all the case statements are considered as
operators.
9. The reserve words like return, default, continue,
break, sizeof, etc., are considered as operators.
10. All the brackets, commas, and terminators are
considered as operators.
11. GOTO is counted as an operator and the label is
counted as an operand.

118
12. The unary and binary occurrence of “+” and “-” are
dealt separately. Similarly “*” (multiplication operator)
are dealt with separately.
13. In the array variables such as “array-name
[index]” “arrayname” and “index” are considered as
operands and [ ] is considered as operator.
14. In the structure variables such as “struct-
name, member-name” or “struct-name -> member-
name”, struct-name, member-name are taken as
operands and ‘.’, ‘->’ are taken as operators. Some
names of member elements in different structure
variables are counted as unique operands.
15. All the hash directive are ignored.

Plan
Software Configuration Management
Plan
Software Quality Assurance Plan

119
Software Requirements Standards
Software Design Document
Software Verification Test Cases &
Products

120

You might also like