SELGNEJun 1, 2019

Neural Bug Finding: A Study of Opportunities and Challenges

arXiv:1906.00307v119 citations
Originality Incremental advance
AI Analysis

This addresses the challenge of making bug detection more accessible beyond experts, though it is incremental in applying neural networks to a known problem.

The paper explores neural bug finding as an alternative to traditional static analysis for detecting software bugs, showing it can achieve over 80% precision and recall for some bug patterns but struggles with certain program properties.

Static analysis is one of the most widely adopted techniques to find software bugs before code is put in production. Designing and implementing effective and efficient static analyses is difficult and requires high expertise, which results in only a few experts able to write such analyses. This paper explores the opportunities and challenges of an alternative way of creating static bug detectors: neural bug finding. The basic idea is to formulate bug detection as a classification problem, and to address this problem with neural networks trained on examples of buggy and non-buggy code. We systematically study the effectiveness of this approach based on code examples labeled by a state-of-the-art, static bug detector. Our results show that neural bug finding is surprisingly effective for some bug patterns, sometimes reaching a precision and recall of over 80%, but also that it struggles to understand some program properties obvious to a traditional analysis. A qualitative analysis of the results provides insights into why neural bug finders sometimes work and sometimes do not work. We also identify pitfalls in selecting the code examples used to train and validate neural bug finders, and propose an algorithm for selecting effective training data.

Foundations

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

Your Notes