19th IEEE International Conference on Software Maintenance (ICSM'03)
A Multiple Hill Climbing Approach to Software Module Clustering
Amsterdam, The Netherlands
September 22-September 26
ISBN: 0-7695-1905-9
Automated software module clustering is important for maintenance of legacy systems written in a 'monolithic format' with inadequate module boundaries. Even where systems were originally designed with suitable module boundaries, structure tends to degrade as the system evolves, making re-modularization worthwhile. This paper focuses upon search-based approaches to the automated module clustering problem, where hitherto, the local search approach of hill climbing has been found to be most successful. In the paper we show that results from a set of multiple hill climbs can be combined to locate good 'building blocks' for subsequent searches. Building blocks are formed by identifying the common features in a selection of best hill climbs. This process reduces the search space, while simultaneously 'hard wiring' parts of the solution. The paper reports the results of an empirical study that show that the multiple hill climbing approach does indeed guide the search to higher peaks in subsequent executions. The paper also investigates the relationship between the improved results and the system size.
Index Terms:
Module clustering, Search based software engineering, Hill climbing
Citation:
Kiarash Mahdavi, Mark Harman, Robert Mark Hierons, "A Multiple Hill Climbing Approach to Software Module Clustering," icsm, pp.315, 19th IEEE International Conference on Software Maintenance (ICSM'03), 2003
Usage of this product signifies your acceptance of the
Terms of Use.
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||