Contents Introduction Requirements Engineering Project Management

Slides:



Advertisements
Similar presentations
Estimation using COCOMO More Science, Less Art. COCOMO History COCOMO History Constructive Cost Model Dr. Barry Boehm TRW in 1970s COCOMO
Advertisements

Chapter 26 Estimation for Software Projects
Contents Introduction Requirements Engineering Project Management
Software Effort Estimation based on Use Case Points Chandrika Seenappa 30 th March 2015 Professor: Hossein Saiedian.
Software project management Module 1 -Introduction to process management Teaching unit 1 – Introduction Ernesto Damiani Free University of Bozen-Bolzano.
R R R CSE870: Advanced Software Engineering (Cheng): Intro to Software Engineering1 Advanced Software Engineering Dr. Cheng Overview of Software Engineering.
Contents Introduction Requirements Engineering Project Management
PVK-HT03
Software Project Planning CS 414 – Software Engineering I Donald J. Bagert Rose-Hulman Institute of Technology December 12, 2002.
SOFTWARE PROJECT MANAGEMENT AND COST ESTIMATION © University of LiverpoolCOMP 319slide 1.
These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by.
April 13, 2004CS WPI1 CS 562 Advanced SW Engineering General Dynamics, Needham Tuesdays, 3 – 7 pm Instructor: Diane Kramer.
1 SOFTWARE PRODUCTION. 2 DEVELOPMENT Product Creation Means: Methods & Heuristics Measure of Success: Quality f(Fitness of Use) MANAGEMENT Efficient &
Project Tracking and Scheduling Infsy 570 Dr. R. Ocker.
Planning. SDLC Planning Analysis Design Implementation.
© 2006 ITT Educational Services Inc. System Analysis for Software Engineers: Unit 5 Slide 1 Chapter 3 Managing the Information Systems Project.
© 2005 by Prentice Hall 3-1 Chapter 3 Managing the Information Systems Project Modern Systems Analysis and Design Fourth Edition.
INFORMATION SYSTEM APPLICATIONS System Development Life Cycle.
Software Project Management Introduction to Project Management.
1 ECE 453 – CS 447 – SE 465 Software Testing & Quality Assurance Lecture 22 Instructor Paulo Alencar.
By K Gopal Reddy.  Metrics in software are of two types.direct and indirect.  Function points as indirect metrics.  Function points are used to measure.
CS /39 Illinois Institute of Technology CS487 Software Engineering David A. Lash.
Group Members: Ayush Newatia, Barry Foye, Billy Felton, Kevin Anderson, Shahnaz Begum and Adam Jasinski Constructive Cost Model is a technique used to.
These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by.
1 Lecture 17: Chapter 26 Estimation for Software Projects Slide Set to accompany Software Engineering: A Practitioner’s Approach, 7/e by Roger S. Pressman.
Project management Lecture 10. Topics covered Management activities Project planning Project scheduling Risk management.
Chapter 3 Project Management Details Tracking Project Progress Project Estimation Project Risk Analysis Project Organization RUP Project Management Workflow.
1 Chapter 23 Estimation for Software Projects. 2 Software Project Planning The overall goal of project planning is to establish a pragmatic strategy for.
Introduction to Software Engineering ECSE-321 Unit 4 – Project Management 10/19/2015Introduction to Software Engineering – ECSE321Unit 4 – Project Management/1.
Chapter 11. Intro  What is Project Management?  Project Manager  Project Failures & Successes Managing Projects  PMBOK  SDLC Core Process 1 – Project.
T. E. Potok - University of Tennessee CS 594 Software Engineering Lecture 3 Dr. Thomas E. Potok
10/27/20151Ian Sommerville.  Fundamentals of software measurement, costing and pricing  Software productivity assessment  The principles of the COCOMO.
1 Chapter 5 Software Project Planning. 2 Software Project Planning The overall goal of project planning is to establish a pragmatic strategy for controlling,
Cost Estimation What is estimated? –resources (humans, components, tools) –cost (person-months) –schedule (months) Why? –Personnel allocation –Contract.
University of Southern California Center for Systems and Software Engineering Barry Boehm, USC CS 510 Software Planning Guidelines.
Estimating Software Projects & Activity Scheduling in the Dynamic, Multi-Project Setting: Choosing Heuristics Through Deterministic Simulation.
Introduction to Software Project Estimation I (Condensed) Barry Schrag Software Engineering Consultant MCSD, MCAD, MCDBA Bellevue.
Software Project Estimation IMRAN ASHRAF
Estimation for Software Projects 1. Software Project Planning 2 The overall goal of project planning is to establish a pragmatic strategy for controlling,
Estimation using COCOMO
Empirical Estimation Models Based upon historic data Basic Structure E = A + B * (ev) C where A, B, c are empirical constants ‘ev’ is the effort in terms.
Function Points Synthetic measure of program size used to estimate size early in the project Easier (than lines of code) to calculate from requirements.
These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by.
Copyright 2002 Prentice-Hall, Inc. Chapter 3 Managing the Information Systems Project 3.1 Modern Systems Analysis and Design.
Estimating “Size” of Software There are many ways to estimate the volume or size of software. ( understanding requirements is key to this activity ) –We.
Project, People, Processes and Products Project management skills – schedule, monitoring, risk management, … People management skills – delegation, mentoring,
Software Engineering (CSI 321) Project Planning & Estimation 1.
Project Management Why do projects fail? Technical Reasons
PROJECT PLANNING & MANAGEMENT Brittany Hamilton. PROGRESS TRACKING Do we understand customer’s needs? Can we design a system to solve customer’s problems.
PLANNING AND MANAGING THE PROJECT CODY STANISH. 3.1 TRACKING PROGRESS Do you understand the customer’s needs? Can you design a system to solve customer’s.
1 Project Management Software management is distinct and often more difficult from other engineering managements mainly because: – Software product is.
Advanced Software Engineering Dr. Cheng
THE FAMU-CIS ALUMNI SYSTEM
Chapter 33 Estimation for Software Projects
Project Cost Management
Project Management Techniques
Software Planning Guidelines
Software Project Management
Software Engineering (CSI 321)
Software Engineering: A Practitioner’s Approach, 6/e Chapter 23 Estimation for Software Projects copyright © 1996, 2001, 2005 R.S. Pressman & Associates,
COCOMO Model Basic.
COCOMO Models.
CIS 210 Systems Analysis and Development
COCOMO 2 COCOMO 81 was developed with the assumption that a waterfall process would be used and that all software would be developed from scratch. Since.
Project Management Chapter 11.
Chapter 33 Estimation for Software Projects
Software Engineering: A Practitioner’s Approach, 6/e Chapter 23 Estimation for Software Projects copyright © 1996, 2001, 2005 R.S. Pressman & Associates,
DOD’S PHASED SYSTEM DEVELOPMENT PROCESS
PPT3: Project planning and management
Chapter 26 Estimation for Software Projects.
Presentation transcript:

