UPDATE: Zenodo migration postponed to Oct 13 from 06:00-08:00 UTC. Read the announcement.

Software documentation Open Access

Language Models and Simple, Stupid Bugs

Kevin Jesse; Toufique Ahmed; Premkumar Devanbu; Emily Morgan

Abstract—With the advent of powerful neural language models, AI-based systems to assist developers in coding tasks are becoming widely available: Copilot is one such system. Copilot uses Codex, a large language model (LLM), to complete code conditioned on a preceding “prompt". Codex, however, is trained on public GitHub repositories, viz., on code that may include bugs and vulnerabilities. Previous studies [1], [2] show Codex reproduces vulnerabilities seen in training. In this study, we examine how prone Codex is to generate an interesting bug category, single statement bugs, commonly referred to as simple, stupid bugs or SStuBs in the MSR community. We find that Codex and similar LLMs do help avoid some SStuBs, but do produce known, verbatim SStuBs as much as 2x as likely thanknown, verbatim correct code. We explore the consequences of the Codex generated SStuBs and propose avoidance strategies that suggest the possibility of reducing the production of known, verbatim SStubs, and increase the possibility of producing known, verbatim fixes.

Files (3.0 GB)
Name Size
msr_sstubs_llms.tar.gz
md5:a1ea6a5c49c9ae58735591fdd160ad5f
3.0 GB Download
112
25
views
downloads
All versions This version
Views 11286
Downloads 2522
Data volume 74.4 GB65.9 GB
Unique views 9877
Unique downloads 2421

Share

Cite as