Recursive Visual Programming
Jiaxin Ge, Sanjay Subramanian, Baifeng Shi, Roei Herzig, Trevor Darrell
TL;DR
Recursive Visual Programming (RVP) advances Visual Question Answering by replacing monolithic code generation with iterative recursive decomposition and dynamic return-type assignment. Built on a two-part architecture with a code generator and a visual executor, and enabled by a recursive_query mechanism, RVP breaks complex questions into simpler sub-questions, solves them modularly, and aggregates results. Empirical results across GQA, VSR, COVR, and NextQA demonstrate improved accuracy and enhanced interpretability, supported by ablations on dynamic typing, prompts, and error-feedback loops. The work also analyzes open-source versus proprietary models, prompting strategies, and readability impacts, suggesting broad applicability of recursive, modular coding in visual reasoning and beyond.
Abstract
Visual Programming (VP) has emerged as a powerful framework for Visual Question Answering (VQA). By generating and executing bespoke code for each question, these methods demonstrate impressive compositional and reasoning capabilities, especially in few-shot and zero-shot scenarios. However, existing VP methods generate all code in a single function, resulting in code that is suboptimal in terms of both accuracy and interpretability. Inspired by human coding practices, we propose Recursive Visual Programming (RVP), which simplifies generated routines, provides more efficient problem solving, and can manage more complex data structures. RVP is inspired by human coding practices and approaches VQA tasks with an iterative recursive code generation approach, allowing decomposition of complicated problems into smaller parts. Notably, RVP is capable of dynamic type assignment, i.e., as the system recursively generates a new piece of code, it autonomously determines the appropriate return type and crafts the requisite code to generate that output. We show RVP's efficacy through extensive experiments on benchmarks including VSR, COVR, GQA, and NextQA, underscoring the value of adopting human-like recursive and modular programming techniques for solving VQA tasks through coding.
