📝 A note regarding the naming convention in this repo: we use "PatchAndFuse" or "patch_and_fuse" as an alternative name for the "Paxion" model.
-
after cloning this repo, setup submodules by:
git submodule update --init --recursive
-
Setup conda environment
conda env create -f environment.yml conda activate paxion
-
install LAVIS library from source
cd src/LAVIS pip install -e .
- Download the annotations for ActionBench here; and put under
ActionBench/ego4d
andActionBench/ssv2
- Download the annotations for downstream tasks here; and put the downloaded folder under the root directory of this repo as
datasets/
- Annotation details for each dataset can be found in the
.md
files in dataset_cards.
Please refer to the .md
files in dataset_cards for instructions on downloading the raw videos and preprocessing.
- InternVideo: Download the
InternVideo-MM-L-14
checkpoint following the instructions here; put the downloadedInternVideo-MM-L-14.ckpt
undersrc/pretrained_ckpt/InternVideo/InternVideo-MM-L-14.ckpt
- ClipViP: Download the
CLIP-ViP-B/32
checkpoint following the instructions here; put the downloadedpretrain_clipvip_base_32.pt
undersrc/pretrained_ckpt/ClipViP/pretrain_clipvip_base_32.pt
- Singularity: Download the
Pre-trained checkpoints
following the instructions here; put thesingularity_temporal_17m
undersrc/pretrained_ckpt/Singularity/singularity_temporal_17m.pth
- Download the Knowledge Patcher checkpoints on actionbench here; and put under
src/pretrained_ckpt/PatchAndFuse/ActionBench
- Download the Patch & Fuse checkpoints on downstream tasks here; and put under
src/pretrained_ckpt/PatchAndFuse/downstream_tasks
demo.py shows an usage example on loading a trained PatchAndFuse model (with InternVideo backbone and trained on SSv2-label) and perform inference on video-text matching.
We build our codebase on top of LAVIS framework. Please refer to the documentation to get an idea of the overall structure (Tasks, Models, Runners, etc). Config files for running any tasks can be found in src/configs/projects
, we include detailed comments in the .yaml
files for more fine-grained customization on the experimental configs.
To train Knowledge Patcher on ActionBench or further train Knowledge Fuser on downstream tasks, we provide configs under src/configs/projects/train
; Please make sure to look into the configs and do necessary modifications (e.g. specify trained checkpoints which are marked as #TODO
).
Here is an example for using the training configs (run_scripts/train.sh
):
cd src/ bash run_scripts/train.sh
To evaluate Knowledge Patcher on ActionBench or evaluate trained Knowledge Fuser on downstream tasks, we provide configs under src/configs/projects/eval
; Please make sure to look into the configs and do necessary modifications (e.g. specify trained checkpoints which are marked as #TODO
).
Here are two examples for using the evaluation configs (run_scripts/eval_actionbench.sh
and run_scripts/eval_downstream_task.sh
):
- eval actionbench:
cd src/ bash run_scripts/eval_actionbench.sh
- eval downstream task:
cd src/ bash run_scripts/eval_downstream_task.sh
For customized inference, i.e., evaluate on some specific samples and visualize the results, we provide inference.py where one can set spefic instance ids in the __main__
function.
Examples for running inference on different tasks can be found in run_scripts/inference.sh
@article{wang2023paxion,
title={Paxion: Patching Action Knowledge in Video-Language Foundation Models},
author={Wang, Zhenhailong and Blume, Ansel and Li, Sha and Liu, Genglin and Cho, Jaemin and Tang, Zineng and Bansal, Mohit and Ji, Heng},
journal={arXiv preprint arXiv:2305.10683},
year={2023}
}
This code used resources from LAVIS, InternVideo, ClipViP, Singularity, and flamingo-pytorch. The code is implemented using PyTorch. We thank the authors for their great work and open-sourcing the code.