Software Project Management lecture 8

74
1 Software Project Management Session 8: Development Management

description

 

Transcript of Software Project Management lecture 8

Page 1: Software Project Management lecture 8

1

Software Project Management

Session 8: Development Management

Page 2: Software Project Management lecture 8

2

Today

• Project Roles & Team Structure• Project Control• Status Reporting• CMM• Requirements• MS-Project

Page 3: Software Project Management lecture 8

3

Session 7 Review

• Risk Management• Feature Set Control• Change Control

Page 4: Software Project Management lecture 8

4

Risk Management

• Risk Management– Types of risk: schedule, cost, requirements

• Risk Identification

• Risk Analysis– Risk Exposure (RE = Prob. * Size)

• Risk Prioritization

• Risk Control

• Risk Resolution– Avoidance, assumption, transfer, gain knowledge

• Top 10 Risk List

Page 5: Software Project Management lecture 8

5

Feature Set Control

• Minimal Specification• Requirements Scrubbing• Versioned Development• Effective Change Control• Feature Cuts

Page 6: Software Project Management lecture 8

6

Change Control

• Average project has 25% requirements change• Sources of change• Change control is a process• Overly detailed specs. or prolonged requirements

phase are not the answer• Change Control Board (CCB)

– Structure, process, triage

Page 7: Software Project Management lecture 8

7

Configuration Control

• Items: code, documents• Change & Version control• SCM• Configuration Management Plan• Maintenance

Page 8: Software Project Management lecture 8

8

Project Roles– Programmers (system engineers)

• Technical lead, architect, programmer, Sr. programmer

– Quality Assurance (QA) engineers (testers)• QA Manager, QA Lead, QA staff

– DBAs• DB Administrator, DB Programmer, DB Modeler

– CM engineers (build engineers)– Network engineers, System Administrators– Analysts (business analysts)– UI Designers– Information Architects– Documentation writers (editors, documentation specialist)– Project manager– Other

– Security specialist, consultants, trainer

Page 9: Software Project Management lecture 8

9

Project Roles

• You need to decide which of these are necessary for your class project

• Depends on what you’re building• How big is it?

• Is it UI intensive? Data intensive?

• Are you installing/managing hardware?

• Do you need to run an operations center?

• Is it in-house, contract, COTS, etc?

• Depends on your budget

Page 10: Software Project Management lecture 8

10

Staffing Profile

• Projects do not typically have a ‘static team size’

• Who and how many varies as needed

Copyright: Rational Software 2002

Page 11: Software Project Management lecture 8

11

Roll-on & Roll-off

• PM must have a plan as to how & when• Roll-on

– Hiring or ‘reserving’ resources

– Ramp-up time• Learning project or company

• Roll-off– Knowledge transfer

– Documentation

– Cleanup

Page 12: Software Project Management lecture 8

12

Staffing Management Plan

• Part of Software Development Plan• Includes

– What roles needed, how many, when, who– Resource assignments– Timing: Start/stop dates– Cost/salary targets (if hiring)

• Project Directory– Simply a list of those involved with contact info.

• Team size: often dictated by budget as often as any other factor

Page 13: Software Project Management lecture 8

13

Team Structure

• 1st: What’s the team’s objective?– Problem resolution

• Complex, poorly-defined problem• Focuses on 1-3 specific issues• Ex: fixing a showstopper defect• Sense of urgency

– Creativity• New product development

– Tactical execution• Carrying-out well-defined plan• Focused tasks and clear roles

Page 14: Software Project Management lecture 8

14

Team Models

• Two early philosophies– Decentralized/democratic– Centralized/autocratic

• Variation– Controlled Decentralized

Page 15: Software Project Management lecture 8

15

Team Models

• Business Team– Most common model– Technical lead + team (rest team at equal

status)– Hierarchical with one principal contact– Adaptable and general– Variation: Democratic Team

• All decisions made by whole team• See Weinberg’s “egoless programming” model

Page 16: Software Project Management lecture 8

16

Team Models• Chief-Programmer Team

• From IBM in 70’s – See Brooks and Mythical Man-Month

• a.k.a. ‘surgical team’• Puts a superstar at the top

– Others then specialize around him/her» Backup Programmer» Co-pilot or alter-ego» Administrator» Toolsmith» “Language lawyer”

• Issues» Difficult to achieve» Ego issues: superstar and/or team

• Can be appropriate for creative projects or tactical execution

Page 17: Software Project Management lecture 8

17

Team Models

• Skunkworks Team– Put a bunch of talented, creative developers

away from the mother ship• Off-site literally or figuratively

– Pro: Creates high ownership & buy-in– Con: Little visibility into team progress– Applicable: exploratory projects needing

creativity• Not on well-defined or narrow problem

Page 18: Software Project Management lecture 8

18

Team Models

• SWAT Team• Highly skilled team

