ViperGPT: Visual Inference via Python Execution for Reasoning

Abstract

Answering visual queries is a complex task that requires both visual processing and reasoning. End-to-end models, the dominant approach for this task, do not explicitly differentiate between the two, limiting interpretability and generalization. Learning modular programs presents a promising alternative, but has proven challenging due to the difficulty of learning both the programs and modules simultaneously. We introduce ViperGPT, a framework that leverages code-generation models to compose vision-and-language models into subroutines to produce a result for any query. ViperGPT utilizes a provided API to access the available modules, and composes them by generating Python code that is later executed. This simple approach requires no further training, and achieves state-of-the-art results across various complex visual tasks.

Cite

Text

Surís et al. "ViperGPT: Visual Inference via Python Execution for Reasoning." International Conference on Computer Vision, 2023. doi:10.1109/ICCV51070.2023.01092

Markdown

[Surís et al. "ViperGPT: Visual Inference via Python Execution for Reasoning." International Conference on Computer Vision, 2023.](https://mlanthology.org/iccv/2023/suris2023iccv-vipergpt/) doi:10.1109/ICCV51070.2023.01092

BibTeX

@inproceedings{suris2023iccv-vipergpt,
  title     = {{ViperGPT: Visual Inference via Python Execution for Reasoning}},
  author    = {Surís, Dídac and Menon, Sachit and Vondrick, Carl},
  booktitle = {International Conference on Computer Vision},
  year      = {2023},
  pages     = {11888-11898},
  doi       = {10.1109/ICCV51070.2023.01092},
  url       = {https://mlanthology.org/iccv/2023/suris2023iccv-vipergpt/}
}