PLCLFLFeb 20

Automating the Analysis and Improvement of Dynamic Programming Algorithms with Applications to Natural Language Processing

arXiv:2603.132421 citationsh-index: 15Has Code
Originality Incremental advance
AI Analysis

This addresses the problem of laborious and error-prone manual optimization of dynamic programs for researchers and practitioners in NLP and computer science, though it is incremental as it systematizes existing insights.

The thesis developed a system to automatically analyze and improve dynamic programming algorithms, showing that it can find substantial runtime improvements, such as discovering speed-ups described in the NLP literature automatically.

This thesis develops a system for automatically analyzing and improving dynamic programs, such as those that have driven progress in natural language processing and computer science, more generally, for decades. Finding a correct program with the optimal asymptotic runtime can be unintuitive, time-consuming, and error-prone. This thesis aims to automate this laborious process. To this end, we develop an approach based on 1. a high-level, domain-specific language called Dyna for concisely specifying dynamic programs 2. a general-purpose solver to efficiently execute these programs 3. a static analysis system that provides type analysis and worst-case time/space complexity analyses 4. a rich collection of meaning-preserving transformations to programs, which systematizes the repeated insights of numerous authors when speeding up algorithms in the literature 5. a search algorithm for identifying a good sequence of transformations that reduce the runtime complexity, given an initial, correct program We show that, in practice, automated search -- like the mental search performed by human programmers -- can find substantial improvements to the initial program. Empirically, we show that many speed-ups described in the NLP literature could have been discovered automatically by our system. We provide a freely available prototype system at https://github.com/timvieira/dyna-pi.

Foundations

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

Your Notes