Unsupervised Machine Learning for Effective Code Smell Detection: A Novel Method
Abstract
The quality of source code is negatively impacted by code smells. Since the term "code smell" originated, numerous attempts have been made to comprehend it by identifying it using various techniques, such as metric-based, heuristic-based, optimization-based, machine learning (ML)-based, etc. Among these, supervised machine learning (SML) has shown effectiveness in detecting code smells. However, SML techniques have significant limitations, including the dependency on expensive and high-quality labeled data, the need for representative training datasets, and the risk of introducing biases in labeled examples that lead to skewed predictions. To overcome these challenges, this study introduces a method that leverages unsupervised machine learning (UnML) along with feature engineering. Unlike SML, UnML does not require labeled data and minimizes potential biases. The proposed method was evaluated using four datasets containing different types of code smells and was compared with a previous study that used SML techniques. The results indicate that the UnML-based method is effective, achieving outcomes closely aligned with those from the SML approach. This method is especially beneficial in situations where labeled data is scarce or unavailable and can be used to identify new code smells, generate labeled data for SML and detect multiple code smells simultaneously within a codebase.
Keywords
Code Smell, unsupervised machine learning, open-source Java projectsThis work is licensed under a Creative Commons Attribution-NonCommercial 4.0 International License.
R. Gupta, N. Kumar, S. Kumar and J. Kumar Seth, "Unsupervised Machine Learning for Effective Code Smell Detection: A Novel Method," in Journal of Communications Software and Systems, vol. 20, no. 4, pp. 307-316, December 2024, doi: https://doi.org/10.24138/jcomss-2024-0083
@article{gupta2024unsupervisedmachine, author = {Ruchin Gupta and Narendra Kumar and Sunil Kumar and Jitendra Kumar Seth}, title = {Unsupervised Machine Learning for Effective Code Smell Detection: A Novel Method}, journal = {Journal of Communications Software and Systems}, month = {12}, year = {2024}, volume = {20}, number = {4}, pages = {307--316}, doi = {https://doi.org/10.24138/jcomss-2024-0083}, url = {https://doi.org/https://doi.org/10.24138/jcomss-2024-0083} }