SlideShare ist ein Scribd-Unternehmen logo
1 von 67
Downloaden Sie, um offline zu lesen
OBJECT-ORIENTED
SOFTWAREENGINEERING
UNIT 02 : PROJECT MANAGEMENT, PLANNING AND RISK
ANALYSIS
© 2019, PRAMOD PARAJULI
Disclaimer
These slides are part of teaching materials for Object Oriented
Software Engineering (OOSE). These slides do not cover all
aspect of learning OOSE, nor are these be taken as primary
source of information. As the core textbooks and reference
books for learning the subject has already been specified and
provided to the students, students are encouraged to learn
from the original sources.
Contents in these slides are copyrighted to the instructor and
authors of original texts where applicable.
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
PROJECTMANAGEMENTSPECTRUM,
4Ps
UNIT 02: PROJECT MANAGEMENT
Reference: Pressman, R., Software Engineering – A Practitioner’s Approach, 5th
Ed., Chapter 3
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
PEOPLE
 The players
– Senior managers
– Project managers
– Practitioners
– Customers
– End users
 Team leaders
– Motivate people
– Build and organise team
– Bring ideas/innovations
 Software team
– n individuals assigned to m different
tasks
– n individuals assigned to m different
tasks (m< n)
– n individuals organised into t teams,
each team assigned to one or more
tasks
– Modes:
democratic decentralised (DD),
controlled decentralised (CD), and
controlled centralised (CC)
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
PEOPLE
7 factors to consider while planning the structure
of software engineering teams:
 The difficulty of the problem to be solved.
 The size of the resultant program(s) in lines of code or function points
 The time that the team will stay together (team lifetime).
 The degree to which the problem can be modularized.
 The required quality and reliability of the system to be built.
 The rigidity of the delivery date.
 The degree of sociability (communication) required for the project.
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
COORDINATIONANDCOMMUNICATION
ISSUES
 Formal, impersonal
approaches
 Formal, interpersonal
procedures
 Informal, interpersonal
procedures
 Electronic communication
 Interpersonal networking
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
THEPRODUCT
Software scope
 Context
 Information objectives
 Function and performance
Problem decomposition
 How do we divide the
problem into small
manageable chunks?
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
THEPROCESS
 the linear sequential model
 the prototyping model
 the RAD model
 the incremental model
 the spiral model
 the WINWIN spiral model
 the component-based
development model
 the concurrent development
model
 the formal methods model
 the fourth generation
techniques model
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
THEPROCESS
Process ?
Process ?
Customer
requirement
s
Customer
requirement
s
Product
characteristi
cs
Product
characteristi
cs
Project
environme
nt
Project
environme
nt
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
MELDINGTHEPRODUCTANDTHEPROCESS
Planning
Customer
communication
Risk analysis
Construction and
release
Customer
evaluation
Engineering
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
MELDINGTHEPRODUCTANDTHEPROCESS
(ANEXAMPLE)
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
PROCESSDECOMPOSITION
1. Review customer request
2. Plan and schedule a formal,
facilitated meeting with the
customer
3. Conduct research to specify the
proposed solution and existing
approaches
4. Prepare a ‘working document’ and an
agenda for the formal meeting
5. Conduct the meeting
6. Jointly develop mini-specs that
reflect data, function, and behavioral
features of the software
7. Review each mini-spec for correctness,
consistency and lack of ambiguity
8. Assemble the mini-specs into a
scoping document
9. Review the scoping document with all
concerned
10. Modify the scoping document as
required
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
THEPROJECT
Challenges
 Software people don’t understand their
customer’s needs.
 The product scope is poorly defined.
 Changes are managed poorly.
 The chosen technology changes.
 Business needs change [or are ill-
defined].
 Deadlines are unrealistic.
 Users are resistant.
 Sponsorship is lost [or was never
properly obtained].
 The project team lacks people with
appropriate skills.
 Managers [and practitioners] avoid
best practices and lessons learned
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
APPROACHES
 ParetoPrincipal: 80-20
1. Start on the right foot – with proper autonomy, team, resources, ...
2. Maintain the momentum – encourage, retain, interact, ...
3. Track progress – quantify activities, check milestones, ...
4. Make smart decisions – reuse, risk transfer, buy, follow standards, ...
5. Conduct a post-mortem analysis – experiential learning, analyze
project using metrics, get feedback, ...
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
THEW5
HHPRINCIPLE
Analyse following questions
 Why is the system being developed? – customer validation
 What will be done, by when? – scheduling, milestones, ...
 Who is responsible for a function? – roles, assignments, ...
 Where are they organizationally located? – stakeholders’ responsibilities
 How will the job be done technically and managerially?
 How much of each resource is needed?
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
CRITICALPRACTICES
Every project must go through various critical practices.
 Formal risk management
 Empirical cost and schedule estimation
 Metric-based project management
 Earned value tracking
 Defect tracking against quality targets
 People-aware program management
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
PROJECTMETRICS
UNIT 02: PROJECT MANAGEMENT
Reference: Pressman, R., Software Engineering – A Practitioner’s Approach, 5th
Ed., Chapter 4
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
MEASURESANDMETRICS
 Software process and project metrics are quantitative measures that enable
software engineers to gain insight into the efficiency of the software process
and the projects conducted using the process framework.
 In software project management, we are primarily concerned with
productivity and quality metrics.
 The four reasons for measuring software processes, products, and resources ;
– to characterize,
– to evaluate,
– to predict, and
– to improve.
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
PROCESSMETRICS
 Private process metrics (e.g. defect rates by individual or module) are known
only to the individual or team concerned.
 Public process metrics enable organizations to make strategic changes to
improve the software process.
 Metrics should not be used to evaluate the performance of
individuals.
 Statistical software process improvement helps and organization
to discover where they are strong and where are week.
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
PROJECTMETRICS
 Software project metrics
are used by the software team to adapt project workflow and technical activities.
 Project metrics
are used to avoid development schedule delays, to mitigate potential risks, and to
assess product quality on an on-going basis.
 Every project should measure itsinputs (resources), outputs
(deliverables), and results (effectiveness of deliverables).
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
SOFTWAREMEASUREMENT
 Direct measures of software engineering process include cost and
effort.
 Direct measures of the product include
lines of code (LOC), execution speed, memory size, defects per reporting time
period.
 Indirect measures examine the quality of the software product
itself
(e.g. functionality, complexity, efficiency, reliability, maintainability).
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
SIZE-ORIENTEDMETRICS
 Derived by normalizing (dividing) any direct measure (e.g. defects
or human effort) associated with the product or project by LOC.
 Size oriented metrics are widely used but their validity and
applicability is widely debated.
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
FUNCTION-ORIENTEDMETRICS
 Function points - computed from direct measures of the information domain
