CodeHalu: Investigating Code Hallucinations in LLMs via Execution-based Verification
Yuchen Tian, Weixiang Yan, Qian Yang, Xuandong Zhao, Qian Chen, Wen Wang, Ziyang Luo, Lei Ma, Dawn Song
TL;DR
<3-5 sentence high-level summary> The paper defines code hallucination as plausible-looking code that fails to execute correctly or meet task requirements, and argues for execution-based verification to assess code generation. It introduces CodeHalu, a dynamic detection algorithm, and CodeHaluEval, a benchmark to quantify code hallucinations across 17 mainstream LLMs. The approach yields a four-type taxonomy (Mapping, Naming, Resource, Logic) with an 8-subcategory granularity, and demonstrates significant model-to-model variation, especially in logical hallucinations, with overall hallucination rates in the 20–60% range. The work provides a structured framework, benchmark, and actionable guidance for improving code generation reliability through execution-driven verification and targeted data/architecture improvements.
Abstract
Large Language Models (LLMs) have made significant progress in code generation, offering developers groundbreaking automated programming support. However, LLMs often generate code that is syntactically correct and even semantically plausible, but may not execute as expected or fulfill specified requirements. This phenomenon of hallucinations in the code domain has not been systematically explored. To advance the community's understanding and research on this issue, we introduce the concept of code hallucinations and propose a classification method for code hallucination based on execution verification. We categorize code hallucinations into four main types: mapping, naming, resource, and logic hallucinations, with each category further divided into different subcategories to understand and address the unique challenges faced by LLMs in code generation with finer granularity. Additionally, we present a dynamic detection algorithm called CodeHalu designed to detect and quantify code hallucinations. We also introduce the CodeHaluEval benchmark, which includes 8,883 samples from 699 tasks, to systematically and quantitatively evaluate code hallucinations. By evaluating 17 popular LLMs using this benchmark, we reveal significant differences in their accuracy and reliability in code generation, offering detailed insights for further improving the code generation capabilities of LLMs. The CodeHalu benchmark and code are publicly available at https://github.com/yuchen814/CodeHalu.
