Research Area: Evaluation, LMs with tools and code
Keywords: benchmark, programming, llm, code editing
TL;DR: CanItEdit evaluates the instructional code editing capabilities of large language models, reveals a performance gap between open and closed models, and demonstrates that fine-tuning with a new dataset improves performance of open models.
Abstract: A significant amount of research is focused on developing and evaluating
large language models for a variety of code synthesis tasks. These include
synthesizing code from natural language, synthesizing tests from
code, and synthesizing explanations of code. In contrast, the behavior of
instructional code editing with LLMs is understudied.
These are tasks in which the model is provided a block of code and an instruction to modify the code.
The editing instruction may ask for a feature to be added or removed, describe a bug and ask
for a fix, or ask for a different kind of solution.
We introduce a carefully crafted benchmark of code editing tasks and use it
to evaluate several cutting edge LLMs. Our evaluation exposes a significant gap
between the capabilities of state-of-the-art open and closed models. For
example, even GPT-3.5-Turbo is better than the best open model at
code editing tasks. We also introduce a new, carefully curated, permissively licensed training dataset of code editing tasks
coupled with natural language instructions.
Using this training dataset, we show that we can fine-tune open Code LLMs to significantly
improve their code editing capabilities,
closing the gap between open and closed models.
All code, data, and models are available at https://github.com/nuprl/CanItEdit.
Supplementary Material: zip
Code Of Ethics: I acknowledge that I and all co-authors of this work have read and commit to adhering to the COLM Code of Ethics on https://colmweb.org/CoE.html
Author Guide: I certify that this submission complies with the submission instructions as described on https://colmweb.org/AuthorGuide.html
Submission Number: 171
Loading