of a business software application and assessment of its complexity.
 Once computed function points are used like LOC to normalize measures
for software productivity, quality, and other attributes.
 Feature points and 3D function points - provide a means of extending the
function point concept to allow its use with real-time and other engineering
applications.
 The relationship of LOC and function points depends on the
language used to implement the software.
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
FUNCTION-ORIENTEDMETRICS
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
FUNCTION-ORIENTEDMETRICS
Every Fi relates to;
1. Does the system require reliable backup and
recovery?
2. Are data communications required?
3. Are there distributed processing functions?
4. Is performance critical?
5. Will the system run in an existing, heavily utilized
operational environment?
6. Does the system require on-line data entry?
7. Does the on-line data entry require the input
transaction to be built over multiple screens or
operations?
8. Are the master files updated on-line?
9. Are the inputs, outputs, files, or inquiries complex?
10. Is the internal processing complex?
11. Is the code designed to be reusable?
12. Are conversion and installation included in the
design?
13. Is the system designed for multiple installations in
different organizations?
14. Is the application designed to facilitate change and
ease of use by the user?
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
EXTENDEDFPAND3D
Refer to Pressman, R., Software Engineering – A practitioner’s Approach
Chapter 4
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
METRICSINTEROPERABILITY
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
SOFTWAREQUALITYMETRICS
 Factors assessing software quality come from three distinct points
of view (product operation, product revision, product modification).
 Software quality factors requiring measures include correctness
(defects per KLOC), maintainability (mean time to change), integrity (threat and
security), and usability (easy to learn, easy to use, productivity increase, user
attitude).
 Defect removal efficiency (DRE) is a measure of the filtering ability of the
quality assurance and control activities as they are applied through out the
process framework.
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
SOFTWAREQUALITYMETRICS
Equations of Integrity and DRE
Refer to Pressman, R., Software Engineering – A practitioner’s Approach
Chapter 4
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
OBJECTORIENTEDMETRICS
– No. of scenario
– No. of key classes
– No. of support classes
– No. of subsystems
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
MAKINGUSEOFMEASUREMENTS
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
MAKINGUSEOFMEASUREMENTS
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
INTEGRATINGMETRICSWITHSOFTWARE
PROCESS
 Many software developers do not collect measures.
 Without measurement it is impossible to determine whether a
process is improving or not.
 Baseline metrics data should be collected from a large,
representative sampling of past software projects.
 Getting this historic project data is very difficult, if the previous
developers did not collect data in an on-going manner.
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
STATISTICALPROCESSCONTROL
 It is important to determine whether the metrics collected are
statistically valid and not the result of noise in the data.
 Control charts provide a means for determining whether changes
in the metrics data are meaningful or not.
 Zone rules identify conditions that indicate out of control processes
(expressed as distance from mean in standard deviation units).
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
METRICSFORSMALLORGANIZATIONS
 Most software organizations have fewer than 20 software
engineers.
 Best advice is to choose simple metrics that provide value to the
organization and don’t require a lot of effort to collect.
 Even small groups can expect a significant return on the
investment required to collect metrics, if this activity leads to
process improvement.
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
ESTABLISHINGASOFTWAREMETRICSPROGRAM
 Identify business goal
 Identify what you want to know
 Identify sub-goals
 Identify sub-goal entities and
attributes
 Formalize measurement goals
 Identify quantifiable questions
and indicators related to sub-goals
 Identify data elements needed to
be collected to construct the
indicators
 Define measures to be used and
create operational definitions for
them
 Identify actions needed to
implement the measures
 Prepare a plan to implement the
measures
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
SOFTWAREPROJECTPLANNING
UNIT 02: PROJECT MANAGEMENT
Reference: Pressman, R., Software Engineering – A Practitioner’s Approach, 5th
Ed., Chapter 5
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
ESTIMATING
 Project complexity – cohesiveness, inter and intra-modular interactions
 Project size – increase in size increases interactions among modules
 Degree of structural uncertainty – change in structure of software changes
interactions
 Risk– quantified uncertainty in estimations of resources, cost and schedule.
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
PROJECTPLANNING-OBJECTIVE
 To provide a framework that enables software manager to make a
reasonable estimate of resources, cost, and schedule.
 Project outcomes should be bounded by 'best case' and 'worst case'
scenarios.
 Estimates should be updated as the project progresses.
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
SOFTWARESCOPE
 Describes
– the data to be processed and produced,
– control parameters,
– function,
– performance,
– constraints,
– external interfaces, and
– reliability.
 Often functions described in the software scope statement are
refined to allow for better estimates of cost and schedule.
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
 SOFTWAREPROJECTESTIMATIONOPTIONS
 Delay estimation until late in the project.
 Base estimates on similar projects already completed.
 Use simple decomposition techniques to estimate project cost and
effort.
 Use empirical models for software cost and effort estimation.
 Automated tools may assist with project decomposition and
estimation.
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
DECOMPOSITIONTECHNIQUES
 Software sizing (fuzzy logic, function point, standard component,
change)
 Problem-based estimation (using LOC decomposition focuses on
software functions, using FP decomposition focuses on information
domain characteristics)
 Process-based estimation (decomposition based on tasks required
to complete the software process framework)
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
 EMPIRICALESTIMATIONMODELS
 Typically derived from regression analysis of historical software
project data with estimated person-months as the dependent
variable and KLOC or FP as independent variables.
 Constructive Cost Model (COCOMO) is an example of a static
estimation model.
 The Software Equation is an example of a dynamic estimation
model.
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
 MAKE-BUYDECISION
 It may be more cost effective to acquire a piece of software rather
than develop it.
 Decision tree analysis provides a systematic way to sort through
the make-buy decision.
 As a rule outsourcing software development requires more skillful
management than does in-house development of the same
product.
 Decision-trees
 Using outsourcing, offshoring, insourcing etc.
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
PLANNINGTOOLS
 PERT (Performance Evaluation and Review Technique)
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
PLANNINGTOOLS
 Gantt chart
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
RISKANALYSISANDMANAGEMENT
UNIT 02: PROJECT MANAGEMENT
Reference: Pressman, R., Software Engineering – A Practitioner’s Approach, 5th
Ed., Chapter 6
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
‘If you don’t actively attack the risks, they will
actively attack you.’
~ Tom Gilb
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
RISKMANAGEMENT
 Risk management is concerned with identifying risks and drawing up plans
to minimise their effect on a project.
 A risk is a loss of value due to some adverse circumstance that
might occur (loss due to uncertainty).
– Project risks affect schedule or resources
– Product risks affect the quality or performance of the software being developed
– Business risks affect the organisation developing or procuring the software
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
SOFTWARERISKS
 Project risks – project schedule and resources
 Product risks – quality or performance of the software product
 Business risks – organization
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
RISKMANAGEMENTPROCESS
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
RISKMANAGEMENTPROCESS
 Risk identification
