SlideShare a Scribd company logo
1
Software Metrics
• It refers to a broad range of
quantitative measurements for
computer software that enable to
– improve the software process
continuously
– assist in quality control and productivity
– assess the quality of technical products
– assist in tactical decision-making
By. Dr. B. J. Mohite 9850098225
2
Measure, Metrics, Indicators
• Measure.
– provides a quantitative indication of the
extent, amount, dimension, capacity, or size
of some attributes of a product or process.
• Metrics.
– relates the individual measures in some
way.
• Indicator.
– a combination of metrics that provide insight
into the software process or project or product
itself.
3
What Should Be Measured?
measurement
What do we
use as a
basis?
• size?
• function?
project metrics
process metrics
process
product
product metrics
4
Metrics of Process Improvement
• Focus on Manageable
Repeatable Process
• Use of Statistical SQA
on Process
• Defect Removal
Efficiency
5
Statistical Software Process Improvement
All errors and defects
are categorized by
origin
The cost to correct
each error and defect
is recorded
No. of errors and defects
in each category is
counted and ranked in
descending order
The overall cost in
each category is
computed
Resultant data are
analyzed and the
“culprit” category is
uncovered
Plans are developed
to eliminate the
errors
6
Causes and Origin of Defects
Logic
20%
Sofware Interface
6%
Hardware Interface
8%
User Interface
12%
Data Handling
11%
Error Checking
11%
Standards
7%
Specification
25%
7
Metrics of Project Management
• Budget
• Schedule/ReResource
Management
• Risk Management
• Project goals met or
exceeded
• Customer satisfaction
8
Metrics of the Software Product
• Focus on Deliverable
Quality
• Analysis Products
• Design Product
Complexity – algorithmic,
architectural, data flow
• Code Products
• Production System
9
How Is Quality Measured?
• Analysis Metrics
– Function-based Metrics: Function Points(
Albrecht), Feature Points (C. Jones)
– Bang Metric (DeMarco): Functional Primitives,
Data Elements, Objects, Relationships, States,
Transitions, External Manual Primitives, Input Data
Elements, Output Data Elements, Persistent Data
Elements, Data Tokens, Relationship Connections.
10
Source Lines of Code (SLOC)
• Measures the number of physical lines of
active code
• In general the higher the SLOC in a module
the less understandable and maintainable
the module is
11
Function Oriented Metric -
Function Points
• Function Points are a measure of “how big” is the
program, independently from the actual physical
size of it
• It is a weighted count of several features of the
program
• Dislikers claim FP make no sense wrt the
representational theory of measurement
• There are firms and institutions taking them very
seriously
12
complexity multiplier
function points
number of user inputs
number of user outputs
number of user inquiries
number of files
number of ext.interfaces
measurement parameter
3
4
3
7
5
count
weighting factor
simple avg. complex
4
5
4
10
7
6
7
6
15
10
=
=
=
=
=
count-total
X
X
X
X
X
Analyzing the Information Domain
Assuming all inputs with the same weight, all output with the same weight, …
Complete Formula for the Unadjusted Function Points:
   lesInternalFi terfacesExternalInInquiryOutputInputs
WeiWifWinWoWi
Unadjusted Function Points:
13
Taking Complexity into Account
Factors are rated on a scale of 0 (not important)
to 5 (very important):
data communications
distributed functions
heavily used configuration
transaction rate
on-line data entry
end user efficiency
on-line update
complex processing
installation ease
operational ease
multiple sites
facilitate change
 MultiplierComplexity MultiplierComplexityFCM
Formula:
14
Typical Function-Oriented Metrics
• errors per FP (thousand lines of code)
• defects per FP
• $ per FP
• pages of documentation per FP
• FP per person-month
15
LOC vs. FP
• Relationship between lines of code and
function points depends upon the
programming language that is used to
implement the software and the quality of
the design
• Empirical studies show an approximate
relationship between LOC and FP
16
LOC/FP (average)
Assembly language 320
C 128
COBOL, FORTRAN 106
C++ 64
Visual Basic 32
Smalltalk 22
SQL 12
Graphical languages (icons) 4
17
How Is Quality Measured?
• Design Metrics
– Structural Complexity: fan-in, fan-out, morphology
– System Complexity:
– Data Complexity:
– Component Metrics: Size, Modularity, Localization,
Encapsulation, Information Hiding, Inheritance,
Abstraction, Complexity, Coupling, Cohesion,
Polymorphism
• Implementation Metrics
Size, Complexity, Efficiency, etc.
18
Comment Percentage (CP)
• Number of commented lines of code divided by
the number of non-blank lines of code
• Usually 20% indicates adequate commenting for C
or Fortran code
• The higher the CP value the more maintainable the
module is
19
Size Oriented Metric - Fan In and
Fan Out
• The Fan In of a module is the amount of information
that “enters” the module
• The Fan Out of a module is the amount of
information that “exits” a module
• We assume all the pieces of information with the
same size
• Fan In and Fan Out can be computed for functions,
modules, objects, and also non-code components
• Goal - Low Fan Out for ease of maintenance.
20
Testing Metrics
• Metrics that predict the likely number of
tests required during various testing phases
• Metrics that focus on test coverage for a
given component
21
Views on SE Measurement
22
Views on SE Measurement
23
Views on SE Measurement
24
12 Steps to Useful Software Metrics
Step 1 - Identify Metrics Customers
Step 2 - Target Goals
Step 3 - Ask Questions
Step 4 - Select Metrics
Step 5 - Standardize Definitions
Step 6 - Choose a Model
Step 7 - Establish Counting Criteria
Step 8 - Decide On Decision Criteria
Step 9 - Define Reporting Mechanisms
Step 10 - Determine Additional Qualifiers
Step 11 - Collect Data
Step 12 - Consider Human Factors
25
Step 1 - Identify Metrics
Customers
Who needs the information?
Who’s going to use the metrics?
If the metric does not have a customer --
do not use it.
26
Step 2 - Target Goals
Organizational goals
– Be the low cost provider
– Meet projected revenue targets
Project goals
– Deliver the product by June 1st
– Finish the project within budget
Task goals (entry & exit criteria)
– Effectively inspect software module ABC
– Obtain 100% statement coverage during testing
27
Step 3 - Ask Questions
Goal: Maintain a high level of customer
satisfaction
• What is our current level of customer
satisfaction?
• What attributes of our products and services are
most important to our customers?
• How do we compare with our competition?
28
Step 4 - Select Metrics
Select metrics that provide information
to help answer the questions
• Be practical, realistic, pragmatic
• Consider current engineering environment
• Start with the possible
Metrics don’t solve problems
-- people solve problems
Metrics provide information so people can make
better decisions
29
Selecting Metrics
Goal: Ensure all known defects are corrected
before shipment
•
•
•
•
•
•
•
30
Metrics Objective Statement Template
To
understand
evaluate
control
predict
the
attribute
of the
entity
in order
to
goal(s)
evaluate
% defects
found &
corrected
during
testing
To the
in order
to
ensure all
known defects
are corrected
before
shipment
Example - Metric: % defects corrected
31
Step 5 - Standardize Definitions
Developer User
32
Step 6 - Choose a Measurement
Models for code inspection metrics
• Primitive Measurements:
– Lines of Code Inspected = loc
– Hours Spent Preparing = prep_hrs
– Hours Spent Inspecting = in_hrs
– Discovered Defects = defects
• Other Measurements:
– Preparation Rate = loc / prep_hrs
– Inspection Rate = loc / in_hrs
– Defect Detection Rate = defects / (prep_hrs + in_hrs)
33
Step 7 - Establish Counting
Criteria
Lines of Code
• Variations in counting
• No industry accepted standard
• SEI guideline - check sheets for criteria
• Advice: use a tool
34
Counting Criteria - Effort
What is a Software Project?
• When does it start / stop?
• What activities does it include?
• Who works on it?
35
Step 8 - Decide On Decision Criteria
Establish Baselines
• Current value
– Problem report backlog
– Defect prone modules
• Statistical analysis (mean & distribution)
– Defect density
– Fix response time
– Cycle time
– Variance from budget (e.g., cost, schedule)
36
Step 9 - Define Reporting Mechanisms
Open Fixed Resolved
Jan-97 23 13 3
Feb-97 27 24 11
Mar-97 18 26 15
Apr-97 12 18 27
0
40
80
120
0 20 40 60 80 100 120
0
20
40
60
80
100
1st Qtr 2nd Qtr 3rd Qtr 4th Qtr
1 2 3 4 5 6 7 8 9 10 11 12
0
20
40
60
80
100
Jan Mar May July
0
40
80
120
160
1st Qtr 2nd Qtr 3rd Qtr 4th Qtr
37
Step 10 - Determine Additional
Qualifiers
A good metric is a generic metric
Additional qualifiers:
• Provide demographic information
• Allow detailed analysis at multiple levels
• Define additional data requirements
38
Step 11 – Collect Data
What data to collect?
• Metric primitives
• Additional qualifiers
Who should collect the data?
• The data owner
– Direct access to source of data
– Responsible for generating data
– Owners more likely to detect anomalies
– Eliminates double data entry
39
Examples of Data Ownership
Owner Examples of Data Owned
• Management • Schedule
• Budget
• Engineers • Time spent per task
• Inspection data including defects found
• Root cause of defects
• Testers • Test Cases planned / executed / passed
• Problems
• Test coverage
• Configuration management • Lines of code
specialists • Modules changed
• Users • Problems
• Operation hours
40
Step 12 – Consider Human Factors
The People Side of the Metrics Equation
• How measures affect people
• How people affect measures
“Don’t underestimate the intelligence of your
engineers. For any one metric you can come
up with, they will find at least two ways to
beat it.” [unknown]
41
Don’t
Measure
individuals
Use metrics as
a “stick”
Ignore the data
Use only one
metric
Cost
Quality
Schedule
42
Do
Select metrics
based on goals
Goal 1 Goal 2
Question 1 Question 2 Question 3 Question 4
Metrics 1 Metric 2 Metric 3 Metric 4 Metric 5
[Basili-88]
Focus on processes,
products & services
Processes,
Products &
Services
Provide feedback
Feedback
Data
Data Providers Metrics
Obtain “buy-in”

More Related Content

PPT
Software Metrics
PPT
Software Quality Metrics
PPT
Chapter 15 software product metrics
PPTX
Use case point ( Software Estimation Technique)
PPTX
Software project estimation
PDF
Chapter 5 software design
PPTX
RMMM Plan
PPTX
Software Metrics - Software Engineering
Software Metrics
Software Quality Metrics
Chapter 15 software product metrics
Use case point ( Software Estimation Technique)
Software project estimation
Chapter 5 software design
RMMM Plan
Software Metrics - Software Engineering

What's hot (20)

PPT
Capability Maturity Model
PPT
Software Quality Management
PPTX
Product metrics
PPT
Software documentation
PPTX
Control Flow Testing
PPTX
software project management Artifact set(spm)
PPT
Unit 2 spm
PPT
Planning in Software Projects
PPTX
unit 3 Design 1
PPT
Software Engineering (Risk Management)
PPT
Software architecture design ppt
PPTX
Artifacts
PPT
Software estimation
PPTX
Software project management Software economics
PPT
Planning for software quality assurance lecture 6
PPTX
Software quality assurance
PDF
Rayleigh model
PPTX
Hierarchical models of software quality
PDF
Gathering requirements
PPTX
Phased life cycle model
Capability Maturity Model
Software Quality Management
Product metrics
Software documentation
Control Flow Testing
software project management Artifact set(spm)
Unit 2 spm
Planning in Software Projects
unit 3 Design 1
Software Engineering (Risk Management)
Software architecture design ppt
Artifacts
Software estimation
Software project management Software economics
Planning for software quality assurance lecture 6
Software quality assurance
Rayleigh model
Hierarchical models of software quality
Gathering requirements
Phased life cycle model
Ad

Viewers also liked (20)

PPT
Payback model of risk management by Dr. B. J. Mohite
PPT
Linear programming in market application
PPT
Greedy method by Dr. B. J. Mohite
PDF
Function Point Analysis (FPA) by Dr. B. J. Mohite
DOCX
Pedagogy of science
PPT
Inventory Management
PPT
Operation research complete note
PPTX
PPTX
Queuing theory
PPT
Enterprise Resource Management by Dr. B. J. Mohite
PPT
Design and analysis of Algorithm By Dr. B. J. Mohite
PPTX
Queuing theory
PPT
Sales forecasting techniques
PPTX
Plant location and layout
PPT
Functional Modules of ERP By Dr. B. J. Mohite
PPT
Problem Definition in research design
PDF
Managerial Decision Making by Dr. B. J. Mohite
PPT
Project management cpm-pert
PDF
COCOMO Model By Dr. B. J. Mohite
PPT
Simplex method
Payback model of risk management by Dr. B. J. Mohite
Linear programming in market application
Greedy method by Dr. B. J. Mohite
Function Point Analysis (FPA) by Dr. B. J. Mohite
Pedagogy of science
Inventory Management
Operation research complete note
Queuing theory
Enterprise Resource Management by Dr. B. J. Mohite
Design and analysis of Algorithm By Dr. B. J. Mohite
Queuing theory
Sales forecasting techniques
Plant location and layout
Functional Modules of ERP By Dr. B. J. Mohite
Problem Definition in research design
Managerial Decision Making by Dr. B. J. Mohite
Project management cpm-pert
COCOMO Model By Dr. B. J. Mohite
Simplex method
Ad

Similar to Software metrics by Dr. B. J. Mohite (20)

PPT
Pressman ch-22-process-and-project-metrics
PPT
Software process and project metrics
PPTX
Software_Engineering_Metrics_and_Project_Management.pptx
PPT
Project Matrix and Measuring S/W
PPT
Software Engineering (Metrics for Process and Projects)
PPTX
Software Engineering Software Engineering
PPTX
UNIT4(2) OB UNIT II NOTESOB UNIT II NOTES
PPT
Managing software project, software engineering
PPTX
Process and Project Metrics-1
PDF
Testing Metrics and why Managers like them
PPT
‏‏‏‏chapter 2 Introduction to Information System - نسخة.ppt
PPTX
Day1 1620-1705-maple-pranabendubhattacharyya-131008043643-phpapp02
PPTX
Day 1 1620 - 1705 - maple - pranabendu bhattacharyya
PDF
Doing Analytics Right - Designing and Automating Analytics
PPTX
Unit2 - Metrics.pptx
PDF
software requirement
PDF
Software Quality Dashboard Benchmarking Study
PPT
Trends in-om-scm-27-july-2012-2
PPTX
Software Matrix it's a topic in software quality.pptx
PPTX
Lectureerdjkldfgjkkjkjkjdfgjlmfdgdfgker.pptx
Pressman ch-22-process-and-project-metrics
Software process and project metrics
Software_Engineering_Metrics_and_Project_Management.pptx
Project Matrix and Measuring S/W
Software Engineering (Metrics for Process and Projects)
Software Engineering Software Engineering
UNIT4(2) OB UNIT II NOTESOB UNIT II NOTES
Managing software project, software engineering
Process and Project Metrics-1
Testing Metrics and why Managers like them
‏‏‏‏chapter 2 Introduction to Information System - نسخة.ppt
Day1 1620-1705-maple-pranabendubhattacharyya-131008043643-phpapp02
Day 1 1620 - 1705 - maple - pranabendu bhattacharyya
Doing Analytics Right - Designing and Automating Analytics
Unit2 - Metrics.pptx
software requirement
Software Quality Dashboard Benchmarking Study
Trends in-om-scm-27-july-2012-2
Software Matrix it's a topic in software quality.pptx
Lectureerdjkldfgjkkjkjkjdfgjlmfdgdfgker.pptx

More from Zeal Education Society, Pune (7)

PDF
Knowledge Management System By Dr. B. J. Mohite
PDF
Ms-Project by Dr. B. J. Mohite
PDF
Software Project Management by Dr. B. J. Mohite
PDF
Fundamentals of Organizational Behavior by Dr. B. J. Mohite
PDF
Principles and Practices of Management By Dr. B. J. Mohite
PPT
Queuing Theory by Dr. B. J. Mohite
PPTX
Replacement Theory. by Dr. Babasaheb. J. Mohite
Knowledge Management System By Dr. B. J. Mohite
Ms-Project by Dr. B. J. Mohite
Software Project Management by Dr. B. J. Mohite
Fundamentals of Organizational Behavior by Dr. B. J. Mohite
Principles and Practices of Management By Dr. B. J. Mohite
Queuing Theory by Dr. B. J. Mohite
Replacement Theory. by Dr. Babasaheb. J. Mohite

Recently uploaded (20)

PDF
VCE English Exam - Section C Student Revision Booklet
PPTX
Week 4 Term 3 Study Techniques revisited.pptx
PPTX
Pharma ospi slides which help in ospi learning
PDF
Business Ethics Teaching Materials for college
PDF
grade 11-chemistry_fetena_net_5883.pdf teacher guide for all student
PDF
Basic Mud Logging Guide for educational purpose
PPTX
school management -TNTEU- B.Ed., Semester II Unit 1.pptx
PPTX
BOWEL ELIMINATION FACTORS AFFECTING AND TYPES
PDF
Microbial disease of the cardiovascular and lymphatic systems
PDF
TR - Agricultural Crops Production NC III.pdf
PDF
O5-L3 Freight Transport Ops (International) V1.pdf
PDF
01-Introduction-to-Information-Management.pdf
PDF
Insiders guide to clinical Medicine.pdf
PPTX
The Healthy Child – Unit II | Child Health Nursing I | B.Sc Nursing 5th Semester
PPTX
Cell Types and Its function , kingdom of life
PPTX
Pharmacology of Heart Failure /Pharmacotherapy of CHF
PPTX
PPH.pptx obstetrics and gynecology in nursing
PDF
Chapter 2 Heredity, Prenatal Development, and Birth.pdf
PPTX
Cell Structure & Organelles in detailed.
PDF
Module 4: Burden of Disease Tutorial Slides S2 2025
VCE English Exam - Section C Student Revision Booklet
Week 4 Term 3 Study Techniques revisited.pptx
Pharma ospi slides which help in ospi learning
Business Ethics Teaching Materials for college
grade 11-chemistry_fetena_net_5883.pdf teacher guide for all student
Basic Mud Logging Guide for educational purpose
school management -TNTEU- B.Ed., Semester II Unit 1.pptx
BOWEL ELIMINATION FACTORS AFFECTING AND TYPES
Microbial disease of the cardiovascular and lymphatic systems
TR - Agricultural Crops Production NC III.pdf
O5-L3 Freight Transport Ops (International) V1.pdf
01-Introduction-to-Information-Management.pdf
Insiders guide to clinical Medicine.pdf
The Healthy Child – Unit II | Child Health Nursing I | B.Sc Nursing 5th Semester
Cell Types and Its function , kingdom of life
Pharmacology of Heart Failure /Pharmacotherapy of CHF
PPH.pptx obstetrics and gynecology in nursing
Chapter 2 Heredity, Prenatal Development, and Birth.pdf
Cell Structure & Organelles in detailed.
Module 4: Burden of Disease Tutorial Slides S2 2025

Software metrics by Dr. B. J. Mohite

  • 1. 1 Software Metrics • It refers to a broad range of quantitative measurements for computer software that enable to – improve the software process continuously – assist in quality control and productivity – assess the quality of technical products – assist in tactical decision-making By. Dr. B. J. Mohite 9850098225
  • 2. 2 Measure, Metrics, Indicators • Measure. – provides a quantitative indication of the extent, amount, dimension, capacity, or size of some attributes of a product or process. • Metrics. – relates the individual measures in some way. • Indicator. – a combination of metrics that provide insight into the software process or project or product itself.
  • 3. 3 What Should Be Measured? measurement What do we use as a basis? • size? • function? project metrics process metrics process product product metrics
  • 4. 4 Metrics of Process Improvement • Focus on Manageable Repeatable Process • Use of Statistical SQA on Process • Defect Removal Efficiency
  • 5. 5 Statistical Software Process Improvement All errors and defects are categorized by origin The cost to correct each error and defect is recorded No. of errors and defects in each category is counted and ranked in descending order The overall cost in each category is computed Resultant data are analyzed and the “culprit” category is uncovered Plans are developed to eliminate the errors
  • 6. 6 Causes and Origin of Defects Logic 20% Sofware Interface 6% Hardware Interface 8% User Interface 12% Data Handling 11% Error Checking 11% Standards 7% Specification 25%
  • 7. 7 Metrics of Project Management • Budget • Schedule/ReResource Management • Risk Management • Project goals met or exceeded • Customer satisfaction
  • 8. 8 Metrics of the Software Product • Focus on Deliverable Quality • Analysis Products • Design Product Complexity – algorithmic, architectural, data flow • Code Products • Production System
  • 9. 9 How Is Quality Measured? • Analysis Metrics – Function-based Metrics: Function Points( Albrecht), Feature Points (C. Jones) – Bang Metric (DeMarco): Functional Primitives, Data Elements, Objects, Relationships, States, Transitions, External Manual Primitives, Input Data Elements, Output Data Elements, Persistent Data Elements, Data Tokens, Relationship Connections.
  • 10. 10 Source Lines of Code (SLOC) • Measures the number of physical lines of active code • In general the higher the SLOC in a module the less understandable and maintainable the module is
  • 11. 11 Function Oriented Metric - Function Points • Function Points are a measure of “how big” is the program, independently from the actual physical size of it • It is a weighted count of several features of the program • Dislikers claim FP make no sense wrt the representational theory of measurement • There are firms and institutions taking them very seriously
  • 12. 12 complexity multiplier function points number of user inputs number of user outputs number of user inquiries number of files number of ext.interfaces measurement parameter 3 4 3 7 5 count weighting factor simple avg. complex 4 5 4 10 7 6 7 6 15 10 = = = = = count-total X X X X X Analyzing the Information Domain Assuming all inputs with the same weight, all output with the same weight, … Complete Formula for the Unadjusted Function Points:    lesInternalFi terfacesExternalInInquiryOutputInputs WeiWifWinWoWi Unadjusted Function Points:
  • 13. 13 Taking Complexity into Account Factors are rated on a scale of 0 (not important) to 5 (very important): data communications distributed functions heavily used configuration transaction rate on-line data entry end user efficiency on-line update complex processing installation ease operational ease multiple sites facilitate change  MultiplierComplexity MultiplierComplexityFCM Formula:
  • 14. 14 Typical Function-Oriented Metrics • errors per FP (thousand lines of code) • defects per FP • $ per FP • pages of documentation per FP • FP per person-month
  • 15. 15 LOC vs. FP • Relationship between lines of code and function points depends upon the programming language that is used to implement the software and the quality of the design • Empirical studies show an approximate relationship between LOC and FP
  • 16. 16 LOC/FP (average) Assembly language 320 C 128 COBOL, FORTRAN 106 C++ 64 Visual Basic 32 Smalltalk 22 SQL 12 Graphical languages (icons) 4
  • 17. 17 How Is Quality Measured? • Design Metrics – Structural Complexity: fan-in, fan-out, morphology – System Complexity: – Data Complexity: – Component Metrics: Size, Modularity, Localization, Encapsulation, Information Hiding, Inheritance, Abstraction, Complexity, Coupling, Cohesion, Polymorphism • Implementation Metrics Size, Complexity, Efficiency, etc.
  • 18. 18 Comment Percentage (CP) • Number of commented lines of code divided by the number of non-blank lines of code • Usually 20% indicates adequate commenting for C or Fortran code • The higher the CP value the more maintainable the module is
  • 19. 19 Size Oriented Metric - Fan In and Fan Out • The Fan In of a module is the amount of information that “enters” the module • The Fan Out of a module is the amount of information that “exits” a module • We assume all the pieces of information with the same size • Fan In and Fan Out can be computed for functions, modules, objects, and also non-code components • Goal - Low Fan Out for ease of maintenance.
  • 20. 20 Testing Metrics • Metrics that predict the likely number of tests required during various testing phases • Metrics that focus on test coverage for a given component
  • 21. 21 Views on SE Measurement
  • 22. 22 Views on SE Measurement
  • 23. 23 Views on SE Measurement
  • 24. 24 12 Steps to Useful Software Metrics Step 1 - Identify Metrics Customers Step 2 - Target Goals Step 3 - Ask Questions Step 4 - Select Metrics Step 5 - Standardize Definitions Step 6 - Choose a Model Step 7 - Establish Counting Criteria Step 8 - Decide On Decision Criteria Step 9 - Define Reporting Mechanisms Step 10 - Determine Additional Qualifiers Step 11 - Collect Data Step 12 - Consider Human Factors
  • 25. 25 Step 1 - Identify Metrics Customers Who needs the information? Who’s going to use the metrics? If the metric does not have a customer -- do not use it.
  • 26. 26 Step 2 - Target Goals Organizational goals – Be the low cost provider – Meet projected revenue targets Project goals – Deliver the product by June 1st – Finish the project within budget Task goals (entry & exit criteria) – Effectively inspect software module ABC – Obtain 100% statement coverage during testing
  • 27. 27 Step 3 - Ask Questions Goal: Maintain a high level of customer satisfaction • What is our current level of customer satisfaction? • What attributes of our products and services are most important to our customers? • How do we compare with our competition?
  • 28. 28 Step 4 - Select Metrics Select metrics that provide information to help answer the questions • Be practical, realistic, pragmatic • Consider current engineering environment • Start with the possible Metrics don’t solve problems -- people solve problems Metrics provide information so people can make better decisions
  • 29. 29 Selecting Metrics Goal: Ensure all known defects are corrected before shipment • • • • • • •
  • 30. 30 Metrics Objective Statement Template To understand evaluate control predict the attribute of the entity in order to goal(s) evaluate % defects found & corrected during testing To the in order to ensure all known defects are corrected before shipment Example - Metric: % defects corrected
  • 31. 31 Step 5 - Standardize Definitions Developer User
  • 32. 32 Step 6 - Choose a Measurement Models for code inspection metrics • Primitive Measurements: – Lines of Code Inspected = loc – Hours Spent Preparing = prep_hrs – Hours Spent Inspecting = in_hrs – Discovered Defects = defects • Other Measurements: – Preparation Rate = loc / prep_hrs – Inspection Rate = loc / in_hrs – Defect Detection Rate = defects / (prep_hrs + in_hrs)
  • 33. 33 Step 7 - Establish Counting Criteria Lines of Code • Variations in counting • No industry accepted standard • SEI guideline - check sheets for criteria • Advice: use a tool
  • 34. 34 Counting Criteria - Effort What is a Software Project? • When does it start / stop? • What activities does it include? • Who works on it?
  • 35. 35 Step 8 - Decide On Decision Criteria Establish Baselines • Current value – Problem report backlog – Defect prone modules • Statistical analysis (mean & distribution) – Defect density – Fix response time – Cycle time – Variance from budget (e.g., cost, schedule)
  • 36. 36 Step 9 - Define Reporting Mechanisms Open Fixed Resolved Jan-97 23 13 3 Feb-97 27 24 11 Mar-97 18 26 15 Apr-97 12 18 27 0 40 80 120 0 20 40 60 80 100 120 0 20 40 60 80 100 1st Qtr 2nd Qtr 3rd Qtr 4th Qtr 1 2 3 4 5 6 7 8 9 10 11 12 0 20 40 60 80 100 Jan Mar May July 0 40 80 120 160 1st Qtr 2nd Qtr 3rd Qtr 4th Qtr
  • 37. 37 Step 10 - Determine Additional Qualifiers A good metric is a generic metric Additional qualifiers: • Provide demographic information • Allow detailed analysis at multiple levels • Define additional data requirements
  • 38. 38 Step 11 – Collect Data What data to collect? • Metric primitives • Additional qualifiers Who should collect the data? • The data owner – Direct access to source of data – Responsible for generating data – Owners more likely to detect anomalies – Eliminates double data entry
  • 39. 39 Examples of Data Ownership Owner Examples of Data Owned • Management • Schedule • Budget • Engineers • Time spent per task • Inspection data including defects found • Root cause of defects • Testers • Test Cases planned / executed / passed • Problems • Test coverage • Configuration management • Lines of code specialists • Modules changed • Users • Problems • Operation hours
  • 40. 40 Step 12 – Consider Human Factors The People Side of the Metrics Equation • How measures affect people • How people affect measures “Don’t underestimate the intelligence of your engineers. For any one metric you can come up with, they will find at least two ways to beat it.” [unknown]
  • 41. 41 Don’t Measure individuals Use metrics as a “stick” Ignore the data Use only one metric Cost Quality Schedule
  • 42. 42 Do Select metrics based on goals Goal 1 Goal 2 Question 1 Question 2 Question 3 Question 4 Metrics 1 Metric 2 Metric 3 Metric 4 Metric 5 [Basili-88] Focus on processes, products & services Processes, Products & Services Provide feedback Feedback Data Data Providers Metrics Obtain “buy-in”