SpecEval: A Novel Black-Box Evaluation Framework to Evaluate Code Comprehension in LLMs via Program Specifications

Posted by:

|

On:

|

As LLMs become more prevalent in software development, it’s crucial to ensure they can accurately understand, generate, and manipulate code. It can also help determine the suitability of LLMs for real-world applications, such as automated code generation, software testing, and code optimization. Current evaluation frameworks, such as CRUXEval and REval, focus primarily on code reasoning tasks. Still, they need to capture the entire range of execution traces required to assess code comprehension fully. This leads to an incomplete or biased evaluation of LLMs, as these methods do not consider all possible semantic variations in the code. 

Researchers from Nanyang Technological University, Singapore, and Nanjing University, China, addressed the challenge of accurately evaluating the code comprehension capabilities of Large Language Models (LLMs). The researchers proposed SpecEval, a black-box evaluation framework designed to evaluate LLMs’ understanding of program semantics through formal specifications. These formal specifications provide a comprehensive representation of program behavior across all possible execution paths, offering a more holistic approach to evaluation.

SpecEval’s methodology revolves around four key tasks: Specification Correctness Judgement, Specification Candidates Selection, Specification Infilling, and Specification Generation. By focusing on these tasks, the framework aims to assess LLMs’ ability to comprehend and generate code that adheres to formal specifications, ensuring that LLMs are evaluated not only on their code generation capabilities but also on their deeper understanding of the code’s semantics.

The core of SpecEval’s evaluation framework is its use of formalized program specifications, which precisely articulate a program’s behavior. This formal approach ensures that every possible execution trace of a program is considered, allowing for a more comprehensive evaluation. To test the robustness of LLMs, the framework introduces semantic-preserving perturbations, which modify code or specifications in ways that maintain their original meaning. This counterfactual analysis helps to examine how LLMs respond to changes that should not affect the underlying logic of the code, revealing any weaknesses in their comprehension.

SpecEval also incorporates a progressive consistency analysis to evaluate the consistency of LLM performance across tasks that have sequential dependencies. This method evaluates whether LLMs can maintain high performance across a series of related tasks that build on one another. Extensive experiments were conducted on six state-of-the-art LLMs, and the results showed that while the models could perform some tasks, their overall performance on specification-related tasks was below expectations. The analysis also revealed that LLMs struggled with maintaining consistency when confronted with semantic-preserving perturbations, indicating limitations in their code comprehension capabilities.

In conclusion, SpecEval provides a novel and rigorous approach to evaluating LLMs’ code comprehension capabilities, moving beyond existing methods focusing only on specific input cases or code reasoning tasks. By employing formal program specifications and tasks that test both basic and advanced levels of comprehension, SpecEval offers a more complete evaluation of LLMs. The experimental results reveal significant gaps in the current state of LLMs, mainly when dealing with semantic variations, highlighting the need for further advancements in LLM development.

Check out the Paper. All credit for this research goes to the researchers of this project. Also, don’t forget to follow us on Twitter and join our Telegram Channel and LinkedIn Group. If you like our work, you will love our newsletter..

Don’t Forget to join our 50k+ ML SubReddit

FREE AI WEBINAR: ‘SAM 2 for Video: How to Fine-tune On Your Data’ (Wed, Sep 25, 4:00 AM – 4:45 AM EST)

The post SpecEval: A Novel Black-Box Evaluation Framework to Evaluate Code Comprehension in LLMs via Program Specifications appeared first on MarkTechPost.

Posted by

in