Bunch: a clustering tool for the recovery and maintenance of software system structures
- 1 January 1999
- conference paper
- Published by Institute of Electrical and Electronics Engineers (IEEE)
- No. 10636773,p. 50-59
- https://doi.org/10.1109/icsm.1999.792498
Abstract
Software systems are typically modified in order to extend or change their functionality, improve their performance, port them to different platforms, and so on. For developers, it is crucial to understand the structure of a system before attempting to modify it. The structure of a system, however, may not be apparent to new developers, because the design documentation is non-existent or, worse, inconsistent with the implementation. This problem could be alleviated if developers were somehow able to produce high-level system decomposition descriptions from the low-level structures present in the source code. We have developed a clustering tool called Bunch that creates a system decomposition automatically by treating clustering as an optimization problem. The paper describes the extensions made to Bunch in response to feedback we received from users. The most important extension, in terms of the quality of results and execution efficiency, is a feature that enables the integration of designer knowledge about the system structure into an otherwise fully automatic clustering process. We use a case study to show how our new features simplified the task of extracting the subsystem structure of a medium size program, while exposing an interesting design flaw in the process.Keywords
This publication has 12 references indexed in Scilit:
- An intelligent tool for re-engineering software modularityPublished by Institute of Electrical and Electronics Engineers (IEEE) ,2002
- Using automatic clustering to produce high-level system organizations of source codePublished by Institute of Electrical and Electronics Engineers (IEEE) ,2002
- Extracting concepts from file names; a new file clustering criterionPublished by Institute of Electrical and Electronics Engineers (IEEE) ,2002
- Using clustering algorithms in legacy systems remodularizationPublished by Institute of Electrical and Electronics Engineers (IEEE) ,2002
- The Orphan Adoption problem in architecture maintenancePublished by Institute of Electrical and Electronics Engineers (IEEE) ,2002
- A C++ data model supporting reachability analysis and dead code detectionACM SIGSOFT Software Engineering Notes, 1997
- Software reflexion modelsPublished by Association for Computing Machinery (ACM) ,1995
- A technique for drawing directed graphsIEEE Transactions on Software Engineering, 1993
- A reverse‐engineering approach to subsystem structure identificationJournal of Software Maintenance: Research and Practice, 1993
- System partitioning and its measureJournal of Systems and Software, 1981