This repository is the official implementation of ProTo: Program-Guided Transformer for Program-Guided Tasks.
Youtube link: https://www.youtube.com/watch?v=Dd8EHqMfOPI&t=24s
Exemplar program-guided tasks:
ProTo model illustrated:
Programs, consisting of semantic and structural information, play an important role in the communication between humans and agents. Towards learning general program executors to unify perception, reasoning, and decision making, we formulate program-guided tasks which require learning to execute a given program on the observed task specification. Furthermore, we propose the Program-guided Transformer (ProTo), which integrates both semantic and structural guidance of a program by leveraging cross-attention and masked self-attention to pass messages between the specification and routines in the program. ProTo executes a program in a learned latent space and enjoys stronger representation ability than previous neural-symbolic approaches. We demonstrate that ProTo significantly outperforms the previous state-of-the-art methods on GQA visual reasoning and 2D Minecraft policy learning datasets. Additionally, ProTo demonstrates better generalization to unseen, complex, and human-written programs.
2022.April.15 Docs finish construction.
2021.Nov.27 Code is available at Github. Docs are under constructing.
To install requirements:
# create conda environment
conda create --name proto python=3.7
conda activate proto
# install general packages
pip install -r requirements.txt
-
Dataset download from the official website:
bash scripts/download_gqa.sh
-
Feature extraction via bottom up attention. The pre-trained features are from meta modular networks.
# clone repo
git clone --recursive https://github.com/MILVLG/bottom-up-attention.pytorch
# install detectron2
cd detectron2
pip install -e .
cd ..
# install apex
git clone https://github.com/NVIDIA/apex.git
cd apex
python setup.py install
cd ..
# install bottom up attention repo
python setup.py build develop
pip install ray
The original data and code are not available due to license issue (the original Minecraft dataset is from the Google company). However, I can provide help if you drop me an email: [email protected].
To train the model(s) in the paper, run this command:
python run_experiments.py
Using -h to see the possible options.
The original data and training code are not available due to license issue (the original Minecraft dataset is from the Google company). However, I can provide help if you drop me an email: [email protected].
To evaluate my model on ImageNet, run:
python run_experiments.py --do_eval
Cite our paper:
@misc{zhao2021proto, title={ProTo: Program-Guided Transformer for Program-Guided Tasks}, author={Zelin Zhao and Karan Samel and Binghong Chen and Le Song}, year={2021}, eprint={2110.00804}, archivePrefix={arXiv}, primaryClass={cs.LG} }
Please raise an issue if you found a bug and we welcome pull requests.