– Identify project, product and business risks
 Risk analysis
– Assess the likelihood and consequences of these risks
 Risk planning
– Draw up plans to avoid or minimise the effects of the risk
 Risk monitoring
– Monitor the risks throughout the project
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
RISKANALYSIS
 Assess probability and
seriousness of each risk
 Probability may be very
low, low, moderate, high
or very high
 Risk effects might be
catastrophic, serious,
tolerable or insignificant
Risk Probability Effects
Organisational financial problems force
reductions in the project budget.
Low Catastrophic
It is impossible to recruit staff with the skills
required for the project.
High Catastrophic
Key staff are ill at critical times in the project. Moderate Serious
Software components which should be reused
contain defects which limit their functionality.
Moderate Serious
Changes to requirements which require major
design rework are proposed.
Moderate Serious
The organisation is restructured so that different
management are responsible for the project.
High Serious
The database used in the system cannot process
as many transactions per second as expected.
Moderate Serious
The time required to develop the software is
underestimated.
High Serious
CASE tools cannot be integrated. High Tolerable
Customers fail to understand the impact of
requirements changes.
Moderate Tolerable
Required training for staff is not available. Moderate Tolerable
The rate of defect repair is underestimated. Moderate Tolerable
The size of the software is underestimated. High Tolerable
The code generated by CASE tools is inefficient. Moderate Insignificant
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
RISKITEMCHECKLIST
 Product size — risks associated with
the overall size of the software to be
built or modified.
 Business impact — risks associated
with constraints imposed by
management or the marketplace.
 Customer characteristics —risks
associated with the sophistication of
the customer and the developer's
ability to communicate with the
customer in a timely manner.
 Process definition — risks associated
with the degree to which the software
process has been defined and is
followed.
 Development environment — risks
associated with the availability and
quality of the tool.
 Technology to be built — risks
associated with the complexity of the
system to be built
 Staff size and experience
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
ASSESSINGOVERALLPROJECTRISK
 Have top software and customer managers
formally committed to support the project?
 Are end-users enthusiastically committed to
the projectand the system/product to be
built?
 Are requirements fully understood by the
software engineering team and their
customers?
 Have customers been involved fully in the
definition of requirements?
 Do end-users have realistic expectations?
 Is projectscope stable?
 Does the software engineering team
have the right mix of skills?
 Are project requirements stable?
 Does the project team have experience
with the technology to be
implemented?
 Is the number of people on the project
team adequate to do the job?
 Do all customer/user constituencies
agree on the importance of the project
and on the requirements for the
system/product to be built?
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
RISKCOMPONENTSANDDRIVERS
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
RISKIDENTIFICATION
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
RISKMATRIXANDRISKTABLE
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
RISKIMPACT
 Risk exposure (RE) = risk probability * risk impact
 A triplet can represent risk [ri,li,xi]
 Risk refinement - Given that <condition> then there is
concern that (possibly) <consequence>.
 e.g. Certain reusable components were developed by a third
party with no knowledge of internal design standards.
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
RISKPLANNING
 Consider each risk and develop a strategy to manage that risk
 Reactive vs. proactive approach
 Avoidance strategies
– The probability that the risk will arise is reduced
 Minimisation strategies
– The impact of the risk on the project or product will be reduced
 Contingency plans
– If risk arises, contingency plans are to deal with that risk
 Risk appetite, risk mitigation, risk transfer
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
RISKMANAGEMENTSTRATEGIES
Risk Strategy
Organisational
financial problems
Prepare a briefing document for senior management showing
how the project is making a very important contribution to the
goals of the business.
Recruitment
problems
Alert customer of potential difficulties and the possibility of
delays, investigate buying-in components.
Staff illness Reorganise team so that there is more overlap of work and
people therefore understand each other’s jobs.
Defective
components
Replace potentially defective components with bought-in
components of known reliability.
Requirements
changes
Derive traceability information to assess requirements
change impact, maximise information hiding in the design.
Organisational
restructuring
Prepare a briefing document for senior management showing
how the project is making a very important contribution to the
goals of the business.
Database
performance
Investigate the possibility of buying a higher-performance
database.
Underestimated
development time
Investigate buying in components, investigate use of a
program generator.
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
RISKMITIGATIONEXAMPLE–EMPLOYEETURNOVER
ANDPOSSIBLESTEPS
 Meet with current staff to determine causes for turnover (e.g., poor working
conditions, low pay, competitive job market).
 Mitigate those causes that are under our control before the project starts.
 Once the project commences, assume turnover will occur and develop techniques to
ensure continuity when people leave.
 Organize project teams so that information about each development activity is widely
dispersed.
 Define documentation standards and establish mechanisms to be sure that
