Function Points
The function point (FP) method calculates an estimate using the parameters of inputs, outputs, inquiries, and files. FP's advantage is that estimators can calculate effort when a defined use case or in-depth system analysis is not available. Estimators calculate function points by summing the number of internal logical files, external interface files, external inputs, external inquiries, and external outputs. Function points are numerical values that measure software size determined from data processing types rather than from software development complexity.
Function Point Analysis (FPA) is a technique used in software development for estimating the size of a software application or system. Allan Albrecht developed the technique in the late 1970s at IBM.
Function points measure the size of the software in terms of the functionality it provides to the users, independently from the technology used to implement it. This is different from other measurement techniques like Lines of Code (LOC), which are technology-dependent.
Here are the basic steps to perform a function point analysis:
Identify and Rate Functions: The software is broken down into five types of functions: External Inputs, External Outputs, External Inquiries, Internal Logical Files, and External Interface Files. Each function type is then assigned a complexity rating (low, average, high) based on its characteristics.
Assign Weights: Each type of function and its complexity level is assigned a weight. The weights typically used are specified in a standard table. These weights were determined empirically by analyzing a large number of projects.
Calculate Unadjusted Function Points: The number of each type of function is multiplied by its corresponding weight to get the function point count for each type. The total of all these counts is the Unadjusted Function Points (UFP).
Calculate Adjusted Function Points: The UFP is then adjusted based on 14 general system characteristics (GSCs) such as data communications, performance, reusability, etc., each rated on a scale of 0 to 5. These ratings are summed to calculate the General System Complexity (GSC), and the UFP is multiplied by a factor derived from the GSC to calculate the Adjusted Function Points (AFP).
The resulting function point count can then be used to estimate effort, cost, and duration of the software project, usually by comparing it to similar projects done in the past.
FPA has the advantage of being independent of technology, so it can be used to compare projects using different languages or tools. It focuses on the features that the user interacts with, so it's more meaningful to non-technical stakeholders than other metrics like LOC. However, it can be time-consuming to perform, especially for large or complex software systems, and it requires expertise to do correctly.