Code Execution with Pre-trained Language Models

14Citations
Citations of this article
32Readers
Mendeley users who have this article in their library.
Get full text

Abstract

Code execution is a fundamental aspect of programming language semantics that reflects the exact behavior of the code. However, most pre-trained models for code intelligence ignore the execution trace and only rely on source code and syntactic structures. In this paper, we investigate how well pre-trained models can understand and perform code execution. We develop a mutation-based data augmentation technique to create a large-scale and realistic Python dataset and task for code execution, which challenges existing models such as Codex. We then present CodeExecutor, a Transformer model that leverages code execution pre-training and curriculum learning to enhance its semantic comprehension. We evaluate CodeExecutor on code execution and show its promising performance and limitations. We also demonstrate its potential benefits for code intelligence tasks such as zero-shot code-to-code search and text-to-code generation. Our analysis provides insights into the learning and generalization abilities of pre-trained models for code execution.

Cite

CITATION STYLE

APA

Liu, C., Lu, S., Chen, W., Jiang, D., Svyatkovskiy, A., Fu, S., … Duan, N. (2023). Code Execution with Pre-trained Language Models. In Proceedings of the Annual Meeting of the Association for Computational Linguistics (pp. 4984–4999). Association for Computational Linguistics (ACL). https://doi.org/10.18653/v1/2023.findings-acl.308

Register to see more suggestions

Mendeley helps you to discover research relevant for your work.

Already have an account?

Save time finding and organizing research with Mendeley

Sign up for free