DocumentCode
2210137
Title
Decomposing object-oriented class modules using an agglomerative clustering technique
Author
Fokaefs, Marios ; Tsantalis, Nikolaos ; Chatzigeorgiou, Alexander ; Sander, Jörg
Author_Institution
Dept. of Comput. Sci., Univ. of Alberta, Edmonton, AB, Canada
fYear
2009
fDate
20-26 Sept. 2009
Firstpage
93
Lastpage
101
Abstract
Software can be considered a live entity, as it undergoes many alterations throughout its lifecycle. Furthermore, developers do not usually retain a good design in favor of adding new features, comply with requirements or meet deadlines. For these reasons, code can become rather complex and difficult to understand. More particularly in object-oriented systems, classes may become very large and less cohesive. In order to identify such problematic cases, existing approaches have proposed the use of cohesion metrics. However, while metrics can identify classes with low cohesion, they cannot identify new or independent concepts. Moreover, these methods require a lot of human interpretation to identify the respective design flaws. In this paper, we propose a class decomposition method using an agglomerative clustering algorithm based on the Jaccard distance between class members. Our methodology is able to identify new concepts and rank the solutions according to their impact on the design quality of the system. Finally, our method has been evaluated by two independent designers who were asked to comment on the suggestions produced by our technique on their projects. The designers provided feedback on the ability of the method to identify new concepts and improve the design quality of the system in terms of cohesion.
Keywords
object-oriented programming; pattern clustering; software engineering; systems analysis; Jaccard distance; agglomerative clustering technique; class decomposition method; class members; object-oriented class module decomposition; system design quality; Clustering algorithms; Clustering methods; Data mining; Feedback; Humans; Informatics; Object oriented programming; Software engineering;
fLanguage
English
Publisher
ieee
Conference_Titel
Software Maintenance, 2009. ICSM 2009. IEEE International Conference on
Conference_Location
Edmonton, AB
ISSN
1063-6773
Print_ISBN
978-1-4244-4897-5
Electronic_ISBN
1063-6773
Type
conf
DOI
10.1109/ICSM.2009.5306332
Filename
5306332
Link To Document