LGAIPLMay 2, 2025

Program Semantic Inequivalence Game with Large Language Models

arXiv:2505.03818v21 citationsh-index: 11
Originality Highly original
AI Analysis

This addresses the challenge of generating training data for LLMs to handle non-trivial program semantics, offering a method to enhance code reasoning in AI systems.

The paper tackles the problem of LLMs failing on complex code reasoning tasks by introducing SInQ, a semi-adversarial game to synthetically generate training data, resulting in improved performance on benchmarks like cross-language vulnerability detection and Python identifier swap tasks.

Large Language Models (LLMs) can achieve strong performance on everyday coding tasks, but they can fail on complex tasks that require non-trivial reasoning about program semantics. Finding training examples to teach LLMs to solve these tasks can be challenging. In this work, we explore a method to synthetically generate code reasoning training data based on a semantic inequivalence game SInQ: a generator agent creates program variants that are semantically distinct, derived from a dataset of real-world programming tasks, while an evaluator agent has to identify input examples that cause the original programs and the generated variants to diverge in their behaviour, with the agents training each other semi-adversarially. We prove that this setup enables theoretically unlimited improvement through self-play in the limit of infinite computational resources. We evaluated our approach on multiple code generation and understanding benchmarks, including cross-language vulnerability detection (Lu et al., 2021), where our method improves vulnerability detection in C/C++ code despite being trained exclusively on Python code, and the challenging Python builtin identifier swap benchmark (Miceli-Barone et al., 2023), showing that whereas modern LLMs still struggle with this benchmark, our approach yields substantial improvements. We release the code needed to replicate the experiments, as well as the generated synthetic data, which can be used to fine-tune LLMs.

Code Implementations1 repo
Foundations

The foundational work for this paper's niche, ranked by how specifically the neighbourhood builds on it — not by global fame.

Your Notes