Contents Introduction Requirements Engineering Project Management Software Design Detailed Design and Coding Quality Assurance Maintenance PVK-HT04 bella@cs.umu.se

Project Management Project Management Activities Project Scheduling Cost Estimation Analysis Design Testing Coding Operation and Maintenance Installation Require- ments Requirements Specification Planning PVK-HT04 bella@cs.umu.se

Project Management Activities Project acquisition Project planning Resource assessment Risk and option analysis Cost estimation Project scheduling Work breakdown structure Effort distribution Resource assignment Project tracking and control Reporting PVK-HT04 bella@cs.umu.se

Project Resources People Hardware and software tools Required skills Availability Duration of tasks Start date Hardware and software tools Description Duration of use Delivery date PVK-HT04 bella@cs.umu.se

Risks and Option Analysis What is a risk? Compare different development alternatives Evaluate their risks Select best alternative Tools Polar graph Decision tree Forms ... PVK-HT04 bella@cs.umu.se

Top Ten Project Risks Staff deficiencies Unrealistic schedules and budgets Developing the wrong functions Developing the wrong interface Over-engineering Changing requirements Externally developed items Externally performed tasks Performance problems Assumptions on technology PVK-HT04 bella@cs.umu.se

Define Work Breakdown Structure Activity Major work unit Start date End date Consumes resources Results in work products (and milestones) Project function Continue throughout the project Not bound to specific phases Step 1 Step 2 Activity 1 Activity 2 Activity 3 Phase 1 Step 1 Step 2 Activity 1 Activity 2 Task 1 Task 2 Task 3 Project Phase 2 Step 1 Step 2 Phase N PVK-HT04 bella@cs.umu.se

Schedule Activities Almost all activities depend on the completion of some other activities Many activities can be performed in parallel Organisation necessary to balance work-load, costs, and duration PERT chart (activity network/task graph) Critical path Project Time-line (Gantt chart) Resource table PVK-HT04 bella@cs.umu.se

PERT Charts Program Evaluation and Review Technique Graph Compute Nodes = activities/tasks and estimated duration Edges = dependencies Compute Slack time = available time - estimated duration Critical path A path is critical when it contains an activity that, if delayed, will cause a delay of the whole project. PVK-HT04 bella@cs.umu.se

Example PERT Chart PVK-HT04 bella@cs.umu.se

Gantt charts A Gantt chart is used to graphically present the start and end dates of each software engineering task One axis shows time. The other axis shows the activities that will be performed. The black bars are the top-level tasks. The white bars are subtasks The diamonds are milestones: Important deadline dates, at which specific events may occur PVK-HT04 bella@cs.umu.se

