The Community for Technology Leaders
RSS Icon
Subscribe
Issue No.03 - March (2006 vol.32)
pp: 193-208
ABSTRACT
Since modern software systems are large and complex, appropriate abstractions of their structure are needed to make them more understandable and, thus, easier to maintain. Software clustering techniques are useful to support the creation of these abstractions by producing architectural-level views of a system's structure directly from its source code. This paper examines the Bunch clustering system which, unlike other software clustering tools, uses search techniques to perform clustering. Bunch produces a subsystem decomposition by partitioning a graph of the entities (e.g., classes) and relations (e.g., function calls) in the source code. Bunch uses a fitness function to evaluate the quality of graph partitions and uses search algorithms to find a satisfactory solution. This paper presents a case study to demonstrate how Bunch can be used to create views of the structure of significant software systems. This paper also outlines research to evaluate the software clustering results produced by Bunch.
INDEX TERMS
Clustering, reverse engineering, reengineering, program comprehension, optimization, maintainability.
CITATION
Brian S. Mitchell, Spiros Mancoridis, "On the Automatic Modularization of Software Systems Using the Bunch Tool", IEEE Transactions on Software Engineering, vol.32, no. 3, pp. 193-208, March 2006, doi:10.1109/TSE.2006.31
28 ms
(Ver 2.0)

Marketing Automation Platform Marketing Automation Tool