PLSemanticsBench: Large Language Models As Programming Language Interpreters
Aditya Thimmaiah, Jiyang Zhang, Jayanth Srinivasa, Junyi Jessy Li, Milos Gligoric
TL;DR
PLSemanticsBench investigates whether large language models can act as interpreters for an imperative language by executing programs according to formal SOS and K-semantics. The authors construct three dataset splits—Human-Written, LLM-Translated, and Fuzzer-Generated—and evaluate 11 state-of-the-art LLMs on three tasks: final-state prediction, semantic-rule prediction, and execution-trace prediction, under standard and two nonstandard semantics. They find that models are generally capable under standard semantics but degrade when faced with semantic mutations, with reasoning models performing better on coarse tasks but struggling on fine-grained ones; execution-trace prediction remains particularly challenging. The work underscores both the promise of LLMs for rapid language prototyping and the need for explicit semantic understanding, and it contributes a new benchmark and codebase to foster progress in semantics-aware AI for programming languages.
Abstract
As large language models (LLMs) excel at code reasoning, a natural question arises: can an LLM execute programs (i.e., act as an interpreter) purely based on a programming language's formal semantics? If so, it will enable rapid prototyping of new programming languages and language features. We study this question using the imperative language IMP (a subset of C), formalized via small-step operational semantics (SOS) and rewriting-based operational semantics (K-semantics). We introduce three evaluation sets-Human-Written, LLM-Translated, and Fuzzer- Generated-whose difficulty is controlled by code-complexity metrics spanning the size, control-flow, and data-flow axes. Given a program and its semantics formalized with SOS/K-semantics, models are evaluated on three tasks ranging from coarse to fine: (1) final-state prediction, (2) semantic rule prediction, and (3) execution trace prediction. To distinguish pretraining memorization from semantic competence, we define two nonstandard semantics obtained through systematic mutations of the standard rules. Across strong code/reasoning LLMs, performance drops under nonstandard semantics despite high performance under the standard one. We further find that (i) there are patterns to different model failures, (ii) most reasoning models perform exceptionally well on coarse grained tasks involving reasoning about highly complex programs often containing nested loop depths beyond five, and surprisingly, (iii) providing formal semantics helps on simple programs but often hurts on more complex ones. Overall, the results show a promise that LLMs could serve as programming language interpreters, but points to the lack of their robust semantics understanding. We release the benchmark and the supporting code at https://github.com/EngineeringSoftware/PLSemanticsBench.
