Creating a Schedule Using Network Diagrams; Defining Task Durations Lecture Packet 8 © John Brackett
Verzuh’s Overview of Project Planning Step 1: Develop WBS Step 2: Sequence the tasks Step 3: Estimate the tasks to get a duration (work packages) Step 4: Calculate an initial schedule Step 5: Assign resources and iterate Step 6: Develop budget
Network Diagram for a Software Project Design Document Require- ments Code Test Plan Finish Start Milestone Milestone A sequence constraint: the Requirements task must be complete before the Test Plan task can start Product Test Test Drivers Test Plan and Design are potentially concurrent tasks
Sequence the Tasks Using a Network Diagram A network diagram shows the order in which tasks are to be performed Two network diagrams for the same tasks (from Verzuh p. 155) Why is the second diagram inconsistent with the Predecessor Table?”
Guidelines for Creating a Network Diagram Seek maximum concurrency in the network diagram for scheduling flexibility Define task relationships only between tasks Summary tasks are groups of tasks, and each task can have different sequence constraints If a task has no predecessor task, it can start at any point in the project, as long as it is meets its finish date Task relationships should only reflect sequence constraints, not resource constraints We may want to perform “what if” analysis on the network diagram with different staffing options Resource constraints can be imposed later before building an initial schedule
Network Diagram with Calculated Durations Task Duration = Time from task start until task completion Design 4 mo. Document 2 mo. Require- ments 3 mo. Duration (4,7) (8,9) (0,3) Code 4 mo. Test Plan 2 mo. Finish Start (Start, Finish month) (4,5) (8,11) (15,15) (0,0) Product Test 4 mo. Key assumptions: task durations and sequence constraints are known Test Drivers 3 mo. (6,8) (12,15)
Network Diagram with Slack Time Some tasks have flexibility in when they can be performed Design 4 mo. Document 2 mo. Require- ments 3 mo. Slack time = 6 months (4,7) (8,9) (0,3) Code 4 mo. Test Plan 2 mo. Finish Start (Start, Finish month) (4,5) (8,11) (15,15) (0,0) Product Test 4 mo. Test Drivers 3 mo. Test Drivers could be started as much as 3 months after Test Plan is completed (the slack time) Slack time = 3 months (6,8) (12,15)
Using Slack Time If 2 persons could do the Test Drivers in 3 months, how many people are needed to complete them before Product Test starts? Design 4 mo. Document 2 mo. Require- ments 3 mo. Slack time = 6 months (4,7) (8,9) (0,3) Code 4 mo. Test Plan 2 mo. Finish Start (Start, Finish month) (4,5) (8,11) (15,15) (0,0) Product Test 4 mo. If the 2 people were not available when the Test Plan was completed, how late could they start without delaying the project? Test Drivers 3 mo. Slack time = 3 months (6,8) (12,15)
How Do We Get the Duration Values? Option 1: Pick “reasonable” duration values for each task and let Project calculate the completion date Issue: does the project finish at a date acceptable to the stakeholders? Option 2: Pick the promised project finish date and work backwards, picking task durations compatible with the finish date Issue: can the development team meet the task durations? Option 3: calculate the labor estimate (the work) for the task Work = (number of people) * (length of time on the task) and then calculate the duration as a f(staff size) Assumption: we have many options of who works on the task and for how long, but the work content of the task is fixed.
Network Diagram Showing Critical Path Design 4 mo. Document 2 mo. Require- ments 3 mo. Duration (4,7) Slack time = 6 months (8 ,9) (0,3) Slack time = 3 months Code 4 mo. Test Plan 2 mo. Finish Start (Start, Finish month) (4,5) (8,11) (15,15) (0,0) Product Test 4 mo. Test Drivers 3 mo. Critical Path is a path in the network diagram with no slack time Slack time = 3 months (6,8) (12,15)
Critical Path Analysis Helps Answer These Scheduling Questions What is the latest time we can start a task without impacting the project finish date? What tasks, if delayed, will result in a delay to the project completion date? What tasks must be shortened if the project is to be shortened?
Characteristics of the Critical Path The critical path specifies the minimum length of the project, given the durations of the tasks on the critical path the constraints in the network diagram If any task on the critical path is delayed, the finish date of the project will be delayed The ways to shorten the project are: to reduce the duration of some of the tasks on the critical path (add more people?) to find more parallelism among the tasks (reduce the constraints in the network diagram)
Creating a Plan for an EDL Phase Start with list of a phase’s additional functions as prioritized by the stakeholders The key question is: what functionality can be delivered with high certainty in the phase length (90-120 days)? DO UNTIL all tasks can be done within the phase length Determine the dependencies among tasks for the phase Seek maximum parallelism among the tasks Estimate the resources required for each task Recalculate task durations If length of critical path > phase length THEN remove tasks for implementing lower-priority functions END DO
Summary of the Steps in Creating the WBS Enumerate all the deliverables to stakeholders external to the project team Specify the stakeholders who are expected to “accept” the external deliverables Develop a Level 1 “deliverable-oriented” WBS for the project based upon the external deliverables Include at Level 1 the jobs that are essential to producing multiple deliverables , such as: Requirements definition Architectural design Include at Level 1 the functions that occur throughout the project Project management Quality assurance
Summary of the Steps in Creating the WBS, Part 2 Insert at Level 1 the external milestones by which the accepting stakeholders can track progress towards completing the deliverables Write a one or two sentence completion criterion (in Notes field) for each external milestones External milestones (including deliverable completion milestones) must be included with: Average interval on a > 6 month project: one per month Average interval on a 3 month project: one every two weeks Detail each Level 1 summary task into Level 2 information Insert the internal milestones into the WBS Develop the lower-level decomposition as required to achieve the required detail (based upon task size)
Why Not Build an Activity-Oriented Work Breakdown Structure? Develop and Install Fashionland System Nationwide 1.0 project management 2.0 quality assurance 3.0 requirements definition 4.0 software design 4.1 design of user system interface 4.2 design of POS system 5.0 code and unit test 6.0 software integration 7.0 document and install 8.0 conduct store and headquarters training
Comparing the Two Representations
Activity Versus Deliverable-oriented WBS? Either WBS approach can represent the project A deliverable-oriented WBS focuses attention on what must be produced, an activity-oriented WBS focuses attention on what is being done A deliverable-oriented WBS facilitates tracking the work completed on your project A deliverable-oriented WBS is more understandable to higher-level management A deliverable-oriented WBS enables cost estimating and cost reporting by deliverable See article: “Making Software Development More Controllable” in the web site Readings area