• Skills tightly match goal

• Members often work together

• Ex: security swat team, Oracle performance team

Page 19: Software Project Management lecture 8

19

Team Models

• Large teams– Communication increases multiplicatively

• Square of the number of people

• 50 programmers = 1200 possible paths

• Communication must be formalized

– Always use a hierarchy– Reduce units to optimal team sizes

• Always less than 10

Page 20: Software Project Management lecture 8

20

Team Size

• What is the optimal team size?• 4-6 developers

– Tech lead + developers

• Small projects inspire stronger identification

• Increases cohesiveness

• QA, ops, and design on top of this

Page 21: Software Project Management lecture 8

21

Hiring

• “Hire for Trait, Train for Skill”

• Look for: “Smart, Gets Things Done”– For programmers, see joelonsoftare’s “Guerilla

Guide to Interviewing”

• Balance the team

Page 22: Software Project Management lecture 8

22

Responsibility Assignment Matrix

• A resource planning tool• Who does What • Can be for both planning and tracking• Identify authority, accountability,

responsibility• Who: can be individual, team or department• Can have totals/summary at end of row or

column (ex: total Contributors on a task)

Page 23: Software Project Management lecture 8

23

Simple RAM

Page 24: Software Project Management lecture 8

24

Sample RAM With Stakeholders

Page 25: Software Project Management lecture 8

25

Skills Matrix

