730 likes | 853 Views
Techniques Supporting Project Management (Part 4). Dr.Çağatay ÜNDEĞER Instructor Bilkent University, Computer Engineering Middle East Technical University, Game Technologies & General Manager SimBT Inc. e-mail : cagatay@undeger.com.
E N D
Techniques Supporting Project Management (Part 4) Dr.Çağatay ÜNDEĞER Instructor Bilkent University, Computer Engineering Middle East Technical University, Game Technologies & General Manager SimBT Inc. e-mail : cagatay@undeger.com Bilgisayar Mühendisliği Bölümü – Bilkent Üniversitesi – Fall 2009
Techniques Supporting Project Management • Task related: • Work breakdown structures • Gantt Charts • Network Diagrams • Program Evaluation Review Technique (PERT) • Calender View • Task usage View • Resource related: • Resource Sheet • Resource Calenders • Resource Graph View • Resource Usage View
Work Breakdown Structures • A hierarchical listing of the activities (e.g. tasks, sub-tasks) necessary for the completion of the project. • Split activities into sub-activities as much as you can; • Until leaf activities become clear and easily manageable.
A Sample Project • Generating a multimedia database with; • Word, excell, power point documents • Image files • Video files • Sound files • Viewing and editing • Source files & database content • Exporting/Importing database content to/from individual files.
A Sample Work Breakdown Structure • Software Project Development Life Cycle (Spiral Model) • Cycle 1 • System Planning • System Analysis • Cycle 2 • System Planning • System Anaylsis • System Design • System Implementation (Prototype) • System Deployment • Cycle 3 • System Planning • System Anaylsis • System Design • System Implementation (Release 1.0) • System Deployment • System Maintenance
Cycle 1 (System Planning) • System Planning • Identify project needs • Determine project scope • Prepare project definition document • Prepare project management plans • Prepare Software Project Management Plan • Prepare Software Quality Assurance Plan • Prepare Software Risk Management Plan • Prepare software engineering plans • Prepare Software Configuration Management Plan • Prepare Software Verification and Validation Plan • Evaluate and approve project plans • Sign project contract • System Analysis ...
Cycle 1 (System Analysis) • System Planning ... • System Analysis • Perform software requirements analysis • Determine software requirements • Structure software requirements • Prepare Software Requirements Specification • Evaluate and approve Software Requirements Specification • Perform literature survey • ???
Cycle 1 (System Analysis) • System Planning ... • System Analysis • Perform software requirements analysis • Determine software requirements • Structure software requirements • Prepare Software Requirements Specification • Evaluate and approve Software Requirements Specification • Perform literature survey • Loading and visualising office files (doc, xls, ppt, etc.) • Loading and visualising image files (bmp, jpg, tif, etc.) • Loading and playing video files (avi, mpg, dat, etc.) • Loading and playing sound files (wav, mp3) • Generating multimedia databases with above sources
Cycle 2 (System Planning) • System Planning • Update project management plans • Update Software Project Management Plan • Update Software Risk Management Plan • Evaluate and approve project plans • System Analysis ... • System Design ... • System Implementation (prototype) ... • System Deployment...
Cycle 2 (System Analysis) • System Planning ... • System Analysis • Refine software requirements analysis • Update software requirements • Restructure software requirements • Prepare Software Requirements Specification • Evaluate and approve Software Requirements Specification • Perform literature survey • ??? • Generate alternative designs • Determine and select alternative designs • Evaluate and approve selected design • System Design ... • System Implementation (prototype) ... • System Deployment...
Cycle 2 (System Analysis) • System Planning ... • System Analysis • Refine software requirements analysis • Update software requirements • Restructure software requirements • Prepare Software Requirements Specification • Evaluate and approve Software Requirements Specification • Perform literature survey • Editing and saving office files (doc, xls, ppt, etc.) • Editing and saving image files (bmp, jpg, tif, etc.) • Editing and saving video files (avi, mpg, dat, etc.) • Editing and saving sound files (wav, mp3) • Generate alternative designs • Determine and select alternative designs • Evaluate and approve selected design • System Design ... • System Implementation (prototype) ... • System Deployment...
Cycle 2 (System Design) • System Planning ... • System Analysis ... • System Design • Prepare logical system description • Prepare physical system description • Determine details of implementation environment • Select hardware platforms and operating systems • Select programming languages • Select database systems and file structures • Select network environment • Design details of system • Design user interfaces • ??? • Design reports • ??? • Design databases • ??? • Design algorithms • ??? • Design computer process • ??? • Design system integration • Prepare Software Design Description • Evaluate and approve Software Design Description • System Implementation (prototype) ... • System Deployment...
Cycle 2 (System Design) • System Planning ... • System Analysis ... • System Design • Prepare logical system description • Prepare physical system description • Determine details of implementation environment • Select hardware platforms and operating systems • Select programming languages • Select database systems and file structures • Select network environment • Design details of system • Design user interfaces • Main window • Windows for file import, visualise, edit and save • Windows for database content generation • Windows for database content browser, visualise, edit and save to file • Windows for database backup and restore • Windows for user accounts management • Design reports • ... • Design databases • Design algorithms • Design computer process • Design system integration • Prepare Software Design Description • Evaluate and approve Software Design Description • System Implementation (prototype) ... • System Deployment...
Cycle 2 (System Implementation) • System Planning ... • System Analysis ... • System Design ... • System Implementation (prototype) • Coding • Implement software components • ??? • Integrate software components • Correct reported bugs • Testing & Correction • Prepare Software Test Document • Evaluate and approve Software Test Document • Perform unit tests • Perform integration tests • Report test results and update Software Test Document • Demonstrate, evaluate and approve system software • System Deployment...
Cycle 2 (System Implementation) • System Planning ... • System Analysis ... • System Design ... • System Implementation (prototype) • Coding • Implement software components • Implement user interfaces • Main window • Windows for file import, visualise, edit and save • Windows for database content generation • Windows for database content browser, visualise, edit and save to file • Windows for database backup and restore • Windows for user accounts management • Implement reports • ... • Implement databases • Implement algorithms • Implement computer process • Integrate software components • Correct reported bugs • Testing & Correction • Prepare Software Test Document • Evaluate and approve Software Test Document • Perform unit tests • Perform integration tests • Report test results and update Software Test Document • Demonstrate, evaluate and approve system software • System Deployment...
Cycle 2 (System Deployment) • System Planning ... • System Analysis ... • System Design ... • System Implementation (prototype) ... • System Deployment • Install system software • Enter baseline data • ??? • Train users • 1 weeks administrator training • 1 week user training
Cycle 2 (System Deployment) • System Planning ... • System Analysis ... • System Design ... • System Implementation (prototype) ... • System Deployment • Install system software • Enter baseline data • Import office documents from previous archives • Import image files from previous archives • Import video files from previous archives • Import sound files from previous archives • Train users • 1 weeks administrator training • 1 week user training
Cycle 3 (System Planning) • System Planning • Update project management plans • Update Software Project Management Plan • Evaluate and approve project plans • System Analysis ... • System Design ... • System Implementation (release 1.0) ... • System Deployment ...
Cycle 3 (System Analysis) • System Planning ... • System Analysis • Refine software requirements analysis • Update software requirements • Restructure software requirements • Prepare Software Requirements Specification • Evaluate and approve Software Requirements Specification • System Design ... • System Implementation (release 1.0) ... • System Deployment ...
Cycle 3 (System Design) • System Planning ... • System Analysis ... • System Design • Refine logical system description • Refine physical system description • Refine details of system • Update user interfaces • Update reports • ... • Refine system integration • Prepare Software Design Description • Evaluate and approve Software Design Description • System Implementation (release 1.0) ... • System Deployment ...
Cycle 3 (System Implementation) • System Planning ... • System Analysis ... • System Design ... • System Implementation (release 1) • Coding • Refine software components • Integrate software components • Correct reported bugs • Testing & Correction • Prepare Software Test Document • Evaluate and approve Software Test Document • Perform unit tests • Perform integration tests • Report test results and update Software Test Document • Prepare Software Deliverables • Prepare user manuals • Prepare system setup application • Demonstrate, evaluate and approve system software • System Deployment ...
Cycle 3 (System Deployment) • System Planning ... • System Analysis ... • System Design ... • System Implementation (release 1) ... • System Deployment • Install system software • Enter baseline data • ... • Train users • 3 weeks administrator training • 2 week user training
Afterwards (System Maintenance) • System Maintenance • Fix system software bugs • Improve system software
Techniques Supporting Project Management • Task related: • Work breakdown structures • Gantt Charts • Network Diagrams • Program Evaluation Review Technique (PERT) • Calender View • Task usage View • Resource related: • Resource Sheet • Resource Calenders • Resource Graph View • Resource Usage View
Gantt Charts • A bar chart showing start and end dates for the activities (WBS) of a project. • Not intended to indicate how tasks must be ordered, • But simply show when a task should begin and end. • Very helpful for seeing date-time relations of activities.
Gantt Charts • On the left, a work breakdown structure is located; • On the right, the time bars are located. Start: 20.02.2008 End: 28.02.2008 Duration: 7 days summary tasks leaf tasks From Microsoft Office
Information on Gantt Charts • Many information can be seen on gantt charts duration of task percent of task completed From Microsoft Office
Information on Gantt Charts • Precedence relations can be seen on gantt charts. Predecessor of Task A Starts at the Same time Successor of Task A Task A From Microsoft Office
Information on Gantt Charts • Resource assignments can be seen on gantt charts • Resource usage can be seen on gantt charts With two full-time personnel With one Full-time personnel Many tasks in parallel With one part-time personnel With two part-time personnel From Microsoft Office
Information on Gantt Charts • Critical paths can be seen on gantt charts Critical path is the longest path through the project illustrating the shortest amount of time in which a project can be completed. Tasks on critical path cannot be delayed without delaying project. Red colored tasks are on critical path. Therefore they can not be delayed. Blue colored tasks are not on critical path. Therefore they can be delayed. From Microsoft Office
Techniques Supporting Project Management • Task related: • Work breakdown structures • Gantt Charts • Network Diagrams • Program Evaluation Review Technique (PERT) • Calender View • Task usage View • Resource related: • Resource Sheet • Resource Calenders • Resource Graph View • Resource Usage View
Network Diagrams • A schematic display; • That illustrates various tasks in a project • As well as their sequential relationship. • A scheduling technique used for controlling resources. • Show which tasks can be done in parallel.
Network Diagrams • Used to identify critical paths. • Critical path is the longest path through the project • Illustrating the shortest amount of time • In which a project can be completed. • Tasks on critical path cannot be delayed without delaying project.
Network Diagrams (Sample: Summary & Leaf Tasks) From Microsoft Office
Network Diagrams (Sample: Leaf Tasks) • With the information below, • You can be able to draw a network diagram.
Network Diagrams (Sample: Visualisation) • Tasks are shown by either • Circles or • Rectangles. • Work flows are shown by arrows. Task 1 is the predecessor of Task 2 1 2 Task 2 follows Task 1 Task 1 Task 2
Network Diagrams (Sample: Network Diagram) 8 6 3 9 5 10 13 4 11 12
Network Diagrams (Sample: Network Diagram) 3 5 8 6 9 10 11 13 4 12
Network Diagrams (Sample: Network Diagram) D = 2 D = 2 D = 1 D = 4 3 5 8 6 D = 1 9 10 11 13 D = 4 4 D = 7 D = 1 D = 1 D = 1 12
Network Diagrams (Sample: Network Diagram) ET = Earliest completion time Compute ET of left mosts first. Compute ET of each forward task by summing ET for each task from left to right. LT = Latest completion time Compute LT of right mosts first. Compute LT of each backward task by subtracting duration for each task from right to left. D = 2 D = 2 D = 1 D = 4 3 5 8 6 D = 1 9 10 11 13 D = 4 4 D = 7 D = 1 D = 1 D = 1 12
Network Diagrams (Sample: Network Diagram) ET = Earliest completion time Compute ET of left mosts first. Compute ET of each forward task by summing ET for each task from left to right. LT = Latest completion time Compute LT of right mosts first. Compute LT of each backward task by subtracting duration for each task from right to left. D = 2 D = 2 D = 1 D = 4 3 5 8 6 ET = 2 D = 1 9 10 11 13 D = 4 4 D = 7 D = 1 D = 1 D = 1 ET = 4 12
Network Diagrams (Sample: Network Diagram) ET = Earliest completion time Compute ET of left mosts first. Compute ET of each forward task by summing ET for each task from left to right. LT = Latest completion time Compute LT of right mosts first. Compute LT of each backward task by subtracting duration for each task from right to left. D = 2 D = 2 D = 1 D = 4 3 5 8 6 ET = 2 ET = max(2,4)+2 D = 1 9 10 11 13 D = 4 4 D = 7 D = 1 D = 1 D = 1 ET = 4 12 ET = 4+7
Network Diagrams (Sample: Network Diagram) ET = Earliest completion time Compute ET of left mosts first. Compute ET of each forward task by summing ET for each task from left to right. LT = Latest completion time Compute LT of right mosts first. Compute LT of each backward task by subtracting duration for each task from right to left. D = 2 D = 2 D = 1 D = 4 3 5 8 6 ET = 2 ET = 6 ET = 6+1 D = 1 9 10 11 13 D = 4 4 D = 7 D = 1 D = 1 D = 1 ET = 4 12 ET = 11
Network Diagrams (Sample: Network Diagram) ET = Earliest completion time Compute ET of left mosts first. Compute ET of each forward task by summing ET for each task from left to right. LT = Latest completion time Compute LT of right mosts first. Compute LT of each backward task by subtracting duration for each task from right to left. D = 2 D = 2 D = 1 D = 4 3 5 8 6 ET = 2 ET = 6 ET = 7 ET = 7+4 D = 1 9 10 11 13 D = 4 4 D = 7 D = 1 D = 1 D = 1 ET = 7+1 ET = 4 12 ET = 11
Network Diagrams (Sample: Network Diagram) ET = Earliest completion time Compute ET of left mosts first. Compute ET of each forward task by summing ET for each task from left to right. LT = Latest completion time Compute LT of right mosts first. Compute LT of each backward task by subtracting duration for each task from right to left. D = 2 D = 2 D = 1 D = 4 3 5 8 6 ET = 2 ET = 6 ET = 7 ET = 11 D = 1 9 10 11 13 D = 4 4 D = 7 D = 1 D = 1 D = 1 ET = max(11,11)+1 ET = 8 ET = 8+1 ET = 4 12 ET = 11
Network Diagrams (Sample: Network Diagram) ET = Earliest completion time Compute ET of left mosts first. Compute ET of each forward task by summing ET for each task from left to right. LT = Latest completion time Compute LT of right mosts first. Compute LT of each backward task by subtracting duration for each task from right to left. D = 2 D = 2 D = 1 D = 4 3 5 8 6 ET = 2 ET = 6 ET = 7 ET = 11 D = 1 9 10 11 13 D = 4 4 D = 7 D = 1 D = 1 D = 1 ET = 12 ET = 8 ET = 9 ET = 9+1 ET = 4 12 ET = 11
Network Diagrams (Sample: Network Diagram) ET = Earliest completion time Compute ET of left mosts first. Compute ET of each forward task by summing ET for each task from left to right. LT = Latest completion time Compute LT of right mosts first. Compute LT of each backward task by subtracting duration for each task from right to left. D = 2 D = 2 D = 1 D = 4 3 5 8 6 ET = 2 ET = 6 ET = 7 ET = 11 D = 1 9 10 11 13 D = 4 4 D = 7 D = 1 D = 1 D = 1 ET = 12 ET = 8 ET = 9 ET = 10 ET = 4 12 ET = 11
Network Diagrams (Sample: Network Diagram) ET = Earliest completion time Compute ET of left mosts first. Compute ET of each forward task by summing ET for each task from left to right. LT = Latest completion time Compute LT of right mosts first. Compute LT of each backward task by subtracting duration for each task from right to left. D = 2 D = 2 D = 1 D = 4 3 5 8 6 ET = 2 ET = 6 ET = 7 ET = 11 D = 1 9 10 11 13 D = 4 4 D = 7 D = 1 D = 1 D = 1 ET = 12 LT = 12 ET = 8 ET = 9 ET = 10 ET = 4 LT = 12 12 ET = 11 Assign project end date, max(ET)
Network Diagrams (Sample: Network Diagram) ET = Earliest completion time Compute ET of left mosts first. Compute ET of each forward task by summing ET for each task from left to right. LT = Latest completion time Compute LT of right mosts first. Compute LT of each backward task by subtracting duration for each task from right to left. D = 2 D = 2 D = 1 D = 4 3 5 8 6 ET = 2 ET = 6 ET = 7 ET = 11 D = 1 LT = 12-1 9 10 11 13 D = 4 4 D = 7 D = 1 D = 1 D = 1 ET = 12 LT = 12 ET = 8 ET = 9 ET = 10 ET = 4 LT = 12-1 LT = 12 12 ET = 11 LT = 12-1
Network Diagrams (Sample: Network Diagram) ET = Earliest completion time Compute ET of left mosts first. Compute ET of each forward task by summing ET for each task from left to right. LT = Latest completion time Compute LT of right mosts first. Compute LT of each backward task by subtracting duration for each task from right to left. D = 2 D = 2 D = 1 D = 4 3 5 8 6 ET = 2 ET = 6 ET = 7 ET = 11 D = 1 LT = 11 9 10 11 13 D = 4 4 D = 7 D = 1 D = 1 D = 1 ET = 12 LT = 12 ET = 8 ET = 9 ET = 10 ET = 4 LT = 11-1 LT = 11 LT = 12 12 ET = 11 LT = 11