SPoC: Search-based Pseudocode to Code

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%.

PDF Abstract NeurIPS 2019 PDF NeurIPS 2019 Abstract

Datasets


Introduced in the Paper:

SPoC

Results from the Paper


Task Dataset Model Metric Name Metric Value Global Rank Result Benchmark
Program Synthesis SPoC TestP Multiclass localizer Success rate @budget 100 34.2 # 2
Program Synthesis SPoC TestW Multiclass localizer Success rate @budget 100 53.7 # 2

Methods


No methods listed for this paper. Add relevant methods here