Projects and Project Planning

Similar documents
Lecture 15 - recap. Kari Systä, TIE-21100/6; Kari Systä 1

TIE Ohjelmistotuotannon menetelmät TIE Software Engineering Methodology

PRINCE Update. Changes to the manual. AXELOS.com. April 2017 PUBLIC

Agile Software Development

Processes and Life- Cycles. Kristian Sandahl

Welcome to this IBM Rational podcast, The. Scaled Agile Framework in Agile Foundation for DevOps. I'm

IBM s SAFe Solution Overview

Chapter 01 - The Process The Process Application Process ACP Qualifications Scheduling Your Exam Rescheduling/Cancelling Fees

Agile Essentials Track: Business Services

SCRUM - LESSONS FROM THE TRENCHES

Software Engineering Fall 2014

Exam 2012, Lecture Project Management

Scrum. Software Engineering and. The Waterfall model. The Waterfall model - some arguments. The Waterfall model - some arguments. Time.

Agilitate.com. From Mountain To Molehill. Saving Millions With Agile Programme Management. Bill Nicholas - 8 th September 2011

The Software Development Process (SDLC)

Software Engineering in the Agile World. Table of contents

This course will explore how your projects can easily and successfully make the transition to an effective Agile environment.

Project Management. Agenda - What will you learn today? Theory Lecture Plan. A Software Life-cycle Model Which part will we talk about today?

Agile Scrum Process Checklist

Tuesday, October 25. Announcements

Web Application Development Process

Standard Work and the Lean Enterprise Net Objectives Inc. All Rights Reserved.

Software Processes. Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 4 Slide 1

An Agile Projects Introduction Course #PMCurrent-1

Johanna Rothman. Chapter 1 Why Agile and Lean Approaches Work. Copyright 2017

Software Engineering II - Exercise

Scrum - Introduction. Petri Heiramo. Agile Coach, CST

In-House Agile Training Offerings

A brief introduction to Agile Product Development with Lean and Scrum

BA25-Managing the Agile Product Development Life Cycle

CS314 Software Engineering Project Management

Rekayasa Perangkat Lunak 2 (IN043): Pertemuan 10. * Construction, Installation and Operations * Agile Method Software Development

Copyright Software Engineering Competence Center

Software Engineering

Software Processes. Objectives. Topics covered. The software process. Waterfall model. Generic software process models

Handling Product Management Across The Enterprise. copyright Net Objectives, Inc.

Introduction to Agile and Scrum

The Product Creation Process

PMI Agile Certified Practitioner (PMI-ACP) Duration: 48 Hours

Scrum Alliance Certified Team Coach SM (CTC) Application SAMPLE

RIGHTNOW A C E

IBM WIoT CP Summit Open Labs (NO COST - not a substitute for full training courses)

Other Agile Approaches & Methodologies

Jochen(Joe)Krebs

Maureen Weverka & Kathy Burnham Mutual of Omaha. November 9, Mutual of Omaha Insurance Company. All Rights Reserved.

Comparing Scrum And CMMI

IBM Collaborative Lifecycle Management & SAFe

1. The Case for Agile 2. The Scrum Process 3. Scaling Scrum

Agile and CMMI : Disciplined Agile with Process Optimization

Scrum Team Roles and Functions

ignoring agile, size and frequency, sales, , 280

AGILE FOR NON-IT PRACTITIONERS

Softwaretechnik. Lecture 02: Processes. Peter Thiemann SS University of Freiburg, Germany

Two Branches of Software Engineering

Q&A from Transitioning from Waterfall to Agile Web Seminar

SOFTWARE DEVELOPMENT LIFE CYCLE (SDLC)

An Introduction to Scrum

Software Development*

Mike Vincent. mvasoftware.net

Management of Projects

Collaboration at Scale: Managing Dependencies Across Large Teams Aug-10

Application of Agile Delivery Methodologies. Bryan Copeland Energy Corridor Brown Bag Event August 31, 2016

AGILE FOR NON-IT PRACTITIONERS

Copyright Intertech, Inc All Rights Reserved. May 18, 2011

Agile Software Development. Agile Software Development Basics. Principles of the Agile Alliance. Agile Manifesto. Agenda. Agile software development

Agile Project Management Certificate Program

AGILE methodology- Scrum

Boston University Metropolitan College. MET CS634 Agile Software Development

Adopting to Agile Software Development

A one day Introduction. Tim Guay, PMP, CSM, PMI-ACP, CLSSS

Managing Projects of Chaotic and Unpredictable Behavior

Certified Team Coach (SA-CTC) Application - SAMPLE

