1 / 25

Personal Software Process SM for Engineers: Part II Tutorial: Using PSP2

Learn how to use PSP2 for program design and code reviews, quality planning, and defect estimation. Understand new process elements and review time estimation techniques.

karenhickey
Download Presentation

Personal Software Process SM for Engineers: Part II Tutorial: Using PSP2

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Personal SoftwareProcessSMfor Engineers: Part IITutorial: Using PSP2

  2. Tutorial Objectives • After this tutorial, you will • understand the new PSP2 process elements • know how to use the PSP2 scripts and forms • be prepared to use PSP2 for program 5

  3. PSP2 Objectives • The objectives of PSP2 are to introduce • design and code reviews • methods for evaluating and improving the quality of your reviews

  4. New Process Elements • There are two new process elements. • design review checklist • code review checklist • Design and code review checklists are described separately. • PSP2 adds two key capabilities to the PSP • design and code reviews • quality planning • The PSP2 project plan summary supports these two new capabilities.

  5. Design and Code Reviews • Two phases have been added to the process • Design reviews (DLDR) • Code reviews (CR) Time and defect data from these phases are summarized on the PSP2 Project Plan Summary.

  6. Quality Planning • PSP2 introduces quality planning. • Quality planning involves • estimating the total number of defects that will be injected • estimating the number of defects that will be injected and removed in each process phase • estimating the amount of time needed for design and code reviews • adjusting these parameters as needed to ensure a high quality result

  7. Estimating Total Defects • To estimate the total defects injected and removed, use the estimated program size and to-date defect density to calculate the estimated total defects. • Use this formula

  8. Estimating Defects by Phase • To estimate defects injected and removed by phase, distribute the planned total defects injected and removed based on historical data. • Planned Total Defects • To Date % defects injected in each phase • To Date % defects removed in each phase

  9. Estimating Review Time • These PSP benchmarks can be used to estimate design review and code review time in phase. For manual calculations, starting with the code review rate is recommended.

  10. Estimating With Review Rates -1 • Benchmark data on code review rates can be used to estimate review time. • From PSP data, we know that code review rates under 200 LOC/hour generally give high yield. • Using planned added and modified LOC, code review time can be calculated using this formula. Assume a similar rate for design reviews.

  11. Estimating With Review Rates -2 • To add review time to your plan • increase the total minutes, and/or • reduce compile and test time • As a final check of your estimate, make sure that • review rates are less than 200 LOC per hour • defect removal rates are between • 3 to 5 per hour for design review • 5 to 10 per hour for code review • A/FR is about 2.0

  12. Estimating Considerations • Initially no historical data are available for planning defects injected and removed in review phases. • Until you have data for design and code review phases, you may want to consider • defects injected are 0 • defects removed should be based on your yield goal • Your yield goal should be based on your interim report analysis. If you do not have a yield goal, you should try to achieve greater than 60% yield.

  13. Estimating Defects Removed • Defects removed in a review phase are calculated using • number of defects escaping from prior phases • number of defects injected in a phase • percentage of defects removed, i.e. Phase Yield

  14. Yield-based Quality Planning • An alternative approach to quality planning is to start with the desired PSP process yield. • Process yield is the percentage of defects removed before the first compile. • First choose a target process yield, then use historical data to calculate the quality plan. • defects injected and removed by phase • time in phase for design review, code review, compile, and test

  15. Choosing a Desired Yield • The ideal yield is 100%, all defects injected are removed before the first compile and test. • While you are likely to achieve 100% yield periodically, this may not be a realistic goal. • Class average yields will typically exceed 50% to 60%. • PSP class data indicate that yields of 60% to 80% are easy to achieve with PSP design and code reviews.

  16. Phase Yield • Phase yield is the percentage of defects that were removed in a phase and is based on defects entering the phase + defects injected in the phase. • With PSP2, the process yield is a function of the design and code review yields, and the proportion of defects present for the design review. Choose a target process yield and solve this equation for the design and code review yields.

  17. Other factors • Other factors to consider • Defects may be removed in phases other than DLDR, CR, Compile, and Test. • Defects may be injected in compile or test • Calculating the desired phase yield is difficult Due to the complexity of this approach, automated support is necessary. To produce a yield-based quality plan, enter the target yield as the planned yield.

  18. Estimating Review Time • Finding defects early will reduce defects found in compile and test. • The support tool computes the time saved using the average defect removal rate for compile or test. • The time saved is then used for design and code reviews. • The allocation of time saved is based on the ratio of estimated time in design vs. estimated time in code.

  19. Derived Quality Measures • PSP2 also provides the following derived quality measures. • Defect removal efficiency • Defect removal leverage • Test defects per KLOC • Total defects per KLOC • Yield

  20. Defect Removal Efficiency • Defect removal efficiency is calculated automatically and • shows the number of defects removed per hour for • Design review • Code review • Compile • Test

  21. Defect Removal Leverage • Defect removal leverage is calculated automatically and • compares removal efficiency for • Design Review vs. Unit Test • Code Review vs. Unit Test • Compile vs. Unit Test

  22. Test Defects Per KLOC • Test defects per KLOC is calculated automatically and is an indicator of the quality of the program that you put into test.

  23. Total Defects Per KLOC • Total defects per KLOC is calculated automatically and is a measure of the total defects injected during the process.

  24. Yield • Yield (actual and to-date) is calculated automatically for the entire process and is the percentage of defects injected and removed before the first compile.

  25. Messages to Remember • You will see more improvement from design and code reviews than any other process change you make. • Quality will improve. • Productivity will increase. • PSP2 provides data that allows you to • plan for specific quality levels • control quality during development • improve the quality of your PSP • increase productivity without sacrificing quality

More Related