Computing Software Metrics from Design Documents
|
|
- Emmeline Jacobs
- 6 years ago
- Views:
Transcription
1 Computing Software Metrics from Design Documents Cara Stein Computer Science Department University of Alabama in Huntsville Huntsville, AL USA Letha Etzkorn Computer Science Department University of Alabama in Huntsville Huntsville, AL USA Dawn Utley ISEEM Department University of Alabama in Huntsville Huntsville, AL USA ABSTRACT Software metrics can provide an automated way for software practitioners to assess the quality of their software. The earlier in the software development lifecycle this information is available, the more valuable it is, since changes are much more expensive to make later in the lifecycle. Semantic metrics, introduced by Etzkorn and Delugach, assess software according to the meaning of the software s functionality in its domain. This is in contrast to traditional metrics, which use syntax measures to assess code. Because semantic metrics do not rely on the syntax or structure of code, they can be computed from requirements or design specifications before the system has been implemented. This paper focuses on using semantic metrics to assess systems that have not yet been implemented. Categories and Subject Descriptors D.2.8 [Software Engineering]: Metrics complexity measures, process measures, product measures; K.6.3 [Management of Computing and Information Systems]: Software Management software development, software process. General Terms Measurement, Documentation Keywords Design, design document, object-oriented software, semantic metrics 1. INTRODUCTION Estimating the size, effort required, and cost of software to be developed is a difficult problem. Methods such as COCOMO [6] and Function-Point Analysis [1] have been proposed to help with making such estimates, but more information is still needed in order to make accurate estimates. One possible source for such information is software metrics. Permission to make digital or hard copies of all or part of this work for personal or classroom use is granted without fee provided that copies are not made or distributed for profit or commercial advantage and that copies bear this notice and the full citation on the first page. To copy otherwise, or republish, to post on servers or to redistribute to lists, requires prior specific permission and/or a fee. ACMSE 04, April 2 3, 2004, Huntsville, Alabama, USA. Copyright 2004 ACM /04/04 $5.00. Traditional metrics are calculated based on the syntax of code. Examples include McCabe s Cyclomatic Complexity [25] and Chidamber and Kemerer s suite of metrics [8][9]. In contrast, semantic metrics, introduced by Etzkorn and Delugach [14] and expanded by Etzkorn, Gholston, and Hughes [15], are not based on the structure of the code. Semantic metrics are calculated based on the meaning of the code s functionality in the problem domain. Thus, instead of calculating the complexity of an algorithm or the number of paths through a piece of code, semantic metrics calculate the psychological complexity or cohesion of a module. Since semantic metrics do not depend on the structure of the code, they can be calculated from design specifications before the code has been written. This allows project managers and developers an earlier insight into the quality of the design and the potential quality of the eventual software. For instance, if the values of semantic metrics show that a module is very complex or lacks cohesion, the project manager could order a code inspection or redesign of the module. Furthermore, many syntactic metrics have been shown to correlate with aspects of software quality such as fault-proneness and changeability. If semantic metrics also correlate with aspects of software quality, project managers could use values of semantic metrics computed from design specifications in making their estimates of size, effort, and cost for software projects. 2. BACKGROUND 2.1 Semantic Metrics Etzkorn and Delugach [14] introduced a suite of semantic metrics that are calculated based on concepts in a knowledge base that are associated with a class or method. These metrics include: LORM (logical relatedness of methods): the number of relations in a class divided by the number of pairs of methods in the class. Here a relation is defined as a pair of methods x and y in which there is a conceptual relation between a concept that is in method x but not in method y and a concept that is in method y but not in x. CDC (class domain complexity): the sum of the concepts associated with a class, each multiplied by a weighting factor, plus their associated conceptual relations. RCDC (relative class domain complexity): the class s CDC value divided by the maximum CDC value for any class in the system 146
2 KCI (key class identity): 1 if the class s RCDC value is at least.75; 0 otherwise. COa (class overlap): the sum of the concepts in common between two classes, divided by the total number of unique concepts in either class, computed for all classes in the system and divided by the number of classes in the system [14]. 2.2 Design Metrics Although many object-oriented metrics claim to be design metrics, most syntactic metrics can be calculated only on source code. However, Bieman and Kang [5] proposed a new way to assess the cohesion of a module (here, a procedure or function) from the design alone. They defined six types of relationships that could exist between any pair of outputs of a module. These relationships are: Coincidental Relationship (R1): the two outputs do not depend on each other, and they don t depend on any common input Conditional Relationship (R2): the two outputs depend on the same input, and that input is a condition in a branch control structure Iterative Relationship (R3): the two outputs depend on the same input, and that input is a condition in a repetition control structure Communicational Relationship (R4): two outputs depend on the same input, and that input is not a condition in any branch or repetition control structure Sequential Relationship (R5): one output depends on the other Functional Relationship (R6): the module has only one output [5] The strength of the weakest relationship (that is, the one with the lowest number) in the module is the cohesion rating for that module [5]. Although some of these relationships might still be difficult to identify during the design phase, particularly the ones that depend on whether the input is a condition in a control structure, this metric is a step in the right direction for true design metrics. Bieman and Kang also defined three other design-level cohesion metrics. They created input/output dependency graphs (IODGs) of the modules to be analyzed. They defined isolated components to be those that affect only one output of the module; essential components are those that affect or depend on all outputs of the module. In this context, a component is an input or output of a module [5]. From these definitions, their metrics are defined as follows: LC (loose cohesiveness): the number of isolated components divided by the number of components in the module TC (tight cohesiveness): the number of essential components divided by the number of components in the module MC (module cohesiveness): the sum over all components of the connectedness of each component, divided by the number of components in the module [5] Another study of design-level metrics was performed by Bansiya and Davis [3]. This study defines a model called QMOOD, containing four levels to be analyzed in object-oriented design: Components: objects, classes, and relationships Metrics (several new ones) Properties: abstraction, encapsulation, coupling, cohesion, complexity, and size Quality attributes: functionality, effectiveness, understandability, extensibility, reusability, and flexibility [3] Then they created mappings between the levels and used the model to predict the quality of software systems [3]. These approaches are more abstract than the usual method of counting units of code, such as lines, semicolons, or function calls, allowing at least some of them to be performed before implementation. However, metrics that provide the same level of abstraction in the design phase as in the implementation phase would be valuable. 2.3 Metrics Used to Predict Aspects of Software Quality A considerable amount of research has been done into the use of metrics to gauge or predict software quality. Li and Henry [24] assessed their suite of metrics, together with those defined by Chidamber and Kemerer [9], and discovered a strong relationship between the metrics and changeability of code [24]. In another study, Ohlsson and Alberg [26] found that one could predict the fault-proneness of software before it is implemented. They found that using a model of the number of signals plus the number of branches, they identified a set of 20% of the modules; they predicted this set to be the most fault-prone. The modules selected by their model had 47% of the faults in the system. The actual most fault-prone 20% of the modules in the system contained 60% of the faults [26]. This study shows that even simple measures can be used effectively to identify fault-prone modules. More extensive studies were done by Basili, Briand, and Melo [4] and Briand et al. [7]. These studies analyzed existing metrics for their use as predictors of probability of fault. Probability of fault is the likelihood that a fault will be detected in a module during an inspection. Basili, Briand, and Melo analyzed the Chidamber and Kemerer suite [8][9]; Briand et al. analyzed those and others too numerous to mention. Both studies had good results. Basili, Briand, and Melo found that fault probability had significant positive correlation to DIT (depth of inheritance tree), RFC (response for class), and CBO (coupling between objects). They also found a significant negative correlation to NOC (number of children), which they attributed to more design and testing effort being expended on classes on which other classes will be based [4]. Overall, Basili, Briand, and Melo found that the best model for predicting fault probability contained DIT, RFC, and NOC. They compared this model with a set of non-object-oriented code-level metrics and found that the model containing DIT, RFC, and NOC performed better [4]. 147
3 Briand et al. also had promising results. They began with a set of 49 metrics compiled from 12 different sources. Using logistic regression, they found that the best model contained 11 of the original metrics, including Chidamber and Kemerer s RFC (two versions) and NOC [8][9] and a version of Li and Henry s DAC [24]. This model found 95% of the faults in the system, and 85% of the modules it flagged as probably having faults actually had faults [7]. 2.4 Analyzing Design Documents There has not been a concentrated effort regarding automation of design document understanding. However, a few studies have addressed different perspectives on processing design specifications. Lague et al. [18] did a study comparing design documents descriptions of layered architecture systems with the way the source code was organized into files. Their goal was to answer questions such as Does a layer ever use services from a layer above it?, Can a layer be broken down into subsystems?, and Are there any extraneous or missing files? [18]. Using a file dependency graph, they were able to answer these questions. A different study, conducted by Li and Horgan [22], involved analyzing a design specification to check its correctness before using a tool to automatically generate code from it. They developed a tool called XSuds to go through the design specification, generate a flow diagram, and analyze coverage features of the flow diagram. Then the tool would run a simulation of the design specification, collect the flow data from that, and compare the two sets of flow data. The goal of this study was to facilitate round-trip engineering [22]. Lakshminarayana et al. [19] took a different approach to analyzing design specifications. Their goal was to generate visual representations of the metric values for each class in a system, to aid developers in quickly pinpointing areas for improvement. They used Rational Rose s extensibility interface and Rose scripting language to get class information from UML diagrams. Then they computed metrics created by Chidamber and Kemerer [8] and Li [23] using that information. They developed a visual representation for each class based on its value for each metric. They represented each class as a cube and each metric as a feature of that cube as follows: DIT (depth of inheritance tree) [8]: number of layers in the cube represents level in inheritance hierarchy NDC (number of descendent classes) [23]: arrows pointing down represent descendent classes NOC (number of child classes) [8]: red arrows pointing down represent direct child classes NAC (number of ancestor classes) [23]: arrows pointing up represent ancestor classes CTA (coupling through abstract data type) [23]: hooks represent instances of aggregation NLM (number of local methods) [23]: box border is a warmer color for relatively higher numbers of local methods in a class DCTM (design coupling through message passing) [19]: envelopes sticking out of the top of the cube represent messages passed [19] In the resulting model, the visual representation makes it immediately clear which classes have complicated interactions with other classes. This allows developers to analyze a large system much more quickly than they ever could with a standard printout of metric values [19]. This work was expanded in Lakshminarayana [20]. This study is most relevant to the present research because both involve processing design specifications to calculate metrics on classes before they have been implemented. However, whereas Lakshminarayana et al. processed UML diagrams to compute syntactic metrics, we address performing natural language understanding on text in design documents to compute semantic metrics. Overall, the paucity of research on design specification understanding is probably because design documents are written for humans to understand already, so understanding them in the sense of program understanding may not seem important or useful at first glance. However, if design documents were processed to retrieve semantic concepts and keywords at the system, class, and function levels, then semantic metrics could be calculated from design documents. This would allow software quality analysis to be done in the design phase, before the code is written, allowing errors to be corrected earlier in the development. 3. COMPUTING METRICS ON DESIGN SPECIFICATIONS Although many tools exist to compute metrics, most of them calculate only syntactic metrics, and only on code. We have created a tool called semmet to compute semantic metrics on software systems. SemMet is based on parts of Etzkorn s PATRicia (Program Analysis Tool for Reuse) system [11]. In its current form, semmet consists of two parts: the source code interface and the main processing module. The source code interface performs the following steps: Generate abstract syntax tree information from code. Process the abstract syntax tree to retrieve the inheritance hierarchy and each class s attributes and behaviors and their accessibility (public, private, or protected). Process the code itself to retrieve all comments at both class and function levels. Use natural language processing to try to determine the part of speech for each identifier. Perform sentencelevel natural language processing on comments to determine the part of speech of each word. The main processing module performs the following steps: Process all words from comments and identifiers through a knowledge base of concepts and keywords of the domain of the system. Count concepts and keywords related to each class and each method of each class. Use class- and method-level concept and keyword information to calculate metrics and generate a report. These two parts together allow the semmet system to calculate semantic metrics on code. Currently, semmet calculates the semantic metrics proposed by Etzkorn and Delugach [14] and 148
4 Stein et al. [28]. The next step is to modify semmet to calculate semantic metrics from design specifications. Semantic metrics are calculated for code by associating concepts and keywords with classes or functions; the same processing can be done for design documents. Therefore, the same main processing module can be used for both code and design specifications. However, an interface must be created to extract the needed information from design specifications. Although there are many similarities between calculating metrics from a paragraph in a design document and calculating metrics from natural language-based program understanding on comments and identifiers in code, there are also some significant differences. For one thing, comments have been shown to have their own sublanguage of the English language [13]. Paragraphs in design documents probably do not belong to the same sublanguage as comments. Design documents may have their own sublanguage of English, but if they do, it is broader than that of comments, since design documents are written in a much more narrative style. The writing style of design documents is analyzed and criticized, whereas the writing style in comments is usually not. Comments are meant to convey information in the most efficient way possible, since most programmers hate writing comments, whereas design documents have the luxury to be less concise. Furthermore, design documents have a different audience than comments: design documents are meant for the customer and managers as well as developers, whereas comments are meant only for other programmers. Design documents may even be written by a different set of people than comments in code, depending on the size and structure of the organization in which the software is written. All of these factors point to design documents not fitting within the sublanguage of comments. Another difference is that, unlike many comments, design documents are already made up of complete sentences. Thus, for design document processing, it should not be necessary to perform any heuristics to try to make sentences as is done for comments [12]. Also, words in design documents should all be English words, unlike identifiers, which may be abbreviations or several words concatenated together [2][11]. Thus, with the exception of identifiers themselves appearing in design documents, there should be no need to perform any transformations to make the words in design documents into real English words. The other major difference between processing code and processing design documents is that design documents contain larger textual constructs than comments or identifiers. Whereas identifiers and comments are made up of words, or generally no more than a few sentences together, design documents are made up of paragraphs. This means that a much broader context is available within a design document for analysis of any one word or sentence. On one hand, harnessing that additional information has the potential to be very helpful in disambiguation, the process of choosing the correct meaning or structure from among many possibilities for a word or sentence. On the other hand, harnessing that information is a very complex task. When analyzing only one word at a time, one must consider the word s definitions, but when analyzing a word in its context, there are all of the word s definitions, with the words around it and their various definitions taken into consideration, plus the previous and next sentence, plus the whole paragraph and even the whole document. This quickly adds up to an unwieldy number of combinations. Ideally, each level of added context will serve to limit the number of definitions under consideration for a word, but the words and sentences in the context also have multiple meanings each. The process quickly becomes very complicated. To get an idea of the problem, consider the following example. The word throw has different meanings in these phrases: throw up (a ball? one s lunch?), throw away (a ball? trash?), throw out (an idea? trash?), throw (a ball? a pot? a match? a party? one s weight around?) [27]. Beyond the problems of understanding individual phrases, multiple sentences and the context as a whole also present problems. One sentence can impact the meaning of another [29]. To calculate semantic metrics from design specifications, we are creating a new interface to process design specifications compliant with the IEEE standard for design specifications [16]. This interface will extract a class hierarchy and class members from the decomposition description section of the design document. Then it will retrieve prose descriptions of functionality from the detailed description section. For these prose descriptions, paragraph-level natural language processing must be performed. All information gathered by the design specification interface will be passed on to the main processing module for inference through the knowledge base and metrics calculation. Both the code interface and the design specification interface will use the same main processing module to compute metrics. class Account { private: float balance; int type; // 0=savings, 1=checking, //2=money market float interestrate; Entity owner; Bool isactive; public: int makedeposit(float amount); int makewithdrawal(float amount); float getbalance(); void closeaccount(); }; Figure 1: Bank Account Code Example For example, given the code sample in Figure 1, the code interface of the semmet system would pick out concepts and keywords account, balance, interest, rate, owner, active, deposit, amount, withdrawal, balance, and close from the code and checking, savings, money, and money market from the comments. Then it would try to associate parts of speech with these concepts, send them through the knowledge base, and calculate metrics from the results. To process the text description in Figure 2, the design specification interface will associate the Account section with the appropriate class already recognized from the decomposition description section. Then it will perform paragraph-level natural language processing on each paragraph of the text description. The current natural language parser used by the semmet system performs only sentence-level natural language processing. We will incorporate a new, more powerful natural language parser such as 149
5 LT POS [21] or Connexor Machinese Syntax [10] to perform the additional analysis needed. Both of these natural language parsers perform paragraph-level processing. 6.1 Module Detailed Design Class Account The account class represents a bank account. It can be a checking, savings, or money market account. Each account will have a balance and an interest rate, which may be 0%, particularly if the account is a checking account. Each account is owned by an entity, which could be a person, multiple people, or a company. The owner of the account can make deposits, check the balance, and make withdrawals. Figure 2: Bank Account Design Specification Example The design specification interface will associate each section of the detailed description with the proper class or member, perform natural language processing on that section, and send the information to the main processing module. At this point, the information will be in the form of a list of words associated with each class or function. Each word will have a part of speech associated with it if the natural language processor could determine one. The main processing module will then assert the words with their locations into the knowledge base. As inference occurs through the knowledge base, the words taken directly from the design document may trigger other concepts to be recognized and associated with a class or method. Finally, the main processing module will tally the concepts and keywords associated with each class and method, and calculate semantic metrics just as it does for code. 4. CONCLUSION Semantic metrics computed for code or design can indicate relative cohesion, complexity, and coupling of the system s modules. Computing semantic metrics in the design phase, before the code is ever written, can give the development team valuable insight. Managers can use this information in the area of project planning. They can also take preventative measures in modules that are complex or lacking in cohesion, by redesigning or including activities such as code inspections. Cost savings, better delivery date estimation, and code with better design and fewer errors are the potential results. 5. FUTURE WORK Once semantic metrics have been collected for several systems, it is important to validate these metrics for use as intended and to check for relationships with aspects of software quality such as effort, changeability, or fault-proneness. Also, this work could easily be extended to compute semantic metrics on requirements documents. One approach would be to compute semantic metrics for each major function and system requirement from a requirements specification compliant with the IEEE standard for requirements specifications [17]. This information could be used for project planning or compared with semantic metric values computed for the implemented software to assess the degree to which the software matches the requirement specification. 6. ADDITIONAL AUTHORS Additional authors: Phillip Farrington (ISEEM Department, University of Alabama in Huntsville), Glenn Cox (Computer Science Department, University of Alabama in Huntsville), Julie Fortune (ISEEM Department, University of Alabama in Huntsville), and Sampson Gholston (ISEEM Department, University of Alabama in Huntsville). 7. ACKNOWLEDGEMENTS The research in this paper was partially supported by NASA grants NAG and NCC REFERENCES [1] A. Albrecht, J. Gaffney. Software Function, Source lines of code, and development effort Prediction: A software science validation. IEEE Transactions on Software Engineering, vol. SE-9, no. 6, Nov. 1983, pp [2] G. Antoniol, G. Canfora, G. Casazza, A. De Lucia, E. Merlo. Recovering Traceability Links Between Code and Documentation. IEEE Transactions on Software Engineering, vol. 28, no. 10, Oct. 2002, pp [3] J. Bansiya, C. Davis. A Hierarchical Model for Object- Oriented Design Quality Assessment. IEEE Transactions on Software Engineering, vol. 28, no. 1, Jan. 2002, pp [4] V. Basili, L. Briand, W. Melo. A Validation of Object- Oriented Design Metrics as Quality Indicators. IEEE Transactions on Software Engineering, vol. 22, no. 10, Oct. 1996, pp [5] J. Bieman, B.-K. Kang. Measuring Design-Level Cohesion. IEEE Transactions on Software Engineering, vol. 24, no. 2, Feb. 1998, pp [6] B. Boehm. Software Engineering Economics. Englewood Cliffs, NJ: Prentice-Hall, [7] L. Briand, J. Daly, V. Porter, J. Wust. Predicting Fault-Prone Classes with Design Measures in Object-Oriented Systems. Proceedings of the 9 th International Symposium on Software Reliability Engineering, 1998, pp [8] S. Chidamber, C. Kemerer. A Metrics Suite for Object Oriented Design. IEEE Transactions on Software Engineering, vol. 20, no. 6, June 1994, pp [9] S. Chidamber, C. Kemerer. Towards a Metrics Suite for Object Oriented Design. Proceedings of the Conference on Object-Oriented Programming Systems, Languages, and Applications, 1991, pp [10] Connexor. Products > Machinese Syntax. Accessed 9/24/03. [11] L. Etzkorn. A Metrics-Based Approach to the Automated Identification of Object-Oriented Reusable Software Components: a Dissertation. Huntsville, AL: University of Alabama in Huntsville, 1997, pp [12] L. Etzkorn, L. Bowen, C. Davis. An Approach to Program Understanding by Natural Language Understanding. Natural Language Engineering, vol. 5, no. 1, 1999, pp
6 [13] L. Etzkorn, C. Davis, L. Bowen. The Language of Comments in Computer Software: A Sublanguage of English. Journal of Pragmatics, vol. 3, no. 11, 2001, pp [14] L. Etzkorn, H. Delugach. Towards a Semantic Metrics Suite for Object-Oriented Design. Proceedings of the34th International Conference on Technology of Object-Oriented Languages and Systems, 2000, pp [15] L. Etzkorn, S. Gholston, W. Hughes. A Semantic Entropy Metric. Journal of Software Maintenance and Evolution, vol. 14, no. 4, July/August 2002, pp [16] Institute of Electrical and Electronics Engineers. IEEE Recommended Practice for Software Design Descriptions. IEEE Standard New York: IEEE, [17] Institute of Electrical and Electronics Engineers. IEEE Recommended Practice for Software Requirements Specifications. IEEE Standard New York: IEEE, [18] B. Lague, C. Leduc, A. Le Bon, E. Merlo, M. Dagenais. An Analysis Framework for Understanding Layered Software Architectures. Proceedings of the 6 th International Workshop on Program Comprehension, 1998, pp [19] A. Lakshminarayana, T. Newman, W. Li, J. Talburt. Automatic Extraction and Visualization of Object-Oriented Software Design Metrics. Proceedings of SPIE The International Society for Optical Engineering, vol. 3960, 2000, pp [20] A. Lakshminarayana. A Dimensional Reduction Analysis and Glyph-Based Visualization of Object-Oriented Software Metrics: a Thesis. Huntsville, AL: University of Alabama in Huntsville, [21] Language Theory Group. LT POS. Accessed 9/24/03. [22] J. J. Li, J. R. Horgan. A tool suite for Diagnosis and Testing of Software Design Specifications. Proceedings of the International Conference on Dependable Systems and Networking, 2000, pp [23] W. Li. Another metric suite for object-oriented programming. The Journal of Systems and Software, vol. 44, no. 2, 1998, pp [24] W. Li, S. Henry. Object-Oriented Metrics that Predict Maintainability. Journal of Systems Software, vol. 23, no. 2, 1993, pp [25] T. McCabe. A Software Complexity Measure. IEEE Transactions on Software Engineering, vol. SE-2, no. 4, Dec. 1976, pp [26] N. Ohlsson, H. Alberg. Predicting Fault-Prone Software Modules in Telephone Switches. IEEE Transactions on Software Engineering, vol. 22, no. 12, Dec. 1996, pp [27] S. Small, C. Reiger. Parsing and Comprehending with Word Experts (A Theory and its Realization). In Strategies for Natural Language Processing. Edited by Wendy G. Lehnert and Martin H. Ringle. Hillsdale, NJ: Lawrence Erblaum Associates, 1982, pp [28] C. Stein, L. Etzkorn, G. Cox, P. Farrington, S. Gholston, D. Utley, and J. Fortune. A New Suite of Semantic Metrics for Object-Oriented Software. Accepted to 1st International Workshop on Software Audit and Metrics, April 13-14, [29] R. Wilensky. Points: A theory of the Structure of Stories in Memory. In Strategies for Natural Language Processing. Edited by Wendy G. Lehnert and Martin H. Ringle. Hillsdale, NJ: Lawrence Erblaum Associates, 1982, pp
An Object Oriented Runtime Complexity Metric based on Iterative Decision Points
An Object Oriented Runtime Complexity Metric based on Iterative Amr F. Desouky 1, Letha H. Etzkorn 2 1 Computer Science Department, University of Alabama in Huntsville, Huntsville, AL, USA 2 Computer Science
More informationResearch Article ISSN:
Research Article [Agrawal, 1(3): May, 2012] IJESRT INTERNATIONAL JOURNAL OF ENGINEERING SCIENCES & RESEARCH TECHNOLOGY Use Of Software Metrics To Measure And Improve The Quality Of The Software Design
More informationCHAPTER 4 HEURISTICS BASED ON OBJECT ORIENTED METRICS
CHAPTER 4 HEURISTICS BASED ON OBJECT ORIENTED METRICS Design evaluation is most critical activity during software development process. Design heuristics are proposed as a more accessible and informal means
More informationReusability Metrics for Object-Oriented System: An Alternative Approach
Reusability Metrics for Object-Oriented System: An Alternative Approach Parul Gandhi Department of Computer Science & Business Administration Manav Rachna International University Faridabad, 121001, India
More informationProcedia Computer Science
Procedia Computer Science 00 (2009) 000 000 Procedia Computer Science www.elsevier.com/locate/procedia INSODE 2011 Theoretical Analysis for the Impact of Including Special Methods in Lack-of-Cohesion Computation
More informationPrincipal Component Analysis of Lack of Cohesion in Methods (LCOM) metrics
Principal Component Analysis of Lack of Cohesion in Methods (LCOM) metrics Anuradha Lakshminarayana Timothy S.Newman Department of Computer Science University of Alabama in Huntsville Abstract In this
More informationInternational Journal of Software and Web Sciences (IJSWS)
International Association of Scientific Innovation and Research (IASIR) (An Association Unifying the Sciences, Engineering, and Applied Research) ISSN (Print): 2279-0063 ISSN (Online): 2279-0071 International
More informationInvestigation of Metrics for Object-Oriented Design Logical Stability
Investigation of Metrics for Object-Oriented Design Logical Stability Mahmoud O. Elish Department of Computer Science George Mason University Fairfax, VA 22030-4400, USA melish@gmu.edu Abstract As changes
More informationAn Object-Oriented Metrics Suite for Ada 95
An Object-Oriented Metrics Suite for Ada 95 William W. Pritchett IV DCS Corporation 133 Braddock Place Alexandria, VA 22314 73.683.843 x726 wpritche@dcscorp.com 1. ABSTRACT Ada 95 added object-oriented
More informationHOW AND WHEN TO FLATTEN JAVA CLASSES?
HOW AND WHEN TO FLATTEN JAVA CLASSES? Jehad Al Dallal Department of Information Science, P.O. Box 5969, Safat 13060, Kuwait ABSTRACT Improving modularity and reusability are two key objectives in object-oriented
More informationApplication of Object Oriented Metrics to Java and C Sharp: Comparative Study
International Journal of Computer Applications (9 888) Volume 64 No., February Application of Object Oriented Metrics to Java and C Sharp: Comparative Study Arti Chhikara Maharaja Agrasen College,Delhi,India
More informationRisk-based Object Oriented Testing
Risk-based Object Oriented Testing Linda H. Rosenberg, Ph.D. Ruth Stapko Albert Gallo NASA GSFC SATC NASA, Unisys SATC NASA, Unisys Code 302 Code 300.1 Code 300.1 Greenbelt, MD 20771 Greenbelt, MD 20771
More informationTowards Cohesion-based Metrics as Early Quality Indicators of Faulty Classes and Components
2009 International Symposium on Computing, Communication, and Control (ISCCC 2009) Proc.of CSIT vol.1 (2011) (2011) IACSIT Press, Singapore Towards Cohesion-based Metrics as Early Quality Indicators of
More informationFault Prediction OO Systems Using the Conceptual Cohesion of Classes
Fault Prediction OO Systems Using the Conceptual Cohesion of Classes Subba Rao Polamuri, S. Rama Sree, M.Rajababu Dept of Computer Science and Engineering, Aditya Engineering College Surampalem, Kakinada,
More informationTechnical Metrics for OO Systems
Technical Metrics for OO Systems 1 Last time: Metrics Non-technical: about process Technical: about product Size, complexity (cyclomatic, function points) How to use metrics Prioritize work Measure programmer
More information2IS55 Software Evolution. Software metrics (2) Alexander Serebrenik
2IS55 Software Evolution Software metrics (2) Alexander Serebrenik Administration Assignment 5: Deadline: May 22 1-2 students Next week NO CLASS Next class May 15 / SET / W&I 2-5-2012 PAGE 1 Sources /
More informationObject Oriented Measurement
Object Oriented Measurement Diego Chaparro González dchaparro@acm.org Student number: 59881P 17th January 2003 Abstract This document examines the state of art in software products measurement, with focus
More information2IS55 Software Evolution. Software metrics (3) Alexander Serebrenik
2IS55 Software Evolution Software metrics (3) Alexander Serebrenik Sources / SET / W&I 19-3-2013 PAGE 1 From imperative to OO All metrics so far were designed for imperative languages Applicable for OO
More informationMeasuring the quality of UML Designs
Measuring the quality of UML Designs Author: Mr. Mark Micallef (mmica@cs.um.edu.mt) Supervisor: Dr. Ernest Cachia (eacaci@cs.um.edu.mt) Affiliation: University of Malta (www.um.edu.mt) Keywords Software
More informationAn Approach for Quality Control Management in Object Oriented Projects Development
J. Basic. Appl. Sci. Res., 3(1s)539-544, 2013 2013, TextRoad Publication ISSN 2090-4304 Journal of Basic and Applied Scientific Research www.textroad.com An Approach for Quality Control Management in Object
More informationABSTRACT 2. Related Work 1. Introduction 1 NNGT Journal: International Journal of Software Engineering Volume 1 July 30,2014
Maintainability Evaluation of Information Systems Dr Nejmeddine Tagoug College of Computer and Information Systems KSU University Saudi Arabia ntagoug@ksu.edu.sa ABSTRACT The maintenance of existing software
More information1 Introduction. Abstract
An MVC-based Analysis of Object-Oriented System Prototyping for Banking Related GUI Applications Correlationship between OO Metrics and Efforts for Requirement Change Satoru Uehara, Osamu Mizuno, Yumi
More informationTaxonomy Dimensions of Complexity Metrics
96 Int'l Conf. Software Eng. Research and Practice SERP'15 Taxonomy Dimensions of Complexity Metrics Bouchaib Falah 1, Kenneth Magel 2 1 Al Akhawayn University, Ifrane, Morocco, 2 North Dakota State University,
More informationA Study of Software Metrics
International Journal of Computational Engineering & Management, Vol. 11, January 2011 www..org 22 A Study of Software Metrics Gurdev Singh 1, Dilbag Singh 2, Vikram Singh 3 1 Assistant Professor, JIET
More informationStatic Metrics. Feature Brief
SOFTWARE QUALITY ASSURANCE TOOLS & TECHNOLOGY PROFESSIONAL SERVICES ACADEMY P a g e 1 Feature Brief Static Metrics Cantata provides a full and unique suite of intelligent testing capabilities for the efficient
More informationImpact of Dependency Graph in Software Testing
Impact of Dependency Graph in Software Testing Pardeep Kaur 1, Er. Rupinder Singh 2 1 Computer Science Department, Chandigarh University, Gharuan, Punjab 2 Assistant Professor, Computer Science Department,
More informationUsing Metrics To Manage Software Risks. 1. Introduction 2. Software Metrics 3. Case Study: Measuring Maintainability 4. Metrics and Quality
Using Metrics To Manage Software Risks 1. Introduction 2. Software Metrics 3. Case Study: Measuring Maintainability 4. Metrics and Quality 1 1. Introduction Definition Measurement is the process by which
More informationA Comparative Study on State Programming: Hierarchical State Machine (HSM) Pattern and State Pattern
A Comparative Study on State Programming: Hierarchical State Machine (HSM) Pattern and State Pattern A. Cüneyd Tantuğ and Özdemir Kavak Abstract State machines can be implemented by using several methods.
More informationJOURNAL OF OBJECT TECHNOLOGY
JOURNAL OF OBJECT TECHNOLOGY Online at http://www.jot.fm. Published by ETH Zurich, Chair of Software Engineering JOT, 24 Vol. 3, No. 4 (April 24) Special issue: TOOLS USA 23 A Proposal of a New Class Cohesion
More informationSOFTWARE COMPLEXITY MEASUREMENT USING MULTIPLE CRITERIA ABSTRACT
SOFTWARE COMPLEXITY MEASUREMENT USING MULTIPLE CRITERIA Bhaskar Raj Sinha, Pradip Peter Dey, Mohammad Amin and Hassan Badkoobehi National University, School of Engineering, Technology, and Media 3678 Aero
More informationPrediction of Software Readiness Using Neural Network
Prediction of Software Readiness Using Neural Network Jon T.S. Quah, Mie Mie Thet Thwin Abstract-- In this paper, we explore the behaviour of neural network in predicting software readiness. Our neural
More informationEffective Modular Design
CSC40232: SOFTWARE ENGINEERING Professor: Jane Cleland Huang Metrics sarec.nd.edu/courses/se2017 Department of Computer Science and Engineering Effective Modular Design Modular design Reduces complexity
More informationTheoretical Validation of Inheritance Metrics for Object-Oriented Design against Briand s Property
I.J. Information Engineering and Electronic Business, 2014, 3, 28-33 Published Online June 2014 in MECS (http://www.mecs-press.org/) DOI: 10.5815/ijieeb.2014.03.05 Theoretical Validation of Inheritance
More informationSoftware Design & Evolution. Lecture 04. You cannot control what you cannot measure. Metrics & Problem Detection. Michele Lanza
Software Design & Evolution Lecture 04 Michele Lanza Metrics & Problem Detection Metrics? Don t trust them Michele Lanza & Radu Marinescu Object-Oriented Metrics in Practice Using Software Metrics to Characterize,
More informationAn Empirical Study on Object-Oriented Metrics
An Empirical Study on Object-Oriented Metrics Mei-Huei Tang Ming-Hung Kao Mei-Hwa Chen Computer Science Department SUNY at Albany Albany, NY 12222 (meitang, kao, mhc)@cs.albany.edu Abstract The objective
More informationMeasuring Complexity
Measuring Complexity outline why should we measure the complexity of a software system? what might we want to measure? complexity of the source code within a code module between code modules complexity
More informationEmpirical Analysis of the Reusability of Object-Oriented Program Code in Open-Source Software
Empirical Analysis of the Reusability of Object-Oriented Program Code in Open-Source Software Fathi Taibi Abstract Measuring the reusability of Object-Oriented (OO) program code is important to ensure
More informationCHAPTER 3 ROLE OF OBJECT-ORIENTED METRICS IN SOFTWARE MEASUREMENT
CHAPTER 3 ROLE OF OBJECT-ORIENTED METRICS IN SOFTWARE MEASUREMENT 3.1 Introduction 3.2 Object-Oriented Metrics 3.2.1 CK Metrics 3.2.2 Metrics by Li and Henry 3.2.3 Metrics by Li 3.2.4 Metrics by Sharble
More informationA Complete and Comprehensive Metrics Suite for Object-Oriented Design Quality Assessment
, pp.173-188 http://dx.doi.org/10.14257/ijseia.2014.8.2.17 A Complete and Comprehensive Metrics Suite for Object-Oriented Design Quality Assessment K.P. Srinivasan 1 and Dr. T.Devi 2 1 Associate Professor
More informationDETERMINE COHESION AND COUPLING FOR CLASS DIAGRAM THROUGH SLICING TECHNIQUES
IJACE: Volume 4, No. 1, January-June 2012, pp. 19-24 DETERMINE COHESION AND COUPLING FOR CLASS DIAGRAM THROUGH SLICING TECHNIQUES Akhilesh Kumar 1* & Sunint Kaur Khalsa 1 Abstract: High cohesion or module
More informationEffects of Dependency Injection on Maintainability. Kate Razina
Effects of Dependency Injection on Maintainability Kate Razina Overview Introduction Maintainability Dependency Injection Hypothesis Research Measuring Maintainability Data Collection Results Conclusion
More informationArchitectural Design. Architectural Design. Software Architecture. Architectural Models
Architectural Design Architectural Design Chapter 6 Architectural Design: -the design the desig process for identifying: - the subsystems making up a system and - the relationships between the subsystems
More informationApplication of a Fuzzy Inference System to Measure Maintainability of Object-Oriented Software
Application of a Fuzzy Inference System to Measure Maintainability of Object-Oriented Software Nasib Singh Gill and Meenakshi Sharma Department of Computer Science & Applications Maharshi Dayanand University,
More informationIntroduction to software metics
Introduction to software metics Alexander Voigt Version_05_21 Technische Universität Dresden Institut für Kern- und Teilchenphysik /01234/546 78994:!"##$%&'$()*+,%&-,,$)*.$ IKTP Computing Kaffee 12 December
More informationQuality Metrics Tool for Object Oriented Programming
Quality Metrics Tool for Object Oriented Programming Mythili Thirugnanam * and Swathi.J.N. Abstract Metrics measure certain properties of a software system by mapping them to numbers (or to other symbols)
More informationSoftware Metrics and Problem Detection
Software Metrics and Problem Detection Oscar Nierstrasz Yuriy Tymchuk Selected material by Mircea Lungu Roadmap > Software Metrics Size / Complexity Metrics Quality Metrics > Metric-Based Problem Detection
More informationDarshan Institute of Engineering & Technology for Diploma Studies
REQUIREMENTS GATHERING AND ANALYSIS The analyst starts requirement gathering activity by collecting all information that could be useful to develop system. In practice it is very difficult to gather all
More informationDesign and code coupling assessment based on defects prediction. Part 1
Computer Science Journal of Moldova, vol.21, no.2(62), 2013 Design and code coupling assessment based on defects prediction. Part 1 Arwa Abu Asad, Izzat Alsmadi Abstract The article discusses an application
More informationTowards the re-usability of software metric definitions at the meta level
Towards the re-usability of software metric definitions at the meta level - Position Paper - Jacqueline A. McQuillan and James F. Power Department of Computer Science, National University of Ireland, Maynooth,
More informationPerformace Evaluation In Object Oriented Metrics
Performace Evaluation In Object Oriented Metrics Mr. S. Pasupathy 1 and Dr. R. Bhavani 2 1 Associate Professor, Dept. of CSE, FEAT, Annamalai University, Tamil Nadu, India. 2 Professor, Dept. of CSE, FEAT,
More informationIntroduction to Extended Common Coupling with an Application Study on Linux
Introduction to Extended Common Coupling with an Application Study on Linux Liguo Yu Computer Science and Informatics Indiana University South Bend 1700 Mishawaka Ave. P.O. Box 7111 South Bend, IN 46634,
More informationSoftware Design Fundamentals. CSCE Lecture 11-09/27/2016
Software Design Fundamentals CSCE 740 - Lecture 11-09/27/2016 Today s Goals Define design Introduce the design process Overview of design criteria What results in a good design? Gregory Gay CSCE 740 -
More informationSNS College of Technology, Coimbatore, India
Support Vector Machine: An efficient classifier for Method Level Bug Prediction using Information Gain 1 M.Vaijayanthi and 2 M. Nithya, 1,2 Assistant Professor, Department of Computer Science and Engineering,
More informationIMPACT OF DEPENDENCY GRAPH IN SOFTWARE TESTING
IMPACT OF DEPENDENCY GRAPH IN SOFTWARE TESTING Pardeep kaur 1 and Er. Rupinder Singh 2 1 Research Scholar, Dept. of Computer Science and Engineering, Chandigarh University, Gharuan, India (Email: Pardeepdharni664@gmail.com)
More informationVragen. Intra-modular complexity measures. The uses relation. System structure: inter-module complexity
Vragen Intra-modular complexity measures Wat wordt bedoeld met het ontwerpsprincipe: Anticipate obsolence? Wat is het voordeel van strong cohesion en weak coupling? Wat is het gevolg van hoge complexiteit
More informationEmpirical Evaluation and Critical Review of Complexity Metrics for Software Components
Proceedings of the 6th WSEAS Int. Conf. on Software Engineering, Parallel and Distributed Systems, Corfu Island, Greece, February 16-19, 2007 24 Empirical Evaluation and Critical Review of Complexity Metrics
More informationAn Efficient Methodology for Developing and Maintaining Consistent Software Using OOAD Tools
An Efficient Methodology for Developing and Maintaining Consistent Software Using OOAD Tools S. Pasupathy 1, Dr. R. Bhavani 2 Associate Professor, Dept. of CSE, FEAT, Annamalai University, Tamil Nadu,
More informationInheritance Metrics: What do they Measure?
Inheritance Metrics: What do they Measure? G. Sri Krishna and Rushikesh K. Joshi Department of Computer Science and Engineering Indian Institute of Technology Bombay Mumbai, 400 076, India Email:{srikrishna,rkj}@cse.iitb.ac.in
More informationSoftware Metrics and Design Principles. What is Design?
Software Metrics and Design Principles Chapters 5,8 What is Design? Design is the process of creating a plan or blueprint to follow during actual construction Design is a problem-solving activity that
More informationMetrics and OO. SE 3S03 - Tutorial 12. Alicia Marinache. Week of Apr 04, Department of Computer Science McMaster University
and OO OO and OO SE 3S03 - Tutorial 12 Department of Computer Science McMaster University Complexity Lorenz CK Week of Apr 04, 2016 Acknowledgments: The material of these slides is based on [1] (chapter
More informationChapter 1: Principles of Programming and Software Engineering
Chapter 1: Principles of Programming and Software Engineering Data Abstraction & Problem Solving with C++ Fifth Edition by Frank M. Carrano Software Engineering and Object-Oriented Design Coding without
More informationReport and Opinion 2014;6(10) Measurement Of Software Complexity In Object Oriented Systems Abstract
Measurement Of Software Complexity In Object Oriented Systems Abstract Hari Om Sharan 1, Garima 1, Md. Haroon 1, and Rajeev Kumar 2 1 Deptt. of Computer Science, COE, Teerthankar Mahaveer University, Moradabad,
More informationToward a definition of run-time object-oriented metrics
7TH ECOOP WORKSHOP ON QUANTITATIVE APPROACHES IN OBJECT-ORIENTED SOFTWARE ENGINEERING 200 1 Toward a definition of run-time object-oriented metrics - Position Paper - Aine Mitchell, James F. Power Abstract
More informationEnhancing Mood Metrics Using Encapsulation
Proceedings of the 8th WSEAS International Conference on Automation and Information, Vancouver, Canada, June 9-2, 2007 252 Enhancing Mood Metrics Using Encapsulation SUNINT SAINI, MEHAK AGGARWAL Department
More informationKeywords: Abstract Factory, Singleton, Factory Method, Prototype, Builder, Composite, Flyweight, Decorator.
Comparative Study In Utilization Of Creational And Structural Design Patterns In Solving Design Problems K.Wseem Abrar M.Tech., Student, Dept. of CSE, Amina Institute of Technology, Shamirpet, Hyderabad
More informationAnalysis of Reusability of Object-Oriented System using CK Metrics
Analysis of Reusability of Object-Oriented System using CK Metrics Brij Mohan Goel Research Scholar, Deptt. of CSE SGVU, Jaipur-302025, India Pradeep Kumar Bhatia Deptt. of CSE., G J University of Science
More informationDmesure: a readability platform for French as a foreign language
Dmesure: a readability platform for French as a foreign language Thomas François 1, 2 and Hubert Naets 2 (1) Aspirant F.N.R.S. (2) CENTAL, Université Catholique de Louvain Presentation at CLIN 21 February
More informationComplexity Metrics for Cascading Style Sheets
Complexity Metrics for Cascading Style Sheets Adewole Adewumi 1, Sanjay Misra 2, and Nicholas Ikhu-Omoregbe 1 1 Department of Computer and Information Sciences, Covenant University, Nigeria 2 Department
More informationAbstract: Refactorings are used to improve the internal structure of software without changing its external behavior.
Refactoring: Risks and its Effects on Software Quality Attribute Ramesh Kumar, Dr.Rajesh Verma Research Scholar, Department of Computer Science, Singhania University, Rajasthan. Asst. Professor, Department
More informationEnhancing Object Oriented Coupling Metrics w.r.t. Connectivity Patterns
Enhancing Object Oriented Coupling Metrics w.r.t. Connectivity Patterns Thesis submitted in partial fulfillment of the requirements for the award of degree of Master of Engineering in Software Engineering
More informationLecture Chapter 2 Software Development
Lecture Chapter 2 Software Development Large Software Projects Software Design o Team of programmers o Cost effective development Organization Communication Problem Solving Analysis of the problem Multiple
More informationCS SOFTWARE ENGINEERING QUESTION BANK SIXTEEN MARKS
DEPARTMENT OF COMPUTER SCIENCE AND ENGINEERING CS 6403 - SOFTWARE ENGINEERING QUESTION BANK SIXTEEN MARKS 1. Explain iterative waterfall and spiral model for software life cycle and various activities
More informationA Hierarchical Model for Object- Oriented Design Quality Assessment
A Hierarchical Model for Object- Oriented Design Quality Assessment IEEE Transactions on Software Engineering (2002) Jagdish Bansiya and Carl G. Davis 2013-08-22 Yoo Jin Lim Contents Introduction Background
More informationBy: Eng. Mohammed T. Abo Alroos
By: Eng. Mohammed T. Abo Alroos Use Case Points The formula for calculating UCP is composed of three variables: 1. Unadjusted Use Case Points (UUCP), which measures the complexity of the functional requirements
More informationDescribing the architecture: Creating and Using Architectural Description Languages (ADLs): What are the attributes and R-forms?
Describing the architecture: Creating and Using Architectural Description Languages (ADLs): What are the attributes and R-forms? CIS 8690 Enterprise Architectures Duane Truex, 2013 Cognitive Map of 8090
More informationAn Empirical Verification of Software Artifacts Using Software Metrics
An Empirical Verification of Software Artifacts Using Software Metrics Raed Shatnawi and Ahmad Alzu bi Abstract In model-driven development, design understandability is very important to maintain software
More informationOn the Applicability of Predictive Maintainability Models onto dynamic Languages
On the Applicability of Predictive Maintainability Models onto dynamic Languages Miguel Lopez 1, Naji Habra 2, Grégory Seront 1 1 CETIC asbl Rue Clément Ader, 8 B-6041 Gosselies, Belgium malm@cetic.be,,
More informationHarmonization of usability measurements in ISO9126 software engineering standards
Harmonization of usability measurements in ISO9126 software engineering standards Laila Cheikhi, Alain Abran and Witold Suryn École de Technologie Supérieure, 1100 Notre-Dame Ouest, Montréal, Canada laila.cheikhi.1@ens.etsmtl.ca,
More informationObject Oriented Design Metrics for Predicting Fault Proneness using Naïve Bayes and Random Forest
Proc. of Int. Conf. on Advances in Communication, Network, and Computing, CNC Object Oriented Design Metrics for Predicting Fault Proneness using Naïve Bayes and Random Forest Vaishnavi.J 1, Anousouya
More informationEffectiveness of software metrics for object-oriented system
Available online at www.sciencedirect.com Procedia Technology 6 (2012 ) 420 427 2nd International Conference on Communication, Computing & Security [ICCCS-2012] Effectiveness of software metrics for object-oriented
More informationSE 2730 Final Review
SE 2730 Final Review 1. Introduction 1) What is software: programs, associated documentations and data 2) Three types of software products: generic, custom, semi-custom Why is semi-custom product more
More informationFault-Proneness Estimation and Java Migration: A Preliminary Case Study
Fault-Proneness Estimation and Java Migration: A Preliminary Case Study Mirco Bianco, Daniel Kaneider, Alberto Sillitti, and Giancarlo Succi Center for Applied Software Engineering, Free University of
More informationHow do we measure product and project progress?? Why is software incomparable to traditional quality of manufactured goods?
Metrics How do we measure product and project progress?? 1 Why is software incomparable to traditional quality of manufactured goods? Software is intangible and has no physical presence Software is a recent
More informationAnalysis of Cohesion and Coupling Metrics for Object Oriented System
2016 IJSRSET Volume 2 Issue 2 Print ISSN : 2395-1990 Online ISSN : 2394-4099 Themed Section: Engineering and Technology Analysis of Cohesion and Coupling Metrics for Object Oriented System Annushri Sethi
More informationThe Software Design Process. CSCE 315 Programming Studio, Fall 2017 Tanzir Ahmed
The Software Design Process CSCE 315 Programming Studio, Fall 2017 Tanzir Ahmed Outline Challenges in Design Design Concepts Heuristics Practices Challenges in Design A problem that can only be defined
More informationRecovering Traceability Links between Code and Documentation
Recovering Traceability Links between Code and Documentation Paper by: Giuliano Antoniol, Gerardo Canfora, Gerardo Casazza, Andrea De Lucia, and Ettore Merlo Presentation by: Brice Dobry and Geoff Gerfin
More informationA Metric-based Approach for Reconstructing Methods in Object-Oriented Systems
A Metric-based Approach for Reconstructing Methods in Object-Oriented Systems Tatsuya Miyake Yoshiki Higo Katsuro Inoue Graduate School of Information Science and Technology, Osaka University {t-miyake,higo,inoue@istosaka-uacjp
More informationEffect of Principle Component Analysis and Support Vector Machine in Software Fault Prediction
International Journal of Computer Trends and Technology (IJCTT) volume 7 number 3 Jan 2014 Effect of Principle Component Analysis and Support Vector Machine in Software Fault Prediction A. Shanthini 1,
More informationDesignMinders: A Design Knowledge Collaboration Approach
DesignMinders: A Design Knowledge Collaboration Approach Gerald Bortis and André van der Hoek University of California, Irvine Department of Informatics Irvine, CA 92697-3440 {gbortis, andre}@ics.uci.edu
More informationInfluence of Design Patterns Application on Quality of IT Solutions
Influence of Design Patterns Application on Quality of IT Solutions NADINA ZAIMOVIC, DZENANA DONKO Department for Computer Science and Informatics Faculty of Electrical Engineering, University of Sarajevo
More informationHigh Precision Cohesion Metric
High Precision Cohesion Metric N. KAYARVIZHY 1, S. KANMANI 2, R.V. UTHARIARAJ 3 1 Assistant Professor, Department of Computer Science and Engineering AMC Engineering College 12 th K.M., Bannerghatta Road,
More informationMeasuring Cohesion and Coupling of Object-Oriented Systems
Master Thesis Software Engineering Thesis no: MSE-2004:29 Month: August Year: 2004 Measuring Cohesion and Coupling of Object-Oriented Systems - Derivation and Mutual Study of Cohesion and Coupling Imran
More informationOn the Impact of Refactoring Operations on Code Quality Metrics
On the Impact of Refactoring Operations on Code Quality Metrics Oscar Chaparro 1, Gabriele Bavota 2, Andrian Marcus 1, Massimiliano Di Penta 2 1 University of Texas at Dallas, Richardson, TX 75080, USA
More informationAnalysis of Various Software Metrics Used To Detect Bad Smells
The International Journal Of Engineering And Science (IJES) Volume 5 Issue 6 Pages PP -14-20 2016 ISSN (e): 2319 1813 ISSN (p): 2319 1805 Analysis of Various Software Metrics Used To Detect Bad Smells
More informationObject Relationships
Object Relationships Objects can work together in three different types of relationships: Uses: An object can use another to do some work (association). Composition: A complex object may be composed of
More informationEVALUATING IMPACT OF INHERITANCE ON OBJECT ORIENTED SOFTWARE METRICS
CHAPTER-4 EVALUATING IMPACT OF INHERITANCE ON OBJECT ORIENTED SOFTWARE METRICS 4.1 Introduction Software metrics are essential to software engineering for measuring software complexity and quality, estimating
More informationSoftware Quality Estimation through Object Oriented Design Metrics
100 Software Quality Estimation through Object Oriented Design Metrics Deepak Arora, Pooja Khanna and Alpika Tripathi, Shipra Sharma and Sanchika Shukla Faculty of Engineering, Department of Computer Science,
More informationMeasuring Web Service Interfaces
Measuring Web Service Interfaces Harry M. Sneed ANECON GmbH, Vienna Harry.Sneed@t-online.de Abstract The following short paper describes a tool supported method for measuring web service interfaces. The
More informationISSN: ISO 9001:2008 Certified International Journal of Engineering and Innovative Technology (IJEIT) Volume 3, Issue 11, May 2014
Coupling Appraisal in Object-Oriented Systems Priya Nigam, Rachna Mishra Department of Computer Science & Engg. Abstract The metrics "Coupling is a quantification of interdependence of two objects. Coupling
More informationCan Complexity, Coupling, and Cohesion Metrics be Used as Early Indicators of Vulnerabilities?
Can Complexity, Coupling, and Cohesion Metrics be Used as Early Indicators of Vulnerabilities? Istehad Chowdhury Dept. of Electrical & Computer Eng. Queen s University, Kingston Ontario, Canada, K7L3N6
More information