Making neural programming architectures generalize via recursion

J Cai, R Shin, D Song - arXiv preprint arXiv:1704.06611, 2017 - arxiv.org
arXiv preprint arXiv:1704.06611, 2017arxiv.org
Empirically, neural networks that attempt to learn programs from data have exhibited poor
generalizability. Moreover, it has traditionally been difficult to reason about the behavior of
these models beyond a certain level of input complexity. In order to address these issues,
we propose augmenting neural architectures with a key abstraction: recursion. As an
application, we implement recursion in the Neural Programmer-Interpreter framework on
four tasks: grade-school addition, bubble sort, topological sort, and quicksort. We …
Empirically, neural networks that attempt to learn programs from data have exhibited poor generalizability. Moreover, it has traditionally been difficult to reason about the behavior of these models beyond a certain level of input complexity. In order to address these issues, we propose augmenting neural architectures with a key abstraction: recursion. As an application, we implement recursion in the Neural Programmer-Interpreter framework on four tasks: grade-school addition, bubble sort, topological sort, and quicksort. We demonstrate superior generalizability and interpretability with small amounts of training data. Recursion divides the problem into smaller pieces and drastically reduces the domain of each neural network component, making it tractable to prove guarantees about the overall system's behavior. Our experience suggests that in order for neural architectures to robustly learn program semantics, it is necessary to incorporate a concept like recursion.
arxiv.org
Showing the best result for this search. See all results