430 likes | 593 Views
Software Engineering. Part 03. 程建群 博士 (Dr. Jason Cheng) Jason_beihang@yahoo.cn 13522913536 2008 年 03 月. Software Project Management. Software Project Management. Software Project Management.
E N D
Software Engineering Part 03 程建群 博士(Dr. Jason Cheng) Jason_beihang@yahoo.cn 13522913536 2008年03月
Software Project Management Software Project Management
Software Project Management Software project management is important task of planning, directing, motivating, and coordinating a group of professionals to accomplish software development. Software project management uses many concepts from management in general, but it also has some concerns unique to software development. Software Project Management
Management Approaches A basic issue in software project management is whether the process or the project is the essential feature being managed. In process-oriented management, the management of small tasks in the software life cycle is emphasized. In project management, the team achieving the project is emphasized. Software Project Management
Management Approaches In a process management approach, if the team does not follow the prescribed software life cycle, this would be a major difficulty. In a project management approach, success or failure is directly attributed to the team. Software Project Management
Team Approaches Choosing a team organization based on the project and the team members will help avoid disaster. Difficulty: efficient and effective Software Project Management
Team Approaches Team Structure: Some programmers can work very independently Others need groups in strong structure to make progress. In a weakly structured team, the tasks are usually of longer duration and more open-ended. Software Project Management
Team Approaches Chief Programmer Teams (from IBM): • It assigns specific roles to members of the team. • The chief programmer is the best programmer and leads the team. • Nonprogrammers are used on the team for documentation and clerical duties. • Junior programmers are included to be mentored by the chief programmer. Software Project Management
Team Approaches • Example 3.1 High-level process model for team structure Software Project Management
Team Approaches • Example 3.2 Company WRT has an IT department with a few experienced software developers and many new programmers. The IT manager has decided to use highly structured teams using a process approach to managing. Each team will be led by an experienced software developer. Each team member will be given a set of tasks weekly. The team leader will continually review progress and make new assignments. Software Project Management
Critical Practices 16 Critical Success Practices • Adopt continuous risk management Estimate cost and schedule empirically • Use metrics to manage • Track earned value • Track defects against quality targets • Treat people as the most important resource • Adopt life cycle configuration management • Manage and trace requirements Software Project Management
Critical Practices 16 Critical Success Practices • Use system-based software design • Ensure data and database interoperability • Define and control interfaces • Design twice code once • Assess reuse risks and costs • Inspect requirements and design • Manage testing as a continuous process • Compile and smoke-test frequently Software Project Management
Capability Maturity Model The Software Engineering Capability Maturity Model (SE-CMM) is used to rate an organization’s software development process by different levels. Software Project Management
Capability Maturity Model Level 1: Initial This is the lowest level and usually characterized as chaotic. Software Project Management
Capability Maturity Model Level 2: Repeatable This level of development capability includes project tracking of costs, schedule, and functionality. The capability exists to repeat earlier successes. Software Project Management
Capability Maturity Model Level 3: Defined This level has a defined software process that is documented and standardized. All development is accomplished using the standard processes. Software Project Management
Capability Maturity Model Level 4: Managed This level quantitatively manages both the process and the products. Software Project Management
Capability Maturity Model Level 5: Optimizing This level uses the quantitative information to continuously improve and manage the software process. Software Project Management
Personal Software Process This process was developed by Watts Humphrey to improve the skills of the individual software engineer. This approach has the individual maintain personal time logs to monitor and measure the individual’s skills. Software Project Management
Personal Software Process Example 3.4 Programmer X recorded this time log Software Project Management
Personal Software Process Example 3.4 Programmer X recorded this time log The programmer spent 360 + 270 + 150 + 120 = 900 minutes to write and test a program 0f 160 LOC. Assuming 5 hours per day (300 minutes/day), X spent effectively 3 days to program 160 LOC. This gives a productivity 0f 53 LOC/day. When X’s manager schedules a week to code a 1000 = LOC project. X is able to estimate that the project will take about 4 weeks. Software Project Management
Earned Value Analysis This approach is to measuring progress in a software project. It is to calculate how much has been accomplished. It is basically the percentage of the estimated time that has been completed. Software Project Management
Earned Value Analysis BASIC MEASURES • Budgeted Cost of Work (BCW): The estimated effort for each work task. • Budgeted Cost of Work Scheduled (BCWS): The sum of the estimated effort for each work task that was scheduled to be completed by the specified time. • Budget at Completion (BAC): The total of the BCWS and thus the estimate of the total effort for the project. Software Project Management
Earned Value Analysis BASIC MEASURES • Planned Value (PV): The percentage of the total estimated effort that is assigned to a particular work task; PV = BCW/BAC. • Budgeted Cost of Work Performed (BCWP): The sum of the estimated efforts for the work tasks that have been completed by the specified time. • Actual Cost of Work Performed (ACWP): The sum of the actual efforts for the work tasks that have been completed. Software Project Management
Earned Value Analysis Progress Indicators • Earned Value (EV) = BCWP/BAC = The sum of the PVs for all completed work tasks = PC = Percent complete • Schedule Performance Index (SPI) = BCWP/BCWS • Schedule Variance (SV) = BCWP – BCWS • Cost Performance Index (CPI) = BCWP/ACWP • Cost Variance (CV) = BCWP – ACWP Software Project Management
Earned Value Analysis Example 3.5 Company LMN is partway through its project. The job log below indicates the current status of the project. Software Project Management
Earned Value Analysis Example 3.5 Software Project Management
Earned Value Analysis Example 3.5 The BAC is the sum of estimations. BAC = 330 days. BAC is an estimate of the total work. On 4/1/01, tasks 1, 2, and 4 have been completed. The BCWP is the sum of the BCWS for those tasks. So BCWP is 70 days. The earned value (EV) is 70/330, or 21.2 percent. On 4/1/01 tasks 1 and 2 were scheduled to be completed and 1, 2, and 4 were actually completed. So BCWP is 70 days and BCWS is 30 days. Thus, SPI is 70/30, 0r 233 percent. The SV = 70 days – 30 days = +40 days, or 40 programmer-days ahead. The ACWP is the sum of actual effort for tasks 1, 2, and 4. So, ACWP is 80 programmer-days. CPI is 70/80 = 87.5 percent. The CV = 70 programmer-days – 80 programmer-days = -10 programmer-days, or 10 programmer-days behind. Software Project Management
Earned Value Analysis Example 3.6 On 7/1/01, assume that task 3 has also been completed using 140 days of actual effort, so BCWP is 190 and EV is 190/330, or 57.5 percent. On 7/1/01, tasks 1, 2, 3 and 4 were actually completed. So BCWP is 190 days and BCWS is 250 days. Thus, SPI is 190/250 = 76 percent. The SV is 190 programmer-days – 250 programmer-days = - 60 programmer-days, or 60 programmer days behind. ACWP is the sum of actual effort for 1, 2, 3, and 4. So ACWP is 220 programmer-days. Task 1 through 5 were scheduled to have been completed, but only 1 through 4 were actually completed. CPI is 190/220 = 86.3 percent, and CV is 190-220, or 30 programmer-days behind. Software Project Management
Error Tracking One excellent management practice is error tracking, which is keeping track of the errors that have occurred and the inter-error times (the time between occurrences of the errors). This can be used to make decisions about when to release software. An additional effect of tracking and publicizing the error rate is to make the software developers aware of the significance of errors and error reduction. The effects of changes in the software process can be seen in the error data. Additionally, making the errors and error detection visible encourages testers and developers to keep error reduction as a goal. Software Project Management
Error Tracking Example 3.7 Consider the following error data (given as the times between errors): 4, 3, 5, 6, 4, 6, 7. The instantaneous error rates are the inverses of the inter-error times: 0.25, 0.33, 0.20, 0.17, 0.25, 0.17, and 0.14. Plotting these against error number gives a download curve. This suggests that the actual error rate is decreasing. Software Project Management
Error Tracking Example 3.7 Software Project Management
Postmortem Reviews One critical aspect of software development is to learn from your mistakes and successes. In software development, this is called postmortem. It consists of assembling key people from the development and the users group. Issues consist of quality, schedule, and software process. Software Project Management
Postmortem Reviews Example 3.8 Company JKL produced the postmortem report shown on next page. Software Project Management
Postmortem Reviews Example 3.8 Software Project Management
Review Questions • What is meant by visibility? Visibility is the attribute of being able to see the progress or lack of progress in a project. Software Project Management
Review Questions • What is the difference between a process approach and a project approach? A process approach is similar to an assembly line, where each person has a task to be done. Developers may do the same task on multiple projects – for example, a test team or a design team. A project emphasis would give the team the responsibility for the whole effort in developing a project. Software Project Management
Review Questions • For a new project that is very different from any previous project. Would a process or project management approach be better? Process management works well with projects that are well understood. A new, very different project might be better managed by a project approach that emphasizes success in the project. Software Project Management
Review Questions • Which earned value progress measures can decrease during a project? All but the earned value, which must increase. Software Project Management
Review Questions • What would be the advantage of using the inverse of SPI and CPI. The inverse of each could be used as a projection tool. If the inverse of SPI was 2, it would imply that project will take twice as long as estimated. If the inverse of CPI was 2, it would imply that the project will take twice the effort that was estimated. Software Project Management
Problems • Draw a process model for a team that has a week structure and depends on the team discussions to set directions and resolve issues. Software Project Management
Problems • Using the following time log calculate the programmer’s productivity in LOC day. Assume that project 1 was 120 LOC and project 2 was 80 LOC. Software Project Management
Problems • Using the following time log calculate the programmer’s productivity in LOC day. Assume that project 1 was 120 LOC and project 2 was 80 LOC. The delta time for day 1 is 8 hours – 1 hour for lunch = 420 minutes; day 2 is 8 hours – 30 minutes = 450 minutes. So the productivity for project 1 is 120 LOC 870 munites – 120 LOC 2.175 days = 55 LOC programmer-day (assume 400 minutes per programmer day). The delta times for day 3 and 4 are 7 hours and 4.5 hours = 690 minutes. The productivity is 80 LOC 1.725 days = 46.4 LOC programmer-day. Overall, the programmer averaged 200 LOC 3.9 days = 51.3 LOC programmer-day. Software Project Management