Download presentation
Presentation is loading. Please wait.
Published byRodger Marsh Modified over 9 years ago
1
Effort and Schedule Estimation Copyright, 2006 © L. Ouyang Liubo Ouyang ouyangliubo@126.comhttp://ss.hnu.cn/oylb/psp/ Personal Software Process Lecture 7
2
L.Ouyang, PSP, Lecture 7 Introduction Time & defect recording Time & defect recording Coding strd+Size measuremnt+PIP Coding strd+Size measuremnt+PIP Size estimating + Test report Task & schedule planning Code & design reviews Code & design reviews Design templates Design templates Cyclic dev. Cyclic dev. Baseline Planning Quality Cyclic
3
L.Ouyang, PSP, Lecture 7 Introduction begin.. end 500 LOC
4
L.Ouyang, PSP, Lecture 7 Plan of the lecture IntroductionIntroduction From the previous lectureFrom the previous lecture Effort estimationEffort estimation Multiple estimatesMultiple estimates Schedule estimatingSchedule estimating Progress trackingProgress tracking
5
L.Ouyang, PSP, Lecture 7 From the previous lecture.. Humphrey, CMU, 1995 PROxy-Based Estimating Objects as proxies StandardcomponentmethodFuzzylogicmethod Probemethod
6
L.Ouyang, PSP, Lecture 7 From the previous lecture.. 4. Knowing: programming language object type size ranges the number of methods estimate, using historical data, size of each object.
7
L.Ouyang, PSP, Lecture 7 From the previous lecture.. 6. Apply linear regression to get estimated program size Y: Y = 1 X + 0 5 means 10 5 means 10
8
L.Ouyang, PSP, Lecture 7 From the previous lecture.. 7. Using the t distribution and standard deviation compute the prediction interval for a given percentage. For 100% the For 100% the interval is [0; + ]
9
L.Ouyang, PSP, Lecture 7 From the previous lecture.. (X - x avg ) 2 (x i - x avg ) 2 + 1 n +1 Range = t 7c. Compute the range as follows: Initial estimate obtained in Step 5
10
L.Ouyang, PSP, Lecture 7 Plan of the lecture IntroductionIntroduction From the previous lectureFrom the previous lecture Effort estimationEffort estimation Multiple estimatesMultiple estimates Schedule estimatingSchedule estimating Progress trackingProgress tracking
11
L.Ouyang, PSP, Lecture 7 Effort estimation begin.. end Programs written so far Historical data It should take... man month to finish the project
12
L.Ouyang, PSP, Lecture 7 Effort estimation begin.. end Estimatedsize Actualtime Historical data
13
L.Ouyang, PSP, Lecture 7 Effort estimation begin.. end Estimatedsize Actualtime Historical data r 2 0.5
14
L.Ouyang, PSP, Lecture 7 Effort estimation Estimated size Actual time 1. 0, 1 2. Effort = 1 * Estimated_size + 0 +... 1 n +1 3. Range = t r 2 0.5 4. Effort min = Effort - Range
15
L.Ouyang, PSP, Lecture 7 Effort estimation begin.. end Estimatedsize Actualtime Historical data Lack of data or lack of correlation between estimated size and actual time
16
L.Ouyang, PSP, Lecture 7 Effort estimation begin.. end Actualsize Actualtime Historical data
17
L.Ouyang, PSP, Lecture 7 Effort estimation begin.. end Actualsize Actualtime Historical data r 2 0.5
18
L.Ouyang, PSP, Lecture 7 Effort estimation Actual size Actual time 1. 0, 1 2. Effort = 1 * Estimated_size + 0 +... 1 n +1 3. Range = t r 2 0.5
19
L.Ouyang, PSP, Lecture 7 Effort estimation begin.. end Actualsize Actualtime Historical data Lack of correlation between software size and actual time
20
L.Ouyang, PSP, Lecture 7 Effort estimation Actual size Actual time 1. 2. Effort = Estimated_size / P av time 1 +.. + time 2 size 1 +.. + size 2 P av = 3. P min = min { size i / time i } P max = max { size i / time i } P max = max { size i / time i } 4. Effort min = Estimated_size/P max Effort max = Estimated_size/P min Effort max = Estimated_size/P min
21
L.Ouyang, PSP, Lecture 7 Effort estimation No data about time You have to make a guess Actual size & actual time with r 2 < 0.5 Productivity-based estimation Actual size & actual time with r 2 0.5 Effort estimate + range (inaccurate) Estimated size & actual time with r 2 0.5 Effort estimate + prediction interval
22
L.Ouyang, PSP, Lecture 7 Plan of the lecture IntroductionIntroduction From the previous lectureFrom the previous lecture Effort estimationEffort estimation Multiple estimatesMultiple estimates Schedule estimatingSchedule estimating Progress trackingProgress tracking
23
L.Ouyang, PSP, Lecture 7 Multiple estimates Is the prediction interval [89.8, 195.2] correct?
24
L.Ouyang, PSP, Lecture 7 Multiple estimates 1107.69 32.3 32.3 Range(70%) = 32.3
25
L.Ouyang, PSP, Lecture 7 Multiple estimates Given: time estimates T 1, T 2,.., T n their standard deviations 1, 2,.., n. their standard deviations 1, 2,.., n. T total = T 1 + T 2 +.. + T n total = 1 2 + 2 2 +.. + n 2 T min (70%) = T total - total T max (70%) = T total + total T min (70%) = T total - total T max (70%) = T total + total T min (95%) = T total - 2* total T max (95%) = T total + 2* total T min (95%) = T total - 2* total T max (95%) = T total + 2* total In general:
26
L.Ouyang, PSP, Lecture 7 PROBE-generated predictions Task: Write a class C1: 144 LOC Write a class C2: 193 LOC Write a class C3: 318 LOC S total = 655 LOC S total = 655 LOCTask: Write a class C1: 144 LOC Write a class C2: 193 LOC Write a class C3: 318 LOC S total = 655 LOC S total = 655 LOC 1 = 0.1482 0 = -5.95 = 5.69 2 = (T i - 0 - S i 1 ) 2 / (n-2) T total = 0 + S total * 1 = 91.13 (S total - s avg ) 2 (s i - s avg ) 2 + 1 n + 1 Range = t Range(70%)= 16.3
27
L.Ouyang, PSP, Lecture 7 Plan of the lecture IntroductionIntroduction From the previous lectureFrom the previous lecture Effort estimationEffort estimation Multiple estimatesMultiple estimates Schedule estimatingSchedule estimating Progress trackingProgress tracking
28
L.Ouyang, PSP, Lecture 7 Schedule estimating Size Effort Calendar Schedule Availability factor
29
L.Ouyang, PSP, Lecture 7 Schedule estimating 10 20 30 40 50 60 70 80 90 [h] 10 20 30 40 50 60 70 80 90 [h] 1w2w3w4w5w6w7w Task 1Task 2Task 3
30
L.Ouyang, PSP, Lecture 7 Schedule estimating Project: ColorMap Data: 23.05.1999
31
L.Ouyang, PSP, Lecture 7 Schedule estimating Project: ColorMap Data: 23.05.1999
32
L.Ouyang, PSP, Lecture 7 Plan of the lecture IntroductionIntroduction From the previous lectureFrom the previous lecture Effort estimationEffort estimation Multiple estimatesMultiple estimates Schedule estimatingSchedule estimating Progress trackingProgress tracking
33
L.Ouyang, PSP, Lecture 7 Progress tracking Problem: how to track a progress when a sequence of tasks is rearranged? Earned Value Method: Each task is assigned a number of credit points. Each task is assigned a number of credit points. To earn the points assigned to a task, the task must be completed. To earn the points assigned to a task, the task must be completed. The points reflect ‘time complexity’ and are normalised to 1000 points.The points reflect ‘time complexity’ and are normalised to 1000 points. T1T2 T1T2
34
L.Ouyang, PSP, Lecture 7 Progress tracking Earned Value Method
35
L.Ouyang, PSP, Lecture 7 Progress tracking Project: ColorMap Data: 23.05.1999
36
L.Ouyang, PSP, Lecture 7 Progress tracking Project: ColorMap Data: 23.05.1999
37
L.Ouyang, PSP, Lecture 7 I’ve forgotten about I’ve forgotten about task T j !!! Progress tracking Adjusted EV: New_EV i = x1000 time i time j + time k
38
L.Ouyang, PSP, Lecture 7 Progress tracking Project: ColorMap Data: 23.05.1999
39
L.Ouyang, PSP, Lecture 7 Summary Effort estimation is based on size estimation. Three cases: Best case Middle case Worst case Multiple estimates Schedule estimating Earned Value Method
40
L.Ouyang, PSP, Lecture 7 Further readings W. Humphrey, A Discipline for Software Engineering, Addison- Wesley, Reading, 1995, Chapter 5.
41
L.Ouyang, PSP, Lecture 7 Quality assessment 1. What is your general impression ? (1 - 6) 2. Was it too slow or too fast ? 3. Did you learn something important to you ? 4. What to improve and how ?
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.