Documenti di Didattica
Documenti di Professioni
Documenti di Cultura
Delivering:
Agreed functionality
On time
At the agreed cost
With the required quality
2
Difficulties with Estimation
Subjective nature of Estimation
Changing Technologies
Lack of homogeneity project experience
Political implications
3
Estimation
Wrong initial estimations
◦ Lead to exceeding deadlines
Over estimation
Under estimation
Over and under-estimating
An over-estimate is
likely to cause project
to take longer than it
would otherwise
5
Basis for s/w estimation
Top-down
◦ produce overall estimate based on project cost drivers
◦ based on past project data
◦ divide overall estimate between jobs to be done
8
Bottom-up estimating
9
Top-down estimates
Estimate
100 days
Produce overall
overall
project estimate using effort
driver(s)
10
Function Point
Function Count
Alan Albrecht while working for IBM, recognized the
problem in size measurement in the 1970s, and
developed a technique (which he called Function
Point Analysis), which appeared to be a solution to
the size measurement problem.
11
Function Count
12
Function Count
The FPA functional units are shown in figure given below:
User
Inquiries
Other
applications
Inputs ILF
EIF
User
Output ILF: Internal logical files
s System EIF: External interfaces
14
Function Count
(ii) Transactional function types
External Input (EI): An EI processes data or control
information that comes from outside the system. The EI is an
elementary process, which is the smallest unit of activity that
is meaningful to the end user in the business.
External Output (EO): An EO is an elementary process that
generate data or control information to be sent outside the
system.
External Inquiry (EQ): An EQ is an elementary process that is
made up to an input-output combination that results in data
retrieval.
15
Software Project Planning
Weighting factors
Functional Units
Low Average High
External Inputs (EI) 3 4 6
External Output (EO) 4 5 7
External Inquiries (EQ) 3 4 6
Internal logical files (ILF) 7 10 15
External Interface files (EIF) 5 7 10
19
Software Project Planning
Functions points may compute the following important metrics:
Productivity = FP / persons-months
Quality = Defects / FP
Cost = Rupees / FP
Documentation = Pages of documentation per FP
20
Software Project Planning
Example: 4.1
Consider a project with the following functional units:
Number of user inputs = 50
Number of user outputs = 40
Number of user enquiries = 35
Number of user files = 06
Number of external interfaces = 04
Assume all complexity adjustment factors and weighting factors are
average. Compute the function points for the project.
21
22
FP
Solution
We know
5 3
UFP Z ij wij
i 1 J 1
UFP = 50 x 4 + 40 x 5 + 35 x 4 + 6 x 10 + 4 x 7
= 200 + 200 + 140 + 60 + 28 = 628
CAF = (0.65 + 0.01 ΣFi)
= (0.65 + 0.01 (14 x 3)) = 0.65 + 0.42 = 1.07
FP = UFP x CAF
= 628 x 1.07 = 672
Function points Mark II
Developed by Charles R. Symons
‘Software sizing and estimating - Mk II FPA’,
Wiley & Sons, 1991.
Work originally for CCTA:
◦ should be compatible with SSADM; mainly used
in UK
has developed in parallel to IFPUG FPs
23
Function points Mk II
For each
transaction, count
#entities ◦ data items input
accessed (Ni)
◦ data items output
(No)
◦ entity types
#input #output accessed (Ne)
items items
Effort=const1+(size*const2)
25
COCOMO
COCOMO applied to
Semidetached
Organic mode Embedded
mode mode
26
COCOMO81
Based on industry productivity standards -
database is constantly updated
Allows an organization to benchmark its
software development productivity
Basic model
effort = c x sizek
C and k depend on the type of system:
organic, semi-detached, embedded
Size is measured in ‘kloc’ ie. Thousands of lines
of code
27
The COCOMO constants
System type c k
Organic (broadly, 2.4 1.05
information systems)
Semi-detached 3.0 1.12
28
Development effort multipliers
(dem)
According to COCOMO, the major productivity
drivers include:
Product attributes: required reliability, database
size, product complexity
Computer attributes: execution time constraints,
storage constraints, virtual machine (VM) volatility
Personnel attributes: analyst capability, application
experience,VM experience, programming language
experience
Project attributes: modern programming practices,
software tools, schedule constraints
29
Software Project Planning
Multipliers of different cost drivers
Cost Drivers RATINGS
Very low Low Nominal High Very Extra
high high
Product Attributes
30
Software Project Planning
Cost Drivers RATINGS
Very low Low Nominal High Very Extra
high high
Personnel Attributes
1.46 1.19 1.00 0.86 0.71 --
ACAP
1.29 1.13 1.00 0.91 0.82 --
AEXP
1.42 1.17 1.00 0.86 0.70 --
PCAP
1.21 1.10 1.00 0.90 -- --
VEXP
1.14 1.07 1.00 0.95 -- --
LEXP
Project Attributes
1.24 1.10 1.00 0.91 0.82 --
MODP
1.24 1.10 1.00 0.91 0.83 --
TOOL
SCED 1.23 1.08 1.00 1.04 1.10 --
31
Table 5: Multiplier values for effort calculations
32
COCOMOI
D ci ( E ) di
E a i (KLOC) * EAF bi