LGCLPLMLJun 12, 2019

SPoC: Search-based Pseudocode to Code

arXiv:1906.04908v1322 citations
Originality Incremental advance
AI Analysis

This addresses the challenge of program synthesis from pseudocode for developers, though it is incremental as it builds on existing search methods with a new credit assignment technique.

The paper tackles the problem of mapping pseudocode to functionally correct long programs by using search-based synthesis with test case validation, improving the success rate from 25.6% to 44.7% under a budget of 100 compilations.

We consider the task of mapping pseudocode to long programs that are functionally correct. Given test cases as a mechanism to validate programs, we search over the space of possible translations of the pseudocode to find a program that passes the validation. However, without proper credit assignment to localize the sources of program failures, it is difficult to guide search toward more promising programs. We propose to perform credit assignment based on signals from compilation errors, which constitute 88.7% of program failures. Concretely, we treat the translation of each pseudocode line as a discrete portion of the program, and whenever a synthesized program fails to compile, an error localization method tries to identify the portion of the program responsible for the failure. We then focus search over alternative translations of the pseudocode for those portions. For evaluation, we collected the SPoC dataset (Search-based Pseudocode to Code) containing 18,356 programs with human-authored pseudocode and test cases. Under a budget of 100 program compilations, performing search improves the synthesis success rate over using the top-one translation of the pseudocode from 25.6% to 44.7%.

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