Metodologías Agiles en E///

Agile Software Development

Introduction to Agile Life Cycles. CSCI 5828: Foundations of Software Engineering Lecture 07 09/13/2016

Trends & Benchmarks Report Switzerland Where do we stand where are we going to? Agile In cooperation with

Scrum and Agile Processes. Dr.-Ing. Oliver Ciupke Haufe-Lexware GmbH & Co. KG 2011

Agile Project Management

agilesem an agile System Development Method at Siemens in CEE Eva Kišoňová, Ralph Miarka SW Quality Days Vienna January 2012

Cloudy skies. How to bring clarity to your cloud platform in order to optimize your investment. September 2016

V Model material adapted from Steve Easterbrook. Waterfall Model material adapted from Steve Easterbrook. Lifecycle of Software Projects

Session 11E Adopting Agile Ground Software Development. Supannika Mobasser The Aerospace Corporation

Information Technology Project Management, Eighth Edition. Note: See the text itself for full citations.

Software Engineering Lecture 5 Agile Software Development

COURSE BROCHURE. CERTIFIED DEVOPS MASTER Training & Certification

Agile Planning with HP Project Portfolio Management and Agile Manager February 3, 2015

Software Project Management Plan

Build Your Project Using Feature Driven Development #4 of a Series, by Pavan Kumar Gorakavi, M.S., M.B.A, G.M.C.P, C.A.P.M.

Integrated Personnel and Pay System- Army (IPPS-A) 25 October Colonel Darby McNulty, Program Manager

Agile, Estimation and Projects

Software Project Management

Legacy System Modernization Using Open Source Tools and Agile. Adam D Angelo

Introduction to Agile (Scrum)

Software Processes. With a focus on Agile/Scrum CPSC310 Software Engineering

A Guide to Critical Success Factors in Agile Delivery

An Oracle White Paper February Oracle Unified Method (OUM) Oracle s Full Lifecycle Method for Deploying Oracle-Based Business Solutions

Avoiding ScrumButt - Nokia Test Origins Nokia Siemens Networks

THE ADVANTAGES OF AGILE METHODOLOGIES APPLIED IN THE ICT DEVELOPMENT PROJECTS

Major attributes of the Lifecycle. The Systems Development Lifecycle. Project phases. Planning. Design. Analysis

An Introduction to Scrum. Mountain Goat Software, LLC

Transcription:

Projects and Project Planning Lecture 3 Kari Systä 27.1.2014 TIE-21100/21106/K.Systä 1

How to contact us Lectures, grading, exams etc. kari.systa@tut.fi Exercises, project etc tero.ahtee@tut.fi 27.1.2014 TIE-21100/21106/K.Systä 2

About project / assignment Will be done in groups of ~4 (min 3, max 5) If you are not registered in IDLE (contact tero.ahtee@tut.fi) IDLE for registering deadline passed, but you still can Staff will start merging 28.1 If you do not have complete group, you should still register. The staff will combine. Project will run in 4 Sprints Instructions (still under preparation) http://www.cs.tut.fi/kurssit/tie-21106/assignment/index.html 27.1.2014 TIE-21100/21106/K.Systä 3

Recap of previous lectures 27.1.2014 TIE-21100/21106/K.Systä 4

A few definitions Software engineering may be defined as the systematic design and development of software products and the management of the software process Mills, H.D., IBM Systems Journal Vol19, Issue: 4, 1980 Software Engineering is the study and application of engineering to the design, development, and maintenance of software. http://en.wikipedia.org/wiki/software_engineering 27.1.2014 TIE-21100/21106/K.Systä 5

Need/idea Prestudy From needs to software Develop Order project Buy Forget Requirements Select supplier Tailor Design Implement. Test Deployment Maintenance Closure 27.1.2014 TIE-21100/21106/K.Systä 6

What is software engineering Requirements Customer Skillful programing Lifecycle models Collaborative game Algoriths Data structures Progr. languages Architectures Quality assurance Project mgmt Developer Testing Validation 27.1.2014 TIE-21100/21106/K.Systä 7

Extended view Users Requirements Money Skillful programming Collaborative game Operation Quality assurance Developers 27.1.2014 TIE-21100/21106/K.Systä 8

