TY - JOUR U1 - Zeitschriftenartikel, wissenschaftlich - begutachtet (reviewed) A1 - Oberhauser, Roy T1 - A Hybrid Graph Analysis and Machine Learning Approach Towards Automatic Software Design Pattern Recognition Across Multiple Programming Languages JF - International Journal on Advances in Software N2 - The volume of program source code created, reused, and maintained worldwide is rapidly increasing, yet code comprehension remains a limiting productivity factor. For developers and maintainers, well known common software design patterns and the abstractions they offer can help support program comprehension. However, manual pattern documentation techniques in code and code-related assets such as comments, documents, or models are not necessarily consistent or dependable and are cost-prohibitive. To address this situation, we propose the Hybrid Design Pattern Detection (HyDPD), a generalized approach for detecting patterns that is programming-language-agnostic and combines graph analysis (GA) and Machine Learning (ML) to automate the detection of design patterns via source code analysis. Our realization demonstrates its feasibility. An evaluation compared each technique and their combination for three common patterns across a set of 75 single pattern Java and C# public sample pattern projects. The GA component was also used to detect the 23 Gang of Four design patterns across 258 sample C# and Java projects as well as in a large Java project. Performance and scalability were measured. The results show the advantages and potential of a hybrid approach for combining GA with artificial neural networks (ANN) for automated design pattern detection, providing compensating advantages such as reduced false negatives and improved F1 scores. KW - software design pattern detection KW - machine learning KW - artificial neural networks KW - graph analysis KW - software engineering Y1 - 2022 U6 - https://nbn-resolving.org/urn:nbn:de:bsz:944-opus4-24683 UN - https://nbn-resolving.org/urn:nbn:de:bsz:944-opus4-24683 UR - http://www.iariajournals.org/software/tocv15n12.html SN - 1942-2628 SS - 1942-2628 VL - 15 IS - 1&2 SP - 28 EP - 42 S1 - 16 ER -