• Another resource planning tool• Resources on one axis, skills on other• Skills can high level or very specific• Cells can be X’s or numeric (ex: level, # yrs.)

Page 26: Software Project Management lecture 8

26

Capability Maturity Model: CMM

• A software process framework• “Process determines capability”• 5 ‘maturity’ levels

• ‘Evolutionary plateaus’ to a mature software process

• Each level has its own goals• Organizations can be ‘certified’

– Later to be used as a marketing or validation tool

• Links: SEI, Diagram, Levels, Drexel

Page 27: Software Project Management lecture 8

27

CMM Levels

• 1. Initial– ‘Ad hoc’ process, chaotic even– Few defined processes– Heroics often required here

• 2. Repeatable– Basic PM processes

• For cost, schedule, functionality

– Earlier successes can be repeated

• 3. Defined– Software & Mgmt. process documented– All projects use a version of org. standard

Page 28: Software Project Management lecture 8

28

CMM Levels

• 4. Managed– Detailed metrics of process & quality– Quantitative control

• 5. Optimizing– Continuous process improvement– Using quantitative feedback

Page 29: Software Project Management lecture 8

29

CMM

• Key Process Areas (KPA)• Identify related activities that achieve set of goals

• India has more CMM level 4 & 5 companies than any other country– Why is that?

• Distribution of organizations over CMM levels

Page 30: Software Project Management lecture 8

30

Tools

• Requirements Tools

• Design Tools

• Construction Tools

• Test Tools

• Maintenance Tools

• CM Tools

Page 31: Software Project Management lecture 8

31

Tools

• Tools could save 10-25% on some projects– But that’s optimistic at best

• Choose tools to meet your needs

• No can guarantee you anything– They *may* help– Tools don’t control people, especially

customers

Page 32: Software Project Management lecture 8

32

Programming Languages

• Your projects: do you choose a language?

• Typically not the PM’s choice, but does effect you– Staffing requirements– Methodology– Tools and infrastructure

Page 33: Software Project Management lecture 8

33

Requirements

• Requirements are capabilities and condition to which the system – more broadly, the project – must conform

Page 34: Software Project Management lecture 8

34

Requirements

• Perhaps most important & difficult phase

• Shortchanging it is a ‘classic mistake’

• Can begin with a Project Kickoff Meeting

• Can end with a Software Requirements Review (SRR)– For Sponsor and/or customer(s) approval

Page 35: Software Project Management lecture 8

35

Why are Requirements so Important?

Page 36: Software Project Management lecture 8

36

Requirements

• Characteristics & Issues– Conflict of interest: developer vs. customer– Potential tug-of-war:

• Disagreement on Features & Estimates

• Especially in fixed-price contracts

– Frequent requirements changes– Achieving sign-off

• Project planning occurs in parallel

Page 37: Software Project Management lecture 8

37

2 Types of Requirements

– Functional (behavioral)– Features and capabilities

– Non-functional (a.k.a. “technical”) (everything else)– Usability

» Human factors, help, documentation– Reliability

» Failure rates, recoverability, availability– Performance

» Response times, throughput, resource usage– Supportability

» Maintainability, internationalization– Operations: systems management, installation– Interface: integration with other systems– Other: legal, packaging, hardware

Page 38: Software Project Management lecture 8

38

Requirements

• Must be prioritized• Must-have

• Should-have

• Could-have (Nice-to-have: NTH)

• Must be approved

Page 39: Software Project Management lecture 8

39

Requirements

• Used by many people for many purposes

• Purposes– Management: Yes, that’s what I funded– Users: Yeah, that’s what I need– Developers: Yes, that’s I will build

Page 40: Software Project Management lecture 8

40

Requirements

• The “What” phase• Inputs: SOW, Proposal• Outputs:

– Requirements Document (RD)• a.k.a.Requirements Specification Document (RSD)• Software Requirements Specification (SRS)

– 1st Project Baseline– Software Project Management Plan (SPMP)– Requirements Approval & Sign-Off

• Your most difficult task in this phase

Page 41: Software Project Management lecture 8

41

Requirements

• “There’s no sense being exact about something if you don’t even know what you’re talking about” John von Neumann

• “When the map and the territory don’t agree, always believe the territory”, taught to all Swedish army recruits

Page 42: Software Project Management lecture 8

42

Requirements Gathering Techniques

• Interviews• Document Analysis• Brainstorming• Requirements Workshops• Prototyping• Use Cases• Storyboards• There are more…

Page 43: Software Project Management lecture 8

43

Interview Techniques

– Best practice: use ‘context free’ questions• A question that does not suggest a response

• High-level, early questions to obtain ‘global’ properties of the problem and solution

• Applicable to any project/product

• Get the ball rolling

Page 44: Software Project Management lecture 8

44

Context-free Questions

• Process, product and meta questions

• Process– “Who is the client for project X”?

– “What is a very successful solution really worth to the client”?

– “What is the reason for this project”?

• Product– “ What problems does this system solve”?

– “What problems could this system create”?

• Meta-questions– “Are these questions relevant”?

– “Is there anyone else who can give useful answers”?

– “Is there anything you want to ask me”?

Page 45: Software Project Management lecture 8

45

Document Analysis

• Review of existing documents• Business plans• Market studies• Contracts• Requests for proposals (RFP)• Statements of work (SOW)• Existing guidelines• Analyses of existing systems and procedures

Page 46: Software Project Management lecture 8

46

Brainstorming

• Idea generation & idea reduction• Typically via group meetings• Generation Best practices

• Minimize criticism and debate– Editing occurs at end of meeting or later

• Aim for quantity• Mutate or combine ideas

• Reduction best practices• Voting with a threshold (N votes/person)• Blending ideas• Applying criteria• Scoring with a weighting formula

Page 47: Software Project Management lecture 8

47

Requirements Workshops

• Typically 1-5 days

• Who? Varies. Users & stakeholders

• Pros– Good for consensus building

– Builds participant commitment

– Can cost less than numerous interviews

– Provide structure to capture and analysis process

– Can involve users across organizational boundaries

– Can help identify priorities and contentious issues

• JAD– A type of requirements workshop using a facilitator

Page 48: Software Project Management lecture 8

48

Prototyping

• Quick and rough implementation• Good communications mechanism• Can be combined with other techniques such as

JAD• Issues: creating the mis-appearance that

development is more complete than it actually is– See joelonsoftware’s “The Iceberg Secret Revealed”

Page 49: Software Project Management lecture 8

49

Use Cases

• Picture plus description• Often misunderstood: the text is more important • Diagrams• Text structure

• Use case name and number (ID)• Goal • Pre-conditions• Primary & secondary actors• Trigger• Description• Business rules• Open issues

• For good examples, see usecases.org

Page 50: Software Project Management lecture 8

50

Storyboards

• Set of drawings depicting user activities• Paper prototyping• Drawing screens or processes

Page 51: Software Project Management lecture 8

51

Requirements: Who?

• Customers and users (note: often not the same)• Customers can be users, but rarely opposite

• Sometimes user constituencies need to be ‘found’

• Subject matter experts• Other stakeholders

– Marketing, sales

– Product managers

Page 52: Software Project Management lecture 8

52

Other Requirements Tips

• Meetings– Treat them like a tool: design them

– Boy scout motto: “Be Prepared”

– As small as possible – but no smaller

– Make it safe not to attend• Publish an agenda before

• Publish a summary after

– Generate a ‘related issues’ list

– Can formal/informal, scheduled/ad-hoc

Page 53: Software Project Management lecture 8

53

Other Requirements Tips

• Manage expectations– Don’t forget to ask people theirs

– Listen

– Make explicit otherwise implicit decisions• PDA: Possibility, Deferred, Absolutely impossible

• Technical reviews– Requirements can be wrong by: inadequate or

inaccurate• Quantity & quality

– Reviews help with the latter

Page 54: Software Project Management lecture 8

54

Requirements Tools

• Starbase: CaliberRM

• Telelogic: DOORS

• Databases of requirements

• Displayable in various formats

• Optional requirements control metrics: – Requirements Stability Index

• To help manage feature creep and ‘vibration’

Page 55: Software Project Management lecture 8

55

The MS-Project Process

• Move WBS into a Project outline (in Task Sheet)• Add resources (team members or roles)• Add costs for resources• Assign resources to tasks• Establish dependencies• Refine and optimize• Create baseline• Track progress (enter actuals, etc.)

Page 56: Software Project Management lecture 8

56

Project Overview

• This is a ‘quickie’ overview

• We will return to all of these steps individually over the next few weeks

• Sample project from McConnell

Page 57: Software Project Management lecture 8

57

Project UI

• Views– Default is Gant Chart View

• 2 panes

• Task Sheet on left (a table)

• Gantt Chart on right

– View Bar on far left

Page 58: Software Project Management lecture 8

58

Project UI

Indicators

Task Sheet

View Bar

Enter TasksHere

Gantt Chart

Timescale

Task Bars

Milestone

Split Bar

OutlineButtons

(Un)Link Buttons Toolbars

Page 59: Software Project Management lecture 8

59

Create Your Project

• File/New• Setup start date• Setup calendar

– Menu: Project/Project Information

– Often left with default settings

– Hours, holidays

Page 60: Software Project Management lecture 8

60

Enter WBS

• Outlining• Sub-tasks and summary tasks• Do not enter start/end dates for each• Just start with Task Name and Duration for each• Use Indent/Outdent buttons to define summary

tasks and subtasks• You can enter specific Start/End dates but don’t

most of the time

Page 61: Software Project Management lecture 8

61

Establish Durations

• Know the abbreviations– h/d/w/m

– D is default

• Can use partial– .5d is a half-day task

• Elapsed durations• Estimated durations

– Put a ‘?’ after duration

Page 62: Software Project Management lecture 8

62

Add Resources

• Work Resources– People

• Material Resources– Things

– Can be used to track costs• Ex: amount of equipment purshased

– Not used as often in typical software project

Page 63: Software Project Management lecture 8

63

Resource Sheet

• Can add new resources here– Or directly in the task entry sheet

• Beware of mis-spellings (Project will create near-duplicates)

• Setup costs– Such as annual salary (put ‘yr’ after ‘Std. Rate’)

Page 64: Software Project Management lecture 8

64

Effort-Driven Scheduling

• MS-Project default• Duration * Units = Work

• Duration = Work / Units (D = W/U)• Work = Duration * Units (W = D*U)• Units = Work / Duration (U = W/D)

• Adding more resources to a task shortens duration• Can be changed on a per-task basis

• In the advanced tab of Task Information dialog box• Task Type setting

• Beware the Mythical Man-month• Good for laying bricks, not always so for software development

Page 65: Software Project Management lecture 8

65

Link Tasks

• On toolbar: Link & Unlink buttons– Good for many at once

• Or via Gantt chart– Drag from one task to another

Page 66: Software Project Management lecture 8

66

Milestones

• Zero duration tasks• Insert task ‘normally’ but put 0 in duration

Page 67: Software Project Management lecture 8

67

Make Assignments

• Approach 1. Using Task Sheet– Using Resource Names column

– You can create new ones by just typing-in here

• 2. Using Assign Resources dialog box– Good for multiple resources

– Highlight task, Tools/Resources or toolbar button

• 3. Using Task Information dialog– Resources tab

• 4. Task Entry view– View/More Views/Task Entry

– Or Task Entry view on Resource Mgmt. toolbar

Page 68: Software Project Management lecture 8

68

Save Baseline

• Saves all current information about your project– Dates, resource assignments, durations, costs

Page 69: Software Project Management lecture 8

69

Fine Tune

• Then is used later as basis for comparing against “actuals”

• Menu: Tools/Tracking/Save Baseline

Page 70: Software Project Management lecture 8

70

Project 2002

• 3 Editions: Standard, Professional, Server• MS Project Server 2002

• Upgrade of old “Project Central”

• Includes “Project Web Access”, web-based UI (partial)

• Workgroup and resource notification features

• Requires SQL-Server and IIS

• “Portfolio Analyzer”– Drill-down into projects via pivot tables & charts

• “Portfolio Modeler”– Create models and “what-if” scenarios

• SharePoint Team Services integration

Page 71: Software Project Management lecture 8

71

Project 2002

• MS-Project Professional– “Build Team” feature

• Skills-based resource matching

– Resource Pools: with skill set tracking

– Resource Substitution Wizard

• “Project Guide” feature– Customizable “process component”

Page 72: Software Project Management lecture 8

72

MS-Project Q&A

• Your WBS in Project

• How did it go?

• Any questions?

Page 73: Software Project Management lecture 8

73

Homework

• Reading:

• McConnell: Chapters 17-19 (very short ones)

• Schwalbe: 6 “Project Cost Management” (175-184), 9 “Project Communication Management”, 15 “Controlling”

• URL on class site about Earned Value

Page 74: Software Project Management lecture 8

74

Questions?