The adverse effects of code duplication in machine learning models of code

M Allamanis - Proceedings of the 2019 ACM SIGPLAN International …, 2019 - dl.acm.org
Proceedings of the 2019 ACM SIGPLAN International Symposium on New Ideas …, 2019dl.acm.org
The field of big code relies on mining large corpora of code to perform some learning task
towards creating better tools for software engineers. A significant threat to this approach was
recently identified by Lopes et al.(2017) who found a large amount of near-duplicate code
on GitHub. However, the impact of code duplication has not been noticed by researchers
devising machine learning models for source code. In this work, we explore the effects of
code duplication on machine learning models showing that reported performance metrics …
The field of big code relies on mining large corpora of code to perform some learning task towards creating better tools for software engineers. A significant threat to this approach was recently identified by Lopes et al. (2017) who found a large amount of near-duplicate code on GitHub. However, the impact of code duplication has not been noticed by researchers devising machine learning models for source code. In this work, we explore the effects of code duplication on machine learning models showing that reported performance metrics are sometimes inflated by up to 100% when testing on duplicated code corpora compared to the performance on de-duplicated corpora which more accurately represent how machine learning models of code are used by software engineers. We present a duplication index for widely used datasets, list best practices for collecting code corpora and evaluating machine learning models on them. Finally, we release tools to help the community avoid this problem in future research.
ACM Digital Library