documents are developed in a timely manner.
 Conduct peer reviews of all work (so that more than one person is "up to speed”).
 Assign a backup staff member for every critical technologist.
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
RISKMONITORING
 Assess each identified risks regularly to decide whether
or not it is becoming less or more probable
 Also assess whether the effects of the risk have changed
 Each key risk should be discussed at management
progress meetings
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
RISKFACTORS
OOSE UNIT 02 - Project Management, Planning & Risk Analysis
End of Unit 02 : Project Management, Planning and
Risk Analysis
OOSE UNIT 02 - Project Management, Planning & Risk Analysis

Weitere ähnliche Inhalte

Was ist angesagt?

Object Orientation Fundamentals
Object Orientation FundamentalsObject Orientation Fundamentals
Object Orientation FundamentalsPramod Parajuli
 
Software Engineering
Software Engineering Software Engineering
Software Engineering JayaKamal
 
Software Engineering Assignment
Software Engineering AssignmentSoftware Engineering Assignment
Software Engineering AssignmentSohaib Latif
 
Selenium - A Trending Automation Testing Tool
Selenium - A Trending Automation Testing ToolSelenium - A Trending Automation Testing Tool
Selenium - A Trending Automation Testing Toolijtsrd
 
Notes of Software engineering and Project Management
Notes of Software engineering and Project ManagementNotes of Software engineering and Project Management
Notes of Software engineering and Project ManagementNANDINI SHARMA
 
Software Engineering unit 2
Software Engineering unit 2Software Engineering unit 2
Software Engineering unit 2Abhimanyu Mishra
 
Software Engineering
Software Engineering Software Engineering
Software Engineering JayaKamal
 
Software Engineering
 Software Engineering  Software Engineering
Software Engineering JayaKamal
 
Software Engineering Unit 1
Software Engineering Unit 1Software Engineering Unit 1
Software Engineering Unit 1Abhimanyu Mishra
 
Software Engineering
Software Engineering Software Engineering
Software Engineering JayaKamal
 
Introduction to software engineering
Introduction to software engineeringIntroduction to software engineering
Introduction to software engineeringHitesh Mohapatra
 
Software process methodologies and a comparative study of various models
Software process methodologies and a comparative study of various modelsSoftware process methodologies and a comparative study of various models
Software process methodologies and a comparative study of various modelsiaemedu
 
Unit i FUNDAMENTALS OF SOFTWARE ENGINEERING
Unit i FUNDAMENTALS OF SOFTWARE ENGINEERINGUnit i FUNDAMENTALS OF SOFTWARE ENGINEERING
Unit i FUNDAMENTALS OF SOFTWARE ENGINEERINGSangeetha Rangarajan
 
Quality Attribute: Testability
Quality Attribute: TestabilityQuality Attribute: Testability
Quality Attribute: TestabilityPranay Singh
 
Software Engineering unit 3
Software Engineering unit 3Software Engineering unit 3
Software Engineering unit 3Abhimanyu Mishra
 
Software engg. pressman_ch-7-complete
Software engg. pressman_ch-7-completeSoftware engg. pressman_ch-7-complete
Software engg. pressman_ch-7-completeDhairya Joshi
 
Design concepts
Design conceptsDesign concepts
Design conceptsJoshuaU1
 

Was ist angesagt? (20)

Object Orientation Fundamentals
Object Orientation FundamentalsObject Orientation Fundamentals
Object Orientation Fundamentals
 
Software Engineering
Software Engineering Software Engineering
Software Engineering
 
Software Engineering Assignment
Software Engineering AssignmentSoftware Engineering Assignment
Software Engineering Assignment
 
Selenium - A Trending Automation Testing Tool
Selenium - A Trending Automation Testing ToolSelenium - A Trending Automation Testing Tool
Selenium - A Trending Automation Testing Tool
 
Notes of Software engineering and Project Management
Notes of Software engineering and Project ManagementNotes of Software engineering and Project Management
Notes of Software engineering and Project Management
 
Software Engineering unit 2
Software Engineering unit 2Software Engineering unit 2
Software Engineering unit 2
 
Software Engineering
Software EngineeringSoftware Engineering
Software Engineering
 
Software Engineering
Software Engineering Software Engineering
Software Engineering
 
Software Engineering
 Software Engineering  Software Engineering
Software Engineering
 
Software Engineering Unit 1
Software Engineering Unit 1Software Engineering Unit 1
Software Engineering Unit 1
 
Software Engineering
Software Engineering Software Engineering
Software Engineering
 
Introduction to software engineering
Introduction to software engineeringIntroduction to software engineering
Introduction to software engineering
 
Software process methodologies and a comparative study of various models
Software process methodologies and a comparative study of various modelsSoftware process methodologies and a comparative study of various models
Software process methodologies and a comparative study of various models
 
Sda 1
Sda   1Sda   1
Sda 1
 
Software Engineering
Software EngineeringSoftware Engineering
Software Engineering
 
Unit i FUNDAMENTALS OF SOFTWARE ENGINEERING
Unit i FUNDAMENTALS OF SOFTWARE ENGINEERINGUnit i FUNDAMENTALS OF SOFTWARE ENGINEERING
Unit i FUNDAMENTALS OF SOFTWARE ENGINEERING
 
Quality Attribute: Testability
Quality Attribute: TestabilityQuality Attribute: Testability
Quality Attribute: Testability
 
Software Engineering unit 3
Software Engineering unit 3Software Engineering unit 3
Software Engineering unit 3
 
Software engg. pressman_ch-7-complete
Software engg. pressman_ch-7-completeSoftware engg. pressman_ch-7-complete
Software engg. pressman_ch-7-complete
 
Design concepts
Design conceptsDesign concepts
Design concepts
 

Ähnlich wie Project Mangement Planning and Risk Analysis

Elico Solutions' Odoo ERP Project Management Implementation Approach
Elico Solutions' Odoo ERP Project Management Implementation ApproachElico Solutions' Odoo ERP Project Management Implementation Approach
Elico Solutions' Odoo ERP Project Management Implementation ApproachElico Solutions Singapore
 
Bca 5th sem seminar(software measurements)
Bca 5th sem seminar(software measurements)Bca 5th sem seminar(software measurements)
Bca 5th sem seminar(software measurements)MuskanSony
 
Exploring the Efficiency of the Program using OOAD Metrics
Exploring the Efficiency of the Program using OOAD MetricsExploring the Efficiency of the Program using OOAD Metrics
Exploring the Efficiency of the Program using OOAD MetricsIRJET Journal
 
Project Management Complete Concept
Project Management Complete Concept Project Management Complete Concept
Project Management Complete Concept MuhammadTalha436
 
Planning in Software Projects
Planning in Software ProjectsPlanning in Software Projects
Planning in Software ProjectsJayakumar PP
 
Ethics of software project management
Ethics of software project managementEthics of software project management
Ethics of software project managementPeica Ionela
 
Managing Software Project
Managing Software ProjectManaging Software Project
Managing Software ProjectAnas Bilal
 
Certified Predictive Modeler (CPM)
Certified Predictive Modeler (CPM)Certified Predictive Modeler (CPM)
Certified Predictive Modeler (CPM)GICTTraining
 
PPT_Management of Large and Complex Software Projects
PPT_Management of Large and Complex Software ProjectsPPT_Management of Large and Complex Software Projects
PPT_Management of Large and Complex Software ProjectsSudipta Das
 
Lecture 2 introduction to Software Engineering 1
Lecture 2   introduction to Software Engineering 1Lecture 2   introduction to Software Engineering 1
Lecture 2 introduction to Software Engineering 1IIUI
 
D0365030036
D0365030036D0365030036
D0365030036theijes
 

Ähnlich wie Project Mangement Planning and Risk Analysis (20)

Guide to Software Estimation
Guide to Software EstimationGuide to Software Estimation
Guide to Software Estimation
 
unit-1.ppt
unit-1.pptunit-1.ppt
unit-1.ppt
 
Elico Solutions' Odoo ERP Project Management Implementation Approach
Elico Solutions' Odoo ERP Project Management Implementation ApproachElico Solutions' Odoo ERP Project Management Implementation Approach
Elico Solutions' Odoo ERP Project Management Implementation Approach
 
Bca 5th sem seminar(software measurements)
Bca 5th sem seminar(software measurements)Bca 5th sem seminar(software measurements)
Bca 5th sem seminar(software measurements)
 
BA-SachinMehta
BA-SachinMehtaBA-SachinMehta
BA-SachinMehta
 
Software Engineering
Software EngineeringSoftware Engineering
Software Engineering
 
Exploring the Efficiency of the Program using OOAD Metrics
Exploring the Efficiency of the Program using OOAD MetricsExploring the Efficiency of the Program using OOAD Metrics
Exploring the Efficiency of the Program using OOAD Metrics
 
Project Management Complete Concept
Project Management Complete Concept Project Management Complete Concept
Project Management Complete Concept
 
Planning in Software Projects
Planning in Software ProjectsPlanning in Software Projects
Planning in Software Projects
 
Ethics of software project management
Ethics of software project managementEthics of software project management
Ethics of software project management
 
Managment spectrum
Managment spectrumManagment spectrum
Managment spectrum
 
Managing Software Project
Managing Software ProjectManaging Software Project
Managing Software Project
 
An Introduction to Project management(project management tutorials)
An Introduction to Project management(project management tutorials)An Introduction to Project management(project management tutorials)
An Introduction to Project management(project management tutorials)
 
Certified Predictive Modeler (CPM)
Certified Predictive Modeler (CPM)Certified Predictive Modeler (CPM)
Certified Predictive Modeler (CPM)
 
PPT_Management of Large and Complex Software Projects
PPT_Management of Large and Complex Software ProjectsPPT_Management of Large and Complex Software Projects
PPT_Management of Large and Complex Software Projects
 
Lecture 2 introduction to Software Engineering 1
Lecture 2   introduction to Software Engineering 1Lecture 2   introduction to Software Engineering 1
Lecture 2 introduction to Software Engineering 1
 
D0365030036
D0365030036D0365030036
D0365030036
 
VASUDEO RANE
VASUDEO RANEVASUDEO RANE
VASUDEO RANE
 
SE chapters 21-23
SE chapters 21-23SE chapters 21-23
SE chapters 21-23
 
Slides chapters 21-23
Slides chapters 21-23Slides chapters 21-23
Slides chapters 21-23
 

Kürzlich hochgeladen

Integration and Automation in Practice: CI/CD in Mule Integration and Automat...
Integration and Automation in Practice: CI/CD in Mule Integration and Automat...Integration and Automation in Practice: CI/CD in Mule Integration and Automat...
Integration and Automation in Practice: CI/CD in Mule Integration and Automat...Patryk Bandurski
 
Transcript: #StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024
Transcript: #StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024Transcript: #StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024
Transcript: #StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024BookNet Canada
 
SQL Database Design For Developers at php[tek] 2024
SQL Database Design For Developers at php[tek] 2024SQL Database Design For Developers at php[tek] 2024
SQL Database Design For Developers at php[tek] 2024Scott Keck-Warren
 
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
04-2024-HHUG-Sales-and-Marketing-Alignment.pptxHampshireHUG
 
Benefits Of Flutter Compared To Other Frameworks
Benefits Of Flutter Compared To Other FrameworksBenefits Of Flutter Compared To Other Frameworks
Benefits Of Flutter Compared To Other FrameworksSoftradix Technologies
 
Salesforce Community Group Quito, Salesforce 101
Salesforce Community Group Quito, Salesforce 101Salesforce Community Group Quito, Salesforce 101
Salesforce Community Group Quito, Salesforce 101Paola De la Torre
 
My Hashitalk Indonesia April 2024 Presentation
My Hashitalk Indonesia April 2024 PresentationMy Hashitalk Indonesia April 2024 Presentation
My Hashitalk Indonesia April 2024 PresentationRidwan Fadjar
 
WhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure service
WhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure serviceWhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure service
WhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure servicePooja Nehwal
 
Human Factors of XR: Using Human Factors to Design XR Systems
Human Factors of XR: Using Human Factors to Design XR SystemsHuman Factors of XR: Using Human Factors to Design XR Systems
Human Factors of XR: Using Human Factors to Design XR SystemsMark Billinghurst
 
Maximizing Board Effectiveness 2024 Webinar.pptx
Maximizing Board Effectiveness 2024 Webinar.pptxMaximizing Board Effectiveness 2024 Webinar.pptx
Maximizing Board Effectiveness 2024 Webinar.pptxOnBoard
 
Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...
Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...
Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...shyamraj55
 
AI as an Interface for Commercial Buildings
AI as an Interface for Commercial BuildingsAI as an Interface for Commercial Buildings
AI as an Interface for Commercial BuildingsMemoori
 
Handwritten Text Recognition for manuscripts and early printed texts
Handwritten Text Recognition for manuscripts and early printed textsHandwritten Text Recognition for manuscripts and early printed texts
Handwritten Text Recognition for manuscripts and early printed textsMaria Levchenko
 
Slack Application Development 101 Slides
Slack Application Development 101 SlidesSlack Application Development 101 Slides
Slack Application Development 101 Slidespraypatel2
 
How to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected WorkerHow to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected WorkerThousandEyes
 
How to Remove Document Management Hurdles with X-Docs?
How to Remove Document Management Hurdles with X-Docs?How to Remove Document Management Hurdles with X-Docs?
How to Remove Document Management Hurdles with X-Docs?XfilesPro
 
Unblocking The Main Thread Solving ANRs and Frozen Frames
Unblocking The Main Thread Solving ANRs and Frozen FramesUnblocking The Main Thread Solving ANRs and Frozen Frames
Unblocking The Main Thread Solving ANRs and Frozen FramesSinan KOZAK
 
Key Features Of Token Development (1).pptx
Key  Features Of Token  Development (1).pptxKey  Features Of Token  Development (1).pptx
Key Features Of Token Development (1).pptxLBM Solutions
 
Factors to Consider When Choosing Accounts Payable Services Providers.pptx
Factors to Consider When Choosing Accounts Payable Services Providers.pptxFactors to Consider When Choosing Accounts Payable Services Providers.pptx
Factors to Consider When Choosing Accounts Payable Services Providers.pptxKatpro Technologies
 
Install Stable Diffusion in windows machine
Install Stable Diffusion in windows machineInstall Stable Diffusion in windows machine
Install Stable Diffusion in windows machinePadma Pradeep
 

Kürzlich hochgeladen (20)

Integration and Automation in Practice: CI/CD in Mule Integration and Automat...
Integration and Automation in Practice: CI/CD in Mule Integration and Automat...Integration and Automation in Practice: CI/CD in Mule Integration and Automat...
Integration and Automation in Practice: CI/CD in Mule Integration and Automat...
 
Transcript: #StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024
Transcript: #StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024Transcript: #StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024
Transcript: #StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024
 
SQL Database Design For Developers at php[tek] 2024
SQL Database Design For Developers at php[tek] 2024SQL Database Design For Developers at php[tek] 2024
SQL Database Design For Developers at php[tek] 2024
 
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
 
Benefits Of Flutter Compared To Other Frameworks
Benefits Of Flutter Compared To Other FrameworksBenefits Of Flutter Compared To Other Frameworks
Benefits Of Flutter Compared To Other Frameworks
 
Salesforce Community Group Quito, Salesforce 101
Salesforce Community Group Quito, Salesforce 101Salesforce Community Group Quito, Salesforce 101
Salesforce Community Group Quito, Salesforce 101
 
My Hashitalk Indonesia April 2024 Presentation
My Hashitalk Indonesia April 2024 PresentationMy Hashitalk Indonesia April 2024 Presentation
My Hashitalk Indonesia April 2024 Presentation
 
WhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure service
WhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure serviceWhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure service
WhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure service
 
Human Factors of XR: Using Human Factors to Design XR Systems
Human Factors of XR: Using Human Factors to Design XR SystemsHuman Factors of XR: Using Human Factors to Design XR Systems
Human Factors of XR: Using Human Factors to Design XR Systems
 
Maximizing Board Effectiveness 2024 Webinar.pptx
Maximizing Board Effectiveness 2024 Webinar.pptxMaximizing Board Effectiveness 2024 Webinar.pptx
Maximizing Board Effectiveness 2024 Webinar.pptx
 
Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...
Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...
Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...
 
AI as an Interface for Commercial Buildings
AI as an Interface for Commercial BuildingsAI as an Interface for Commercial Buildings
AI as an Interface for Commercial Buildings
 
Handwritten Text Recognition for manuscripts and early printed texts
Handwritten Text Recognition for manuscripts and early printed textsHandwritten Text Recognition for manuscripts and early printed texts
Handwritten Text Recognition for manuscripts and early printed texts
 
Slack Application Development 101 Slides
Slack Application Development 101 SlidesSlack Application Development 101 Slides
Slack Application Development 101 Slides
 
How to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected WorkerHow to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected Worker
 
How to Remove Document Management Hurdles with X-Docs?
How to Remove Document Management Hurdles with X-Docs?How to Remove Document Management Hurdles with X-Docs?
How to Remove Document Management Hurdles with X-Docs?
 
Unblocking The Main Thread Solving ANRs and Frozen Frames
Unblocking The Main Thread Solving ANRs and Frozen FramesUnblocking The Main Thread Solving ANRs and Frozen Frames
Unblocking The Main Thread Solving ANRs and Frozen Frames
 
Key Features Of Token Development (1).pptx
Key  Features Of Token  Development (1).pptxKey  Features Of Token  Development (1).pptx
Key Features Of Token Development (1).pptx
 
Factors to Consider When Choosing Accounts Payable Services Providers.pptx
Factors to Consider When Choosing Accounts Payable Services Providers.pptxFactors to Consider When Choosing Accounts Payable Services Providers.pptx
Factors to Consider When Choosing Accounts Payable Services Providers.pptx
 
Install Stable Diffusion in windows machine
Install Stable Diffusion in windows machineInstall Stable Diffusion in windows machine
Install Stable Diffusion in windows machine
 

Project Mangement Planning and Risk Analysis

  • 1. OBJECT-ORIENTED SOFTWAREENGINEERING UNIT 02 : PROJECT MANAGEMENT, PLANNING AND RISK ANALYSIS © 2019, PRAMOD PARAJULI
  • 2. Disclaimer These slides are part of teaching materials for Object Oriented Software Engineering (OOSE). These slides do not cover all aspect of learning OOSE, nor are these be taken as primary source of information. As the core textbooks and reference books for learning the subject has already been specified and provided to the students, students are encouraged to learn from the original sources. Contents in these slides are copyrighted to the instructor and authors of original texts where applicable. OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 3. OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 4. PROJECTMANAGEMENTSPECTRUM, 4Ps UNIT 02: PROJECT MANAGEMENT Reference: Pressman, R., Software Engineering – A Practitioner’s Approach, 5th Ed., Chapter 3 OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 5. PEOPLE  The players – Senior managers – Project managers – Practitioners – Customers – End users  Team leaders – Motivate people – Build and organise team – Bring ideas/innovations  Software team – n individuals assigned to m different tasks – n individuals assigned to m different tasks (m< n) – n individuals organised into t teams, each team assigned to one or more tasks – Modes: democratic decentralised (DD), controlled decentralised (CD), and controlled centralised (CC) OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 6. PEOPLE 7 factors to consider while planning the structure of software engineering teams:  The difficulty of the problem to be solved.  The size of the resultant program(s) in lines of code or function points  The time that the team will stay together (team lifetime).  The degree to which the problem can be modularized.  The required quality and reliability of the system to be built.  The rigidity of the delivery date.  The degree of sociability (communication) required for the project. OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 7. COORDINATIONANDCOMMUNICATION ISSUES  Formal, impersonal approaches  Formal, interpersonal procedures  Informal, interpersonal procedures  Electronic communication  Interpersonal networking OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 8. THEPRODUCT Software scope  Context  Information objectives  Function and performance Problem decomposition  How do we divide the problem into small manageable chunks? OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 9. THEPROCESS  the linear sequential model  the prototyping model  the RAD model  the incremental model  the spiral model  the WINWIN spiral model  the component-based development model  the concurrent development model  the formal methods model  the fourth generation techniques model OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 12. MELDINGTHEPRODUCTANDTHEPROCESS (ANEXAMPLE) OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 13. PROCESSDECOMPOSITION 1. Review customer request 2. Plan and schedule a formal, facilitated meeting with the customer 3. Conduct research to specify the proposed solution and existing approaches 4. Prepare a ‘working document’ and an agenda for the formal meeting 5. Conduct the meeting 6. Jointly develop mini-specs that reflect data, function, and behavioral features of the software 7. Review each mini-spec for correctness, consistency and lack of ambiguity 8. Assemble the mini-specs into a scoping document 9. Review the scoping document with all concerned 10. Modify the scoping document as required OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 14. THEPROJECT Challenges  Software people don’t understand their customer’s needs.  The product scope is poorly defined.  Changes are managed poorly.  The chosen technology changes.  Business needs change [or are ill- defined].  Deadlines are unrealistic.  Users are resistant.  Sponsorship is lost [or was never properly obtained].  The project team lacks people with appropriate skills.  Managers [and practitioners] avoid best practices and lessons learned OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 15. APPROACHES  ParetoPrincipal: 80-20 1. Start on the right foot – with proper autonomy, team, resources, ... 2. Maintain the momentum – encourage, retain, interact, ... 3. Track progress – quantify activities, check milestones, ... 4. Make smart decisions – reuse, risk transfer, buy, follow standards, ... 5. Conduct a post-mortem analysis – experiential learning, analyze project using metrics, get feedback, ... OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 16. THEW5 HHPRINCIPLE Analyse following questions  Why is the system being developed? – customer validation  What will be done, by when? – scheduling, milestones, ...  Who is responsible for a function? – roles, assignments, ...  Where are they organizationally located? – stakeholders’ responsibilities  How will the job be done technically and managerially?  How much of each resource is needed? OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 17. CRITICALPRACTICES Every project must go through various critical practices.  Formal risk management  Empirical cost and schedule estimation  Metric-based project management  Earned value tracking  Defect tracking against quality targets  People-aware program management OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 18. PROJECTMETRICS UNIT 02: PROJECT MANAGEMENT Reference: Pressman, R., Software Engineering – A Practitioner’s Approach, 5th Ed., Chapter 4 OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 19. MEASURESANDMETRICS  Software process and project metrics are quantitative measures that enable software engineers to gain insight into the efficiency of the software process and the projects conducted using the process framework.  In software project management, we are primarily concerned with productivity and quality metrics.  The four reasons for measuring software processes, products, and resources ; – to characterize, – to evaluate, – to predict, and – to improve. OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 20. PROCESSMETRICS  Private process metrics (e.g. defect rates by individual or module) are known only to the individual or team concerned.  Public process metrics enable organizations to make strategic changes to improve the software process.  Metrics should not be used to evaluate the performance of individuals.  Statistical software process improvement helps and organization to discover where they are strong and where are week. OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 21. PROJECTMETRICS  Software project metrics are used by the software team to adapt project workflow and technical activities.  Project metrics are used to avoid development schedule delays, to mitigate potential risks, and to assess product quality on an on-going basis.  Every project should measure itsinputs (resources), outputs (deliverables), and results (effectiveness of deliverables). OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 22. SOFTWAREMEASUREMENT  Direct measures of software engineering process include cost and effort.  Direct measures of the product include lines of code (LOC), execution speed, memory size, defects per reporting time period.  Indirect measures examine the quality of the software product itself (e.g. functionality, complexity, efficiency, reliability, maintainability). OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 23. SIZE-ORIENTEDMETRICS  Derived by normalizing (dividing) any direct measure (e.g. defects or human effort) associated with the product or project by LOC.  Size oriented metrics are widely used but their validity and applicability is widely debated. OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 24. FUNCTION-ORIENTEDMETRICS  Function points - computed from direct measures of the information domain of a business software application and assessment of its complexity.  Once computed function points are used like LOC to normalize measures for software productivity, quality, and other attributes.  Feature points and 3D function points - provide a means of extending the function point concept to allow its use with real-time and other engineering applications.  The relationship of LOC and function points depends on the language used to implement the software. OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 25. FUNCTION-ORIENTEDMETRICS OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 26. FUNCTION-ORIENTEDMETRICS Every Fi relates to; 1. Does the system require reliable backup and recovery? 2. Are data communications required? 3. Are there distributed processing functions? 4. Is performance critical? 5. Will the system run in an existing, heavily utilized operational environment? 6. Does the system require on-line data entry? 7. Does the on-line data entry require the input transaction to be built over multiple screens or operations? 8. Are the master files updated on-line? 9. Are the inputs, outputs, files, or inquiries complex? 10. Is the internal processing complex? 11. Is the code designed to be reusable? 12. Are conversion and installation included in the design? 13. Is the system designed for multiple installations in different organizations? 14. Is the application designed to facilitate change and ease of use by the user? OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 27. EXTENDEDFPAND3D Refer to Pressman, R., Software Engineering – A practitioner’s Approach Chapter 4 OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 28. METRICSINTEROPERABILITY OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 29. SOFTWAREQUALITYMETRICS  Factors assessing software quality come from three distinct points of view (product operation, product revision, product modification).  Software quality factors requiring measures include correctness (defects per KLOC), maintainability (mean time to change), integrity (threat and security), and usability (easy to learn, easy to use, productivity increase, user attitude).  Defect removal efficiency (DRE) is a measure of the filtering ability of the quality assurance and control activities as they are applied through out the process framework. OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 30. SOFTWAREQUALITYMETRICS Equations of Integrity and DRE Refer to Pressman, R., Software Engineering – A practitioner’s Approach Chapter 4 OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 31. OBJECTORIENTEDMETRICS – No. of scenario – No. of key classes – No. of support classes – No. of subsystems OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 32. MAKINGUSEOFMEASUREMENTS OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 33. MAKINGUSEOFMEASUREMENTS OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 34. INTEGRATINGMETRICSWITHSOFTWARE PROCESS  Many software developers do not collect measures.  Without measurement it is impossible to determine whether a process is improving or not.  Baseline metrics data should be collected from a large, representative sampling of past software projects.  Getting this historic project data is very difficult, if the previous developers did not collect data in an on-going manner. OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 35. STATISTICALPROCESSCONTROL  It is important to determine whether the metrics collected are statistically valid and not the result of noise in the data.  Control charts provide a means for determining whether changes in the metrics data are meaningful or not.  Zone rules identify conditions that indicate out of control processes (expressed as distance from mean in standard deviation units). OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 36. METRICSFORSMALLORGANIZATIONS  Most software organizations have fewer than 20 software engineers.  Best advice is to choose simple metrics that provide value to the organization and don’t require a lot of effort to collect.  Even small groups can expect a significant return on the investment required to collect metrics, if this activity leads to process improvement. OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 37. ESTABLISHINGASOFTWAREMETRICSPROGRAM  Identify business goal  Identify what you want to know  Identify sub-goals  Identify sub-goal entities and attributes  Formalize measurement goals  Identify quantifiable questions and indicators related to sub-goals  Identify data elements needed to be collected to construct the indicators  Define measures to be used and create operational definitions for them  Identify actions needed to implement the measures  Prepare a plan to implement the measures OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 38. SOFTWAREPROJECTPLANNING UNIT 02: PROJECT MANAGEMENT Reference: Pressman, R., Software Engineering – A Practitioner’s Approach, 5th Ed., Chapter 5 OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 39. OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 40. ESTIMATING  Project complexity – cohesiveness, inter and intra-modular interactions  Project size – increase in size increases interactions among modules  Degree of structural uncertainty – change in structure of software changes interactions  Risk– quantified uncertainty in estimations of resources, cost and schedule. OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 41. PROJECTPLANNING-OBJECTIVE  To provide a framework that enables software manager to make a reasonable estimate of resources, cost, and schedule.  Project outcomes should be bounded by 'best case' and 'worst case' scenarios.  Estimates should be updated as the project progresses. OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 42. SOFTWARESCOPE  Describes – the data to be processed and produced, – control parameters, – function, – performance, – constraints, – external interfaces, and – reliability.  Often functions described in the software scope statement are refined to allow for better estimates of cost and schedule. OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 43.  SOFTWAREPROJECTESTIMATIONOPTIONS  Delay estimation until late in the project.  Base estimates on similar projects already completed.  Use simple decomposition techniques to estimate project cost and effort.  Use empirical models for software cost and effort estimation.  Automated tools may assist with project decomposition and estimation. OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 44. DECOMPOSITIONTECHNIQUES  Software sizing (fuzzy logic, function point, standard component, change)  Problem-based estimation (using LOC decomposition focuses on software functions, using FP decomposition focuses on information domain characteristics)  Process-based estimation (decomposition based on tasks required to complete the software process framework) OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 45.  EMPIRICALESTIMATIONMODELS  Typically derived from regression analysis of historical software project data with estimated person-months as the dependent variable and KLOC or FP as independent variables.  Constructive Cost Model (COCOMO) is an example of a static estimation model.  The Software Equation is an example of a dynamic estimation model. OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 46.  MAKE-BUYDECISION  It may be more cost effective to acquire a piece of software rather than develop it.  Decision tree analysis provides a systematic way to sort through the make-buy decision.  As a rule outsourcing software development requires more skillful management than does in-house development of the same product.  Decision-trees  Using outsourcing, offshoring, insourcing etc. OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 47. PLANNINGTOOLS  PERT (Performance Evaluation and Review Technique) OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 48. PLANNINGTOOLS  Gantt chart OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 49. RISKANALYSISANDMANAGEMENT UNIT 02: PROJECT MANAGEMENT Reference: Pressman, R., Software Engineering – A Practitioner’s Approach, 5th Ed., Chapter 6 OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 50. ‘If you don’t actively attack the risks, they will actively attack you.’ ~ Tom Gilb OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 51. RISKMANAGEMENT  Risk management is concerned with identifying risks and drawing up plans to minimise their effect on a project.  A risk is a loss of value due to some adverse circumstance that might occur (loss due to uncertainty). – Project risks affect schedule or resources – Product risks affect the quality or performance of the software being developed – Business risks affect the organisation developing or procuring the software OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 52. SOFTWARERISKS  Project risks – project schedule and resources  Product risks – quality or performance of the software product  Business risks – organization OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 53. RISKMANAGEMENTPROCESS OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 54. RISKMANAGEMENTPROCESS  Risk identification – Identify project, product and business risks  Risk analysis – Assess the likelihood and consequences of these risks  Risk planning – Draw up plans to avoid or minimise the effects of the risk  Risk monitoring – Monitor the risks throughout the project OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 55. RISKANALYSIS  Assess probability and seriousness of each risk  Probability may be very low, low, moderate, high or very high  Risk effects might be catastrophic, serious, tolerable or insignificant Risk Probability Effects Organisational financial problems force reductions in the project budget. Low Catastrophic It is impossible to recruit staff with the skills required for the project. High Catastrophic Key staff are ill at critical times in the project. Moderate Serious Software components which should be reused contain defects which limit their functionality. Moderate Serious Changes to requirements which require major design rework are proposed. Moderate Serious The organisation is restructured so that different management are responsible for the project. High Serious The database used in the system cannot process as many transactions per second as expected. Moderate Serious The time required to develop the software is underestimated. High Serious CASE tools cannot be integrated. High Tolerable Customers fail to understand the impact of requirements changes. Moderate Tolerable Required training for staff is not available. Moderate Tolerable The rate of defect repair is underestimated. Moderate Tolerable The size of the software is underestimated. High Tolerable The code generated by CASE tools is inefficient. Moderate Insignificant OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 56. RISKITEMCHECKLIST  Product size — risks associated with the overall size of the software to be built or modified.  Business impact — risks associated with constraints imposed by management or the marketplace.  Customer characteristics —risks associated with the sophistication of the customer and the developer's ability to communicate with the customer in a timely manner.  Process definition — risks associated with the degree to which the software process has been defined and is followed.  Development environment — risks associated with the availability and quality of the tool.  Technology to be built — risks associated with the complexity of the system to be built  Staff size and experience OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 57. ASSESSINGOVERALLPROJECTRISK  Have top software and customer managers formally committed to support the project?  Are end-users enthusiastically committed to the projectand the system/product to be built?  Are requirements fully understood by the software engineering team and their customers?  Have customers been involved fully in the definition of requirements?  Do end-users have realistic expectations?  Is projectscope stable?  Does the software engineering team have the right mix of skills?  Are project requirements stable?  Does the project team have experience with the technology to be implemented?  Is the number of people on the project team adequate to do the job?  Do all customer/user constituencies agree on the importance of the project and on the requirements for the system/product to be built? OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 58. RISKCOMPONENTSANDDRIVERS OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 59. RISKIDENTIFICATION OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 60. RISKMATRIXANDRISKTABLE OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 61. RISKIMPACT  Risk exposure (RE) = risk probability * risk impact  A triplet can represent risk [ri,li,xi]  Risk refinement - Given that <condition> then there is concern that (possibly) <consequence>.  e.g. Certain reusable components were developed by a third party with no knowledge of internal design standards. OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 62. RISKPLANNING  Consider each risk and develop a strategy to manage that risk  Reactive vs. proactive approach  Avoidance strategies – The probability that the risk will arise is reduced  Minimisation strategies – The impact of the risk on the project or product will be reduced  Contingency plans – If risk arises, contingency plans are to deal with that risk  Risk appetite, risk mitigation, risk transfer OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 63. RISKMANAGEMENTSTRATEGIES Risk Strategy Organisational financial problems Prepare a briefing document for senior management showing how the project is making a very important contribution to the goals of the business. Recruitment problems Alert customer of potential difficulties and the possibility of delays, investigate buying-in components. Staff illness Reorganise team so that there is more overlap of work and people therefore understand each other’s jobs. Defective components Replace potentially defective components with bought-in components of known reliability. Requirements changes Derive traceability information to assess requirements change impact, maximise information hiding in the design. Organisational restructuring Prepare a briefing document for senior management showing how the project is making a very important contribution to the goals of the business. Database performance Investigate the possibility of buying a higher-performance database. Underestimated development time Investigate buying in components, investigate use of a program generator. OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 64. RISKMITIGATIONEXAMPLE–EMPLOYEETURNOVER ANDPOSSIBLESTEPS  Meet with current staff to determine causes for turnover (e.g., poor working conditions, low pay, competitive job market).  Mitigate those causes that are under our control before the project starts.  Once the project commences, assume turnover will occur and develop techniques to ensure continuity when people leave.  Organize project teams so that information about each development activity is widely dispersed.  Define documentation standards and establish mechanisms to be sure that documents are developed in a timely manner.  Conduct peer reviews of all work (so that more than one person is "up to speed”).  Assign a backup staff member for every critical technologist. OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 65. RISKMONITORING  Assess each identified risks regularly to decide whether or not it is becoming less or more probable  Also assess whether the effects of the risk have changed  Each key risk should be discussed at management progress meetings OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 66. RISKFACTORS OOSE UNIT 02 - Project Management, Planning & Risk Analysis
  • 67. End of Unit 02 : Project Management, Planning and Risk Analysis OOSE UNIT 02 - Project Management, Planning & Risk Analysis