A Gantt Chart (Project Time Line) PVK-HT04 bella@cs.umu.se

Another Gantt Chart PVK-HT04 bella@cs.umu.se

Cost Estimation Approach Problems: Use empirical and historical data Decompose problem Check for experiences/ data on sub problems Make qualified estimations (Make at least two independent estimates) Problems: What are good measures? Do the estimates affect the result? Does the type of software affect the result? Does the project environment affect the result? ... Use empirical and historical data Algorithmic cost modelling COCOMO (based on LOC) FP (based on function points) PVK-HT04 bella@cs.umu.se

COCOMO Constructive Cost Modelling [Boehm 81] Based on publicly available historical data of 63 TRW projects Basic assumptions: Requirements change only slightly during the project There is good project management The historical data is representative Assigning more resources to the project does NOT result in linear decreasing development time PVK-HT04 bella@cs.umu.se

Basic Model Effort = a (KDSI)b Schedule = c (Effort)d Organic KDSI = Kilo Delivered Source Instructions ( LOC - comments) The a, b, c, and d factors vary depending on the type of project Effort is measured in PM (Person Months = 152h of work) Schedule is the Development Time measured in Months a b c d 2.4 3.0 3.6 1.05 1.12 1.20 2.5 0.38 0.35 0.32 Organic In-house IS, Development in a familiar environment Semi-detached Between OM- and EM projects Embedded Large and inexperienced teams, many constraints Boehm, Software Engineering Economics, Prentice-Hall, 1981.

COCOMO Summary Works quite well in practice Needs KLOC as input Problems: Estimating KLOC in early project stages Comparison of projects using different LOC counts Outdated metrics base (70s) Solutions: Cross-check using an other estimation technique Standardised LOC counts Continuous model calibration COCOMO II is a recent new version PVK-HT04 bella@cs.umu.se

COCOMO II Goal: To develop a software cost and schedule estimation model tuned to the life cycle practices of the 1990’s and 2000’s 3 Models Application Composition: prototyping to resolve high-risk user interface issues, 2 environment drivers, 0 process drivers, Sizing in Object Points Early Design Model: to explore alternative architectures and concepts,7 environment drivers, 5 process drivers, Sizing in Function Points or SLOC Post Architecture Model: development has begun, 17 environment drivers, 5 process drivers, Sizing in Function Points or SLOC PVK-HT04 bella@cs.umu.se

Effort and schedule in COCOMO 2 Application Composition Model Effort = NOP/productivity NOP = OP * [(100 -%reuse)/100] Productivity = NOP/man-months, 5 productivity levels depending on the 2 environment drivers (table 3.12 course book) Early Design and Post-architecture Model æ ö Environment [ ] ( ) Factors Scale Process Effort = ç ÷ Size ç ÷ Multipliers è ø Environment: product, platform, people, project factors Process: constraint, risk/architecture, team, maturity factors ( ) [ ] Effort ( ) Factors Scale Process Schedule = Multiplier PVK-HT04 bella@cs.umu.se

COCOMO II Model Stages Overestimated Underestimated 4x Overestimated 2x Early Design (13 parameters) 1.5x 1.25x Relative Size Range x 0.8x Post-Architecture 0.67x (23 parameters) 0.5x Underestimated Applications Composition (3 parameters) 0.25x Product Detail Concept of Rqts. Design Design Accepted Operation Spec. Spec. Spec. Software Feasibility Plans Product Detail Devel. and Design Design and Test Rqts. PVK-HT04 Phases and Milestones bella@cs.umu.se

COCOMO II summary COCOMO II allow for spiral model instead of waterfall model only Size of project can be listed as object points, function points or source lines of code (SLOC) The environmental multipliers are calculated from seventeen cost drivers better suited for today's methods Calibration is difficult, but can improve accuracy by a factor of five PVK-HT04 bella@cs.umu.se

Function Points Function Point Analysis (FPA) measures the size of a software product in terms of the functionality it delivers to the users. A.J. Albrecht 1979 What the software must do from the user’s perspective Irrespective of software construction Based on five function types: Inputs Outputs Inquiries Logic Files Interfaces PVK-HT04 bella@cs.umu.se

Project plan contents Documentation plan Project scope Data management plan Resource management plan Test plan Training plan Security plan Risk management plan Maintenance plan Project scope Project schedule Project team organization Technical description of system Project standards and procedures Quality assurance plan Configuration management plan PVK-HT04 bella@cs.umu.se

Difficulties and Risks in Project Management Accurately estimating costs is a constant challenge It is very difficult to measure progress and meet deadlines It is difficult to deal with lack of human resources or technology needed to successfully run a project Communicating effectively in a large project is hard It is hard to obtain agreement and commitment from others PVK-HT04 bella@cs.umu.se