Royce, 1970 (http://www.cs.umd.edu/class/spring2003/cmsc838p/process/waterfall.pdf) 27.1.2014 TIE-21100/21106/K.Systä 9

Precursor of interative models: Spiral Model (picture from: http://www.sei.cmu.edu/reports/00sr008.pdf) 27.1.2014 TIE-21100/21106/K.Systä 10

Iterative model: RUP (Rational Unified Process) 27.1.2014 TIE-21100/21106/K.Systä 11

Scrum Framework for agile and iterative developmet Jeff Sutherland, John Scumniotales, and Jeff McKenna OOPSLA 95 TIE-21100/21106/K.Systä 27.1.2014 12

The following slides were postponed to next lecture 27.1.2014 TIE-21100/21106/K.Systä 13

Burndown -Chart Definition of done === 100% done Velocity -> The velocity is calculated by counting the number of units of work completed in a certain interval (sprint in case of Scrum) When task is done value in chart is reduced If the task grows value is increased TIE-21100/21106/K.Systä 27.1.2014 14

Timeboxing http://guide.agilealliance.org/guide/timebox.html: A timebox is a previously agreed period of time during which a person or a team works steadily towards completion of some goal. Rather than allow work to continue until the goal is reached, and evaluating the time taken, the timebox approach consists of stopping work when the time limit is reached and evaluating what was accomplished TB1 TB2 TB3 Ways to manage risks Fast response Makes requirement management more rigid TIE-21100/21106/K.Systä 27.1.2014 15

Iron triangle Scope/features Resources Quality Time/ Schedule 27.1.2014 TIE-21100/21106/K.Systä 16

Different project customer specific Vendor Vendor research Implement. validation Specificat. bid bid delployment deployment Order spec Tender call order Customer 17 27.1.2014 TIE-21100/21106/K.Systä

Learning goals of today What is project especially in the scope of software How projects should be planned, tracked, managed and ended. What is difference between projects and processmodels. Management aspects of process models Agile does not mean that project planning or management is not needed. 27.1.2014 TIE-21100/21106/K.Systä 18

Initial content of lectures Introduction Life-cycle models, their background Project management, product management, project planning in general management aspects Scrum in details Kanban, Customer Development and DevOps details Requirement definition, requirement management, requirements prioritization Version management, configuration management, continuous integration Architecture issues, role of architect, architectural quality attributes, product families,. (TIE-21300 will go deeper) Testing and quality assurance (TIE-21200 will go deeper) Quality systems and process improvement Embedded and real-time systems (other courses will go deeper) Safety-critical and dependable systems Effort estimation Software business, software start-ups Recap 27.1.2014 TIE-21100/21106/K.Systä 19

Project Wikipedia (borrows): In project management a project consists of a temporary endeavor undertaken to create a unique product, service or result. Oxford dictionary an individual or collaborative enterprise that is carefully planned and designed to achieve a particular aim. 27.1.2014 TIE-21100/21106/K.Systä 20

Key elements for this lecture Wikipedia (borrows): In project management a project consists of a temporary endeavor undertaken to create a unique product, service or result. Oxford dictionary an individual or collaborative enterprise that is carefully planned and designed to achieve a particular aim. 27.1.2014 TIE-21100/21106/K.Systä 21

A project Has Start End Goals Should have Plan Success criteria Management 27.1.2014 TIE-21100/21106/K.Systä 22

Project management aims at Deliver SW to customer at the agreed time Keep overall costs within the budget Deliver software taht meets customer s expectations Maintain spirit and performance of the team 27.1.2014 TIE-21100/21106/K.Systä 23

Special about software projects The product is intagible Unlike buildings it is hard to tell condition and phase of development Large software project are often one-off projects Hard to repeat experience Processes are variable and organization specific 27.1.2014 TIE-21100/21106/K.Systä 24

Project organization (traditional) Other stakeholders Customer Vendor Steering group Project group Project manager of custormer PM of vendor Users Support group - Tech experts - Legal experts 27.1.2014 TIE-21100/21106/K.Systä 25

Steering Project Project preparation Projectproposal QUESTION 1: Where do this conflict with agile methods? Steering group Approval of project plan Follow-up and steering Acceptance of the results Ending of the project project decision Project description Project plan Progress reports Steering Changeproposals Updated project plan Results End-report Project planning Execution of the project ANSWER: Do not need to conflict much Agile method concerns execution Applied method is agreed in the plan However note that customer (or somebody representing customer) is more involved in agile projects 27.1.2014 TIE-21100/21106/K.Systä 26

Project planning Organization Target setting Risk analysis Selection of technologies, methods, practices, tools For instance if agile is selected Support (dokumentation, quality assurance, product management) Splitting and phasing (WBS = Work Breakdown Structure) Worktime estimation Resource availability and time table Developers, external experts Special tools Budget, financing, funding Success criteria 27.1.2014 TIE-21100/21106/K.Systä 27

Project plan template Walkthrough of the template for our project course: http://www.cs.tut.fi/~projekti/tie-proj_project_plan_2013.odt 27.1.2014 TIE-21100/21106/K.Systä 28

Gantt charts (lähde: http://www.matchware.com) 27.1.2014 TIE-21100/21106/K.Systä 29

Another alternative (Lähde: http://orgmode.org) 27.1.2014 TIE-21100/21106/K.Systä 30

Risk management 31 Sommerville Identification Analysis Planning/ Monitoring Potential risks Prioritized risk list Avoidance Contigency Mitigation 27.1.2014 TIE-21100/21106/K.Systä

Risk types 32 Product Technology risks Used SW, HW,. Requirement risks Estimation risks Tool risks Project People risks Key personel leave the company Sudden illness Organizational risks Business 27.1.2014 TIE-21100/21106/K.Systä

A very common approach for analysis and planning 33 Probability of the risk Severity of the risk Priority Plan Ways to avoid the risk Ways reduce probability of the risk What do if the risk is realized (action) How we minimize the consequences in advance 27.1.2014 TIE-21100/21106/K.Systä

Simple table 34 RISK Probab. Severity Prevent Reduce Key person leaves 50% 8 Keep people happy. Give a raise. Nuclear war <0.001% 10 Attend peace campaign Ensure that all critical data and skill is possessed by more than one. Move the office to a bunger Often better to use - low - medium - high 27.1.2014 TIE-21100/21106/K.Systä

Reasons for one big project to fail 35 The size and features of the result were impossible to estimate during planning The result was much bigger than originally planned There was a constant flow of changes: features were added and removed Coordination between sub-projects was mostly nonexisting Terrible hurry during the last phases of the project 27.1.2014 TIE-21100/21106/K.Systä

More reasons 36 Close to end project manager got sick and replaced by unexperienced person Many features and technologies were new and never tested in similar products. System testing showed that the system is not stable, but because project was late it was deployed anyways. 27.1.2014 TIE-21100/21106/K.Systä

37 27.1.2014 TIE-21100/21106/K.Systä

more 38 Afterwards it was discovered that the design could not work. The ship would have been stable only with so much of weight that some guns had been under water surface. Reference; Curt Borgenstam: Why the Wasa Capsized. 27.1.2014 TIE-21100/21106/K.Systä

Stakeholder analysis (not in the books) 39 To figure out the environment of the project and product for planning, risk management, requirements management, training and deployment Especially important if the project somehow changes the ways of working in the customer organization Should include information about all who have a stake : For example, users, interfacing departments, authorities Description Name Role and influence Also: goal, expectations, responsibilities, Importance It may be difficult to connect all stakeholders or their representatives Goals of stakeholders might ne conflicting or even against the project 27.1.2014 TIE-21100/21106/K.Systä

Why project plan is important It is a tool for steering and tracking Communication tool among the stakeholders Goals Tasks and timetable Organization and responsibilities Tools, working practices Budgets Risks 27.1.2014 TIE-21100/21106/K.Systä 40

http://nadihassan.wordpress.com 27.1.2014 TIE-21100/21106/K.Systä 41

A few words about project management and agile 27.1.2014 TIE-21100/21106/K.Systä 42

Five principles of Agile Customer involvement Incremental delivery People not process Embrace change Maintain simplicity Through the project. Provide and prioritize requirements, evaluate iterations Customer specifies the increments Skill recognized and exploited; Team should decide on ways of working Plan and design for change Both in process and software 27.1.2014 TIE-21100/21106/K.Systä 43

But Some things are not covered by agile methods Stakeholders Budget Risks High-level goals Risks Some things need to be agreed on Timing of sprints Who participate in sprint review Who takes the roles (in Scrum: Scrum master and product owner) 27.1.2014 TIE-21100/21106/K.Systä 44

Agile improves visibility to managment Important argument for selling the idea of Agile Each sprint provides on opportunity see the progress Steering group or management may ask a status report (but status reporting and sprint rhythm should be synchronized) Example: burn-down charts 27.1.2014 TIE-21100/21106/K.Systä 45

Steering Project Customer Project preparation Projectproposal project decision Project description Project planning Steering group Approval of project plan Follow-up and steering Acceptance of the results Project plan Progress reports Steering Changeproposals Updated project plan Results Execution of the project Execution of the project Ending of the project End-report 27.1.2014 TIE-21100/21106/K.Systä 46

Learning goals of today What is project especially in the scope of software How projects should be planned, tracked, managed and ended. What is difference between projects and processmodels. Management aspects of process models Agile does not mean that project planning or management is not needed. 27.1.2014 TIE-21100/21106/K.Systä 47