Professional Documents
Culture Documents
Ii Year/Iv Semester: - Software Engineering & Project Management
Ii Year/Iv Semester: - Software Engineering & Project Management
PREPARED BY
M Prabu
AP(SR.G)
What is Software?
The product that software professionals build and then support
over the long term.
Software encompasses:
(1) instructions (computer programs) that when executed provide
desired features, function, and performance;
(2) data structures that enable the programs to adequately store
and manipulate information and
(3) documentation that describes the operation and use of the
programs.
2
Features of Software?
• Its characteristics that make it different from other things
human being build.
3
Features of Software?
• Hardware has bathtub curve of failure rate ( high failure rate
in the beginning, then drop to steady state, then cumulative
effects of dust, vibration, abuse occurs).
4
Software Applications
• 1. System software: such as compilers, editors, file management utilities
• 6. Web Apps (Web applications) network centric software. As web 2.0 emerges, more
sophisticated computing environments is supported integrated with remote database and
business applications.
6
Process framework
Why process :
A process defines who is doing what, when and how to
reach a certain goal.
• To build complete software process.
• Identified a small number of framework activities
that are applicable to all software projects, regardless of
their size or complexity.
• It encompasses a set of umbrella activities that
are applicable across the entire software process.
7
Process
Framework
•Each framework
activities is populated by
a set for software
engineering actions – a
collection of related
tasks.
• Each action has
individual work task.
8
Generic Process Framework
Activities
• Communication:
– Heavy communication with customers, stakeholders, team
– Encompasses requirements gathering and related activities
• Planning:
– Workflow that is to follow
– Describe technical task, likely risk, resources will require, work products
to be produced and a work schedule.
• Modeling:
– Help developer and customer to understand requirements (Analysis of
requirements) & Design of software
• Construction
– Code generation: either manual or automated or both
– Testing – to uncover error in the code.
• Deployment:
– Delivery to the customer for evaluation
– Customer provide feedback
9
Umbrella Activities
• Software project tracking and control
– Assessing progress against the project plan.
– Take adequate action to maintain schedule.
10
• Document preparation and production
– Help to create work products such as models, documents, logs,
form and list.
• Reusability management
– Define criteria for work product reuse
– Mechanisms to achieve reusable components.
• Measurement
– Define and collects process, project, and product measures
– Assist the team in delivering software that meets customer‟s
needs.
• Risk management
– Assesses risks that may effect that outcome of project or quality
of product (i.e. software)
11
Software process model
• Process models prescribe a distinct set of activities,
actions, tasks, milestones, and work products required to
engineer high quality software.
12
Prescriptive Model
• Prescriptive process models advocate an orderly approach to software
engineering
– Organize framework activities in a certain order
• Process framework activity with set of software engineering actions.
• Each action in terms of a task set that identifies the work to be
accomplished to meet the goals.
• The resultant process model should be adapted to accommodate the
nature of the specific project, people doing the work, and the work
environment.
• Software engineer choose process framework that includes activities like;
– Communication
– Planning
– Modeling
– Construction
– Deployment
13
Waterfall Model or Classic Life e
Cycl
14
Prescriptive Model
• Calling this model as “Prescribe” because it
recommend a set of process elements,
activities, action task, work product & quality.
15
Waterfall Model or Classic Life
• Cycle
Requirement Analysis and Definition: What - The systems services,
constraints and goals are defined by customers with system users.
• Scheduling tracking -
– Assessing progress against the project plan.
– Require action to maintain schedule.
• System and Software Design: How –It establishes and overall system
architecture. Software design involves fundamental system abstractions and
their relationships.
• Integration and system testing: The individual program unit or programs are
integrated and tested as a complete system to ensure that the software
requirements have been met. After testing, the software system is delivered to
the customer.
• Operation and Maintenance: Normally this is the longest phase of the software
life cycle. The system is installed and put into practical use. Maintenance
involves correcting errors which were not discovered in earlier stages of the
life-cycle.
16
Limitations of the waterfall
During development; during model
The nature of the requirements will not change very much
evolution
The model implies that you should attempt to complete a given stage before
moving on to the next stage
Does not account for the fact that requirements constantly change.
It also means that customers can not use anything until the entire system is
complete.
The model implies that once the product is finished, everything else is
maintenance.
Surprises at the end are very expensive
Some teams sit ideal for other teams to finish
Therefore, this model is only appropriate when the requirements are well-
understood and changes will be fairly limited during the design process.
• Problems:
.
V-Shaped
Strengths
• Emphasize planning for verification and validation of
the
• Easy to use
V-Shaped
Weaknesses
• Does not easily handle concurrent events
Delivers software in small but usable pieces, each piece builds on pieces already
delivered
24
The Incremental Model
• Rather than deliver the system as a single delivery, the development and delivery is broken
down into increments with each increment delivering part of the required functionality.
• It is particularly useful when enough staffing is not available for the whole project
• Incremental model focus more on delivery of operation product with each increment.
The Incremental Model
• User requirements are prioritised and the highest priority requirements
are included in early increments.
• The highest priority system services tend to receive the most testing.
Rapid Application Development (RAD) Model
27
RAD model
• Communication – To understand business problem.
• Modeling –
– Business modeling – Information flow among business is working. Ex. What
kind of information drives?
Who is going to generate information? From where information comes and goes?
– Data modeling – Information refine into set of data objects that are needed
to support business.
to implement business
28
RAD Model
Drawback:
• Not appropriate when technical risks are high ( heavy use of new
technology)
Evolutionary Process
Model
• Produce an increasingly more complete
version of the software with each
iteration.
• Evolutionary Models are iterative.
• Evolutionary models are:
– Prototyping
– Spiral Model
– Concurrent Development Model
– Fourth Generation Techniques (4GT)
Evolutionary Process
Models :
Prototyping
Prototyping
• Best approach when: cohesive
– Objectives defines by customer are general but does not
have details like input, processing, or output requirement.
• Drawing the customer into the team. Planning in an uncertain world has its
limits and plan must be flexible.
• Eliminate all but the most essential work products and keep them lean.
• products
Emphasize angets
that incremental delivery
.Ge),r as rapidly strategy as opposed to intermediate 43
as feasible.
Department of Software
Engineering ,SRMIST.
What is “Agility”?
4. Business people and developers must work together daily throughout the
project.
5. Build projects around motivated individuals. Give them the environment and
support they need, and trust them to get the job done.
12. At regular intervals, the team reflects on how to become more effective,
then tunes and adjusts its behavior accordingly.
Extreme Programming
•
(XP)
The most widely used agile process, originally proposed by Kent Beck in 2004. It
uses an object-oriented approach.
• XP Planning
– Begins with the listening, leads to creation of “user stories” that describes required
output, features, and functionality. Customer assigns a value(i.e., a priority) to
each story.
– Agile team assesses each story and assigns a cost (development weeks. If more
than 3 weeks, customer asked to split into smaller stories)
– Working together, stories are grouped for a deliverable increment next release.
– A commitment (stories to be included, delivery date and
other project matters) is made.
– Three ways:
– 1. Either all stories will be implemented in a few weeks,
– 2. high priority stories first, or
– 3. the riskiest stories will be implemented first.
– For difficult design problems, suggests the creation of “spike solutions”—a design
prototype for that portion is implemented and evaluated.
• XP Testing
– All unit tests are executed daily and ideally should be automated.
Regression tests are conducted to test current and previous components.
– “Acceptance tests” are defined by the customer and executed to
assess customer visible functionality
Extreme Programming
(XP) simple design
spike solut ions
prot ot ypes
CRC cards
user st ories
values
accept ance t est crit eria
it erat ion plan
refact oring
pair
programming
Release
sof t ware increment unit t est
project velocity computed cont inuous int egrat ion
53
Some key practices
include:
• self-directed and self-organizing team
54
REQUIREMENT ENGINEERING
INTRODUCTION
What is
Requirement?
It is a statement describing either
In either case it must contribute in some way towards adequately solving the
customer’s problem;
58
What are
Requirements?
• Requirements are defined during the early stages of a system
development as a specification of what should be implemented or as
a constraint of some kind on the system.
• They may be:
– a user-level facility description,
– a detailed specification of expected system behaviour,
– a general system property,
– a specific constraint on the system,
– information on how to carry out some computation,
• Statements in natural language plus diagrams of the services the system provides
and its operational constraints. Written for customers. provides and its operational
constraints. Written for customers.
System requirements
Interviews Exploring issues Some quantitative but Interviewer can guide Time consuming.
mostly qualitative data interviewee. Artificial environment
Encourages contact may intimidate
between developers interviewee
and users
Focus groups and Collecting multiple Some quantitative but Highlights areas of Possibility of dominant
workshops viewpoints mostly qualitative data consensus and characters
conflict. Encourages
contact between
developers and users
Naturalistic observation Understanding context Qualitative Observing actual work Very time consuming.
of user activity gives insight that other Huge amounts of data
techniques cannot give
[1] Preece, Rogers, and Sharp “Interaction Design: Beyond human-computer interaction”, p214
66
Software Project
Effort and Cost
estimation
& Project Planning
The key parameters which define the quality of any software products, which
are also an outcome of the Cocomo are primarily Effort & Schedule:
Schedule: Simply means the amount of time required for the completion of
the job
Boehm’s definition of organic, semidetached, and embedded
systems:
Organic – A software project is said to be an organic type if the team size required is
adequately small, the problem is well understood and has been solved in the past
The projects classified as Semi-Detached are comparatively less familiar and difficult to
develop compared to the organic ones and require more experience and better guidance
and creativity. E.g.: Compilers or different Embedded Systems can be considered of Semi-
Detached type.
Embedded – A software project with requiring the highest level of complexity, creativity,
and experience requirement fall under this category. Such software requires a larger
team size than the other two models and also the developers need to be sufficiently
All the above system types utilize different values of the constants used in Effort
Calculations.
Types of Models: COCOMO consists of a hierarchy of three increasingly detailed and
accurate forms. Any of the three forms can be adopted according to our
• Global Perspective:
• Take a forward-looking view:
• Open Communication:
• Integrated management:
• Continuous process:
• The first level, Basic COCOMO can be used for quick and slightly rough
calculations of Software Costs. Its accuracy is somewhat restricted due to
the absence of sufficient factor considerations.
• Intermediate COCOMO takes these Cost Drivers into account and Detailed
COCOMO additionally accounts for the influence of individual project
phases
72
• The effort is measured in Person-Months and as evident from the formula
• These formulas are used as such in the Basic Model calculations, as not much
function of the number of lines of code and some constants evaluated according to
However, in reality, no system’s effort and schedule can be solely calculated on the
basis
of Lines of Code. For that, various other factors such as reliability, experience,
Capability. These factors are known as Cost Drivers and the Intermediate Model
Analyst capability
Applications experience
language experience
Required development
schedule
(iii) Personnel attributes –
Analyst capability
Applications experience
language experience
Required development
schedule
The project manager is to rate these 15 different parameters for a particular
project on a scale of one to three.
Then, depending on these ratings, appropriate cost driver values are taken
from the above table.
These 15 values are then multiplied to calculate the EAF (Effort Adjustment
Factor). The Intermediate COCOMO formula now takes the form:
Work Breakdown Structures
Work Breakdown
Structures
●The development of a work breakdown structure is dependent on the project
management style, organizational culture, customer preference, financial
constraints and several other hard-to-define parameters.
FIRST-LEVEL DEFAULT
WBS ELEMENT BUDGET
Management 10%
DOMAIN INCEPTION ELABORATION CONSTRUCTION TRANSITION
Environment 10%
Effort 5% 20% 65% 10%
Requirements 10%
Implementation 25%
The second guideline prescribes the allocation
Assessment 25%
of effort and schedule across the life-cycle phases
Deployment 5%
Total 100%
●Forward-looking:
1. The software project manager develops a characterization of the overall size, process,
environment, people,
and quality required for the project
2. A macro-level estimate of the total effort and schedule is developed using a software cost
estimation model
3. The software project manager partitions the estimate for the effort into a top-level WBS,
also partitions the schedule into major milestone dates and partitions the effort into a staffing
profile
4. At this point, subproject managers are given the responsibility for decomposing each of the WBS
elements into lower levels using their top-level allocation, staffing profile, and major milestone
dates as constraints.
The Cost and Schedule Estimating Process
●Forward-looking:
.
●Backward-looking:
1. The lowest level WBS elements are elaborated into detailed tasks, for which
budgets
and schedules are estimated by the responsible WBS element manager.
2. Estimates are combined and integrated into higher level budgets and milestones.
3. Comparisons are made with the top-down budgets and schedule milestones. Gross
differences are assessed and adjustments are made in order to converge on agreement
between the top-down and the bottom-up estimates.
Software Configuration Management
97
Work Breakdown Structure
• A Work Breakdown Structure includes
dividing a large and complex project into
simpler, manageable and independent
tasks. The root of this tree (structure) is
labelled by the Project name itself.
Sample WBS diagram: