1. Software Metric- A definition 2. Types of Software metrics 3. Frame work of product metrics 4. Product metrics.

Slides:



Advertisements
Similar presentations
Software Metrics Software Engineering.
Advertisements

Chapter 4 Software Process and Project Metrics
Chapter 4 Software Process and Project Metrics
These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by.
Process and Project Metrics
These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by.
Metrics for Process and Projects
Metrics for Process and Projects
1 These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 5/e and are provided with permission by.
Software Engineering II - Topic: Software Process Metrics and Project Metrics Instructor: Dr. Jerry Gao San Jose State University
Software Metrics II Speaker: Jerry Gao Ph.D. San Jose State University URL: Sept., 2001.
These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by.
Object-Oriented Metrics
Software Process and Product Metrics
Project Metrics Infsy 570 Dr. R. Ocker.
Chapter 2 The process Process, Methods, and Tools
Chapter 15 Software Product Metrics
1 Software Quality CIS 375 Bruce R. Maxim UM-Dearborn.
Software Engineering Software Process and Project Metrics.
Chapter 6 : Software Metrics
Software Measurement & Metrics
1 Software Engineering: A Practitioner’s Approach, 6/e Chapter 15b: Product Metrics for Software Software Engineering: A Practitioner’s Approach, 6/e Chapter.
Product Metrics An overview. What are metrics? “ A quantitative measure of the degree to which a system, component, or process possesses a given attribute.”
Version control – Project repository, version management capability, make facility, issue/bug tracking Change control Configuration audit – compliments.
1 Chapter 15 Product Metrics for Software Software Engineering: A Practitioner’s Approach, 6th edition by Roger S. Pressman.
Software Project Management Lecture # 3. Outline Chapter 22- “Metrics for Process & Projects”  Measurement  Measures  Metrics  Software Metrics Process.
Software Quality Metrics
Software Metrics – part 2 Mehran Rezaei. Software Metrics Objectives – Provide State-of-art measurement of software products, processes and projects Why.
Lecture 4 Software Metrics
Chapter 3: Software Project Management Metrics
SOFTWARE PROCESS AND PROJECT METRICS. Topic Covered  Metrics in the process and project domains  Process, project and measurement  Process Metrics.
CSc 461/561 Information Systems Engineering Lecture 5 – Software Metrics.
Measurement and quality assessment Framework for product metrics – Measure, measurement, and metrics – Formulation, collection, analysis, interpretation,
1 Software Engineering: A Practitioner’s Approach, 6/e Chapter 15a: Product Metrics for Software Software Engineering: A Practitioner’s Approach, 6/e Chapter.
1 These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 5/e and are provided with permission by.
Hussein Alhashimi. “If you can’t measure it, you can’t manage it” Tom DeMarco,
Advanced Software Engineering Lecture 4: Process & Project Metrics.
Chapter 22 Metrics for Process and Projects Software Engineering: A Practitioner’s Approach 6 th Edition Roger S. Pressman.
Metrics "A science is as mature as its measurement tools."
Software Project Management Lecture # 3. Outline Metrics for Process and Projects  Introduction  Software Metrics Process metrics Project metrics Direct.
These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by.
1 These slides are designed to accompany Software Engineering: A Practitioner’s Approach, 7/e (McGraw-Hill 2009). Slides copyright 2009 by Roger Pressman.
These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by.
Software Engineering Object Oriented Metrics. Objectives 1.To describe the distinguishing characteristics of Object-Oriented Metrics. 2.To introduce metrics.
SPM UNIT 2 - Prof S. S. Deshmukh. Software measurements  Measurement gives us the insight by providing mechanism for evaluation.  There are four reasons.
Software Test Metrics When you can measure what you are speaking about and express it in numbers, you know something about it; but when you cannot measure,
Software Metrics 1.
Chapter 22 Process and Project Metrics
Course Notes Set 12: Object-Oriented Metrics
Design Characteristics and Metrics
Software Engineering (CSI 321)
Lecture 15: Technical Metrics
Object-Oriented Metrics
Software Project Sizing and Cost Estimation
Chapter 30 Product Metrics
Software engineering.
Software Metrics “How do we measure the software?”
Chapter 25 Process and Project Metrics
Software metrics.
Presented by Trey Brumley and Ryan Carter
Chapter 19 Technical Metrics for Software
Process and Project Metrics
Metrics for process and Projects
Chapter 32 Process and Project Metrics
Chapter 22 Process and Project Metrics
Software Engineering: A Practitioner’s Approach, 6/e Chapter 15 Product Metrics for Software copyright © 1996, 2001, 2005 R.S. Pressman & Associates,
Metrics for Process and Projects
6. Software Metrics.
Chapter 8: Design: Characteristics and Metrics
Presentation transcript:

1. Software Metric- A definition 2. Types of Software metrics 3. Frame work of product metrics 4. Product metrics for SDLC a. Metrics: Requirements phase b. Metric for analysis model c. Metric for design model d. Metric for source code e. Metric for Testing f. Metric for Maintenance 5. Types of Software Measurement 6. Software Quality metric 7. Software Metrics cost

A quantitative measure of the degree to which a system, component, or process possesses a given attribute. Measured by: individual module during development Errors should be categorized by origin, type, cost

Measure - quantitative indication of extent, amount, dimension, capacity, or size of some attribute of a product or process. E.g. Number of errors uncovered Measurement- is the act of obtaining a measure E.g. Reviews or unit tests etc. Metric – relates the individual measures in some way E.g. Average number of errors found per review or per unit test Indicator - a metric or combination of metrics that provide insight into the software process, a software project, or the product itself

Processes, Products & Services UnderstandPredictControl Evaluate

Example - M etric: % defects corrected To understand evaluate control predict the attribute of the entity in order to goal(s) evaluate % defects found & corrected during testing Tothe in order to ensure all known defects are corrected before shipment

1.Product metrics quantify characteristics of the product being developed size, reliability 2.Process metrics quantify characteristics of the process being used to develop the software efficiency of fault detection 3.Project metrics Enable a software project manager to assess the status of an ongoing project, track potential risks, uncover problem areas before they go “critical” & evaluate the project team’s ability to control quality of software work products.

Insights of process paradigm, software engineering tasks, work product, or milestones Lead to long term process improvement Private process metrics Private process metrics (e.g. defect rates by individual or module) are known only to the individual or team concerned Public process metrics Public process metrics enable organizations to make strategic changes to improve the software process Statistical software process improvement helps an organization to discover its strengths and weaknesses

Explicit results of software development activities e.g., Deliverables, documentation, by products  Assesses the state of the project  Track potential risks  Uncover problem areas  Adjust workflow or tasks  Evaluate teams ability to control quality

Software project metrics are used by the software team to adapt project workflow and technical activities. Project metrics are used to avoid development schedule delays, to mitigate potential risks, and to assess product quality on an on-going basis. Every project should measure its inputs (resources), outputs (deliverables), and results (effectiveness of deliverables). Application of project metrics on most software projects occurs during estimation.

According to Roche, a measurement process can be characterized by five activities. Formulation 1. Formulation- derivation of s/w measures and metrics Collection- 2. Collection- to accumulate data required to derive formulated metrics. Analysis 3. Analysis- computation of metrics & application of mathematical tools. Interpretation 4. Interpretation- evaluation of metrics to gain insight into the quality of the representation. Feedback 5. Feedback- Recommendations derived from interpretation transmitted to the s/w team.

A set of attributes that should be encompassed by effective software metrics are as follows 1. Simple and Computable 2. Consistent and objective 3. Consistent in the use of units and dimensions 4. Programming language independent 5. An effective mechanism for high quality feedback

Function-Based Metrics Metrics for specification quality

Function points are computed from direct measures of the information domain of a business software application and assessment of its complexity. Once computed function points are used like LOC to normalize measures for software productivity, quality, and other attributes Use a measure of the functionality delivered by the application as a normalization value. The relationship of LOC and function points depends on the language used to implement the software.

Information domain values are defined as follow: 1. No. of external inputs(EIs) 2. No. of external output(EOs) 3. No. of external inquiries(EQs) 4. No. of internal logical files(ILFs) 5. No. of external interface files(EIFs) Compute function point as follows: FP = count-total * [ * Σ(Fi)] The Fi ( i = 1 to 14) are "complexity adjustment values“.

Davis suggested that the qualitative characteristics of s/w quality can be can be represented using one or more metrics. e.g., say there are n r number of requirements in a specification, such that n r = n f + n nf Specificity(lack of ambiguity): Q1 = n ui /n r Completeness: Q2 = n u /n i  n s Overall Completeness: Q3 = n c /n c + n nv

There are five design model for software metrics. 1. Architectural design 2. Object oriented design 3. Class oriented Metrics 4. Component level design 5. Operations oriented design

It focus on characteristic of the program architecture. These metrics are “black box” in the sense that they do not require any knowledge of the inner workings of a particular software component. According to Card & Glass three s/w design complexity measure 1.Structural Complexity 2.Data Complexity 3.System Complexity

1. Structural Complexity 1. Structural Complexity S(i) of a module i. S(i) = f out 2 (i) Fan out is the number of modules immediately subordinate (directly invoked). 2. Data Complexity 2. Data Complexity D(i) D(i) = v(i)/[f out (i)+1] v(i) is the number of inputs and outputs passed to and from i 3. System Complexity 3. System Complexity C(i) C(i) = S(i) + D(i) As each of these complexity values increases the overall complexity of the system also increases Proposed by Card and Glass, 90

Size = n + a Size = n + a n number of nodes a= number of arcs Depth Depth Width Width Arc-to-Node ratio, r = a/n (indicator of coupling) Arc-to-Node ratio, r = a/n (indicator of coupling) Proposed by Fenton, 91

Much about OO design is subjective - a good programmer “knows” what makes good code There are 9 characteristic of an OO design 1.Size 2.Complexity 3.Coupling 4.Sufficiency 5.Completeness 6.Cohesion 7.Primitiveness 8.Similarity 9.Volatility

Chidamber and Kemerer have proposed six class-based design metrics for OO systems. 1. Weighted methods per class (WMC) 2. Depth of the inheritance tree (DIT) 3. Number of children (NOC) 1. Weighted methods per class (WMC) 2. Depth of the inheritance tree (DIT) 3. Number of children (NOC) 4. Coupling between object classes (CBO) 5. Response for a class (RFC) 6. Lack of cohesion in methods (LCOM) 4. Coupling between object classes (CBO) 5. Response for a class (RFC) 6. Lack of cohesion in methods (LCOM)

Component- level design metrics focus on internal characteristics of a software component. It include measures of the “three Cs”- (a.)cohesion metrics (b.)coupling metrics (c.)complexity metrics It is “glass box” in the sense that they require knowledge of inner working of the module under consideration.

Three simple metric, proposed by Lorenz and Kidd 1. Average operation size (LOC, volume) 2. Operation complexity (cyclomatic) 3. Average number of parameters per operation

Halstead assigned quantitative laws to the development of computer s/w, using a set of primitive measures They may be derived after code is generated or estimated once design is complete The measures are : n1 : no. of distinct operators that appear in a program n2 : no. of distinct operands that appear in a program N1 : total no. of operator occurrences N2 : total no. of operand occurrences Halstead uses primitive measures to develop expression for

Program length, potential min. vol. For an algo., actual vol., program level, language level. Halstead shows that length N can be estimated N= n1 log 2 n1 +n2 log 2 n2 And program volume V= N log 2 (n1+n2) Halstead defines a volume ratio L as the ratio of volume of most compact form of a program to the volume of the actual program Volume ratio L= 2/n1 *n2/N2 L= 2/n1 *n2/N2, where L must always be less than 1.

This metrics focus on the process of testing, not the technical characteristic of the tests themselves Function-based metrics can be used as a predictor for overall testing effort Architectural design metrics provide information on the ease or difficulty associated with integration testing Cyclomatic complexity lies at the core of basis path testing Testing metrics fall into two broad categories 1. Metrics that attempt to predict the likely number of tests required at various testing levels 2. Metrics that focus on test coverage for a given component

Testing effort can also be estimated using metrics derived from Halstead measures Program Level(PL) =1/[(n1/2)*(N2/n2)] Halstead effort(e)= Program vol.(V)/PL % of testing effort(k)=e(k)/Σe(i) where e(k) is computed for module k

The OO design metrics provide an indication of design quality. The metrics consider aspects of encapsulation and inheritance. A sampling follows: 1. Lack of cohesion in methods(LCOM) 2. Percent public and protected(PAP) 3. Public access to data members(PAD) 4. Numbers of root classes (NOR) 5. Fan- in(FIN) 6. Number of children(NOC) and depth of the inheritance tree(DIT)

Software maturity index(SMI) that provides an indication of the stability of a software product Software maturity index is computed as SMI = [Mt-(Fa + Fc + Fd)]/Mt where Mt= no. of modules in the current release Fc= no. of modules in the current release that have been change. Fa= no. of modules in the current release that have been added. Fd= no. of modules from the preceding release that were deleted in the current release.

The overriding goal of software engineering is to produce a high- quality system, application, or product. The quality of a system, application, or product is only as good as The requirements that describe the problem The design that models the solution The code that leads to an executable program The tests that exercise the software to uncover errors. To accomplish this real-time quality assessment, the engineer must use technical measures to evaluate quality in objective, rather than subjective, ways.

1. Correctness : 1. Correctness : The degree to which the software performs its required function. Common measure: Defects per KLOC, where a defect is defined as a verified lack of conformance to requirements. 2. Maintainability: 2. Maintainability: The ease with which a program can be corrected if an error is encountered, adapted if its environment changes, or enhanced if the customer desires a change in requirements. A simple time -oriented metric Mean-time -to-change (MTTC), the time it takes to analyze the change request, design an appropriate modification, implement the change, test it, and distribute the change to all users

3. Integrity: 3. Integrity: Measures a system's ability to withstand attacks (both accidental and intentional) on its security. Attacks programs, data, and documents. To measure integrity, two additional attributes must be defined – Threat – Security Threat: The probability that an attack of a specific type will occur within a given time. Security: The probability that the attack of a specific type will be repelled. integrity = Σ [1 - threat x (1 - security)] where threat and security are summed over each type of attack.

4. Usability: 4. Usability: User friendliness. If a program is not "user friendly," it is often doomed to failure, even if the functions that it performs are valuable User friendliness can be measured in terms of four characteristics (i) the physical and/or intellectual skill required to learn the system (ii) the time required to become moderately efficient in the use of the system (iii) the net increase in productivity measured when the system is used by someone who is moderately efficient (iv) a subjective assessment of users attitudes toward the system

A quality metric that provides benefits at both project and process level is defect removal efficiency. DRE is a measure of the filtering ability of quality assurance and control activities as they are applied throughout all process frame work activates. DRE = E / (E + D) where E = number of errors found before delivery of the software to the end user D = number of defects found after delivery The ideal value for DRE is 1. No defects are found in the software Realistically, D will be greater than zero, but the value of DRE can still approach 1 as E increases As E increases it is likely that the final value of D will decrease

DRE can also be used within the project to assess a team's ability to find errors before they are passed to the next framework activity DREi = Ei / (Ei + Ei + 1) where Ei = number of errors found during software engineering activity i. Ei + 1 = number of errors found during software engineering activity i +1 that are traceable to errors that were not discovered in software engineering activity i.

Measure individuals Use metrics as a “stick” Ignore the data Use only one metric Cost Quality Schedule

Select metrics based on goals Goal 1 Goal 2 Question 1Question 2Question 3Question 4 Metrics 1Metric 2Metric 3Metric 4Metric 5 [Basili-88] Focus on processes, products & services Processes, Products & Services Provide feedback Feedback Data Data Providers Metrics Obtain “buy-in”