• 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