This repository is the official implementation of the ICLR2024 paper: "FROSTER: Frozen CLIP is a Strong Teacher for Open-vocabulary Action Recognition"
Xiaohu Huang, Hao Zhou, Kun Yao, Kai Han
teaser.mp4
This paper introduces FROSTER, an effective framework for open-vocabulary action recognition. The overall pipeline of FROSTER consists of two key components, namely, model finetuning to bridge the gap between image and video tasks, and knowledge distillation to maintain the generalizability of the pretrained CLIP.
Froster is released under the CC BY-NC-SA 4.0 license
.
We conduct experiments on two open-vocabulary settings, i.e., base-to-novel and cross-dataset. FROSTER achieves state-of-the-art performance on both the two benchmarks.
Method | K-400 | HMDB-51 | UCF-101 | SSv2 | ||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|
- | Base | Novel | HM | Base | Novel | HM | Base | Novel | HM | Base | Novel | IMM |
FrozenCLIP | ||||||||||||
ActionCLIP | ||||||||||||
XCLIP | ||||||||||||
VPT | ||||||||||||
AIM † | ||||||||||||
ST-Adapter † | ||||||||||||
ViFi-CLIP | ||||||||||||
OpenVCLIP | ||||||||||||
FROSTER (Ours) |
Table 2: Performance comparison (Top1-Acc (%)) with the previous approaches under the cross-dataset evaluation protocol. All methods are based on CLIP ViT-B/16, except for ER-ZASR (TSM pre-trained on ImageNet-1k) and Text4Vis (ViT-L/14). UCF* and HMDB* indicate evaluating the full validation set, while UCF and HMDB denote evaluating across the three validation splits. The results of most other papers are taken from Open-VCLIP and ViFi-CLIP. † denotes the results produced with our implementation.
Method | UCF* | UCF | HMDB* | HMDB | K-600 |
---|---|---|---|---|---|
ER-ZASR | - | - | |||
Frozen CLIP † | |||||
ActionCLIP † | |||||
X-CLIP | - | - | |||
VPT | - | - | |||
Text4Vis | - | - | |||
AIM † | |||||
ST-Adapter † | |||||
Vita-CLIP | - | - | |||
ViFi-CLIP | - | - | |||
Open-VCLIP | |||||
FROSTER (Ours) |
The main dependent packages include: PyTorch 1.11.0 and torchvision 0.12.0 and PySlowFast
Detailed Installation instructions can be viewed in INSTALL.md
.
-
Kinetics-400.
We obtained the compressed version Kinetics-400 dataset, where videos have been resized to 256, from the
VoV3d Repo
. The repository provides the download link for the dataset:Kinetics-400 dataset link
. After downloading and extracting the data, you should rename the folders "train_256" and "val_256" to "train" and "val" respectively. Additionally, please note that the video "val/crossing_river/ZVdAl- yh9m0.mp4" is invalid and needs to be replaced. You should download a new version of the video fromhere
and perform the replacement. -
UCF-101.
We download UCF-101 dataset by the
script
provided by MMAction2. -
HMDB-51.
We download the HMDB-51 dataset by the
script
provided by MMAction2. -
Kinetics-600 testing.
The validation data of Kinetics-600 we used can be downloaded from
link
.
The pre-trained model on K400 is provided at Google Drive.
- Base-to-Novel Setting
The training scripts are in the script/training/temporal_b16 folder.
Please use
train_clip_B2N_hmdb.sh
,train_clip_B2N_k400.sh
,train_clip_B2N_ssv2.sh
andtrain_clip_B2N_ucf.sh
for the training on HMDB51, K400, SSV2, and UCF101, respectively.
Below is the training script on k400, where you need to modify the ROOT
, CKPT
, DATA.PATH_TO_DATA_DIR
, DATA.PATH_PREFIX
, DATA.INDEX_LABEL_MAPPING_FILE
variables to fit the paths on your server.
ROOT=PATH_TO_FROSTER_WORKSPACE
CKPT=PATH_TO_FROSTER_WORKSPACE
# TRAIN_FILE can be set as train_1.csv or train_2.csv or train_3.csv;
B2N_k400_file=B2N_k400
TRAIN_FILE=train_1.csv
VAL_FILE=val.csv
TEST_FILE=test.csv
cd $ROOT
TORCH_DISTRIBUTED_DEBUG=INFO python -W ignore -u tools/run_net.py \
--cfg configs/Kinetics/TemporalCLIP_vitb16_8x16_STAdapter_K400.yaml \
--opts DATA.PATH_TO_DATA_DIR $ROOT/zs_label_db/$B2N_k400_file \
TRAIN_FILE $TRAIN_FILE \
VAL_FILE $VAL_FILE \
TEST_FILE $TEST_FILE \
DATA.PATH_PREFIX $ROOT/data/k400 \
DATA.PATH_LABEL_SEPARATOR , \
DATA.INDEX_LABEL_MAPPING_FILE $ROOT/zs_label_db/$B2N_k400_file/train_rephrased.json \
TRAIN.ENABLE True \
OUTPUT_DIR $CKPT/basetraining/B2N_k400_froster \
TRAIN.BATCH_SIZE 64 \
TEST.BATCH_SIZE 240 \
TEST.NUM_ENSEMBLE_VIEWS 3 \
TEST.NUM_SPATIAL_CROPS 1 \
NUM_GPUS 8 \
SOLVER.MAX_EPOCH 12 \
SOLVER.WARMUP_EPOCHS 2.0 \
SOLVER.BASE_LR 3.33e-6 \
SOLVER.WARMUP_START_LR 3.33e-8 \
SOLVER.COSINE_END_LR 3.33e-8 \
TRAIN.MIXED_PRECISION True \
DATA.DECODING_BACKEND "pyav" \
MODEL.NUM_CLASSES 200 \
MIXUP.ENABLE False \
AUG.ENABLE False \
AUG.NUM_SAMPLE 1 \
TRAIN.EVAL_PERIOD 1 \
TRAIN.CHECKPOINT_PERIOD 1 \
MODEL.LOSS_FUNC soft_cross_entropy \
TRAIN.LINEAR_CONNECT_CLIMB False \
TRAIN.CLIP_ORI_PATH /root/.cache/clip/ViT-B-16.pt \
TRAIN.LINEAR_CONNECT_LOSS_RATIO 0.0 \
MODEL.RAW_MODEL_DISTILLATION True \
MODEL.KEEP_RAW_MODEL True \
MODEL.DISTILLATION_RATIO 2.0
- Cross-Dataset Setting
The training script is also in the script/training/temporal_b16 folder.
Please use train_clip.sh
for the training on K400, where you also need to modify the ROOT
, CKPT
, DATA.PATH_TO_DATA_DIR
, DATA.PATH_PREFIX
, DATA.INDEX_LABEL_MAPPING_FILE
variables to fit the paths on your server.
To improve the generalizability of your model, after training, you can use weight_average_tool.py
to average the models from different epochs. The source folder source_dir
should be changed according to your saved path.
python weight_average_tool.py
- Base-to-Novel Setting
Please use hmdb_clip_B2N.sh
, k400_clip_B2N.sh
, ssv2_clip_B2N.sh
and ucf_clip_B2N.sh
for the evaluation on HMDB51, K400, SSV2, and UCF101, respectively, where you need to modify the ROOT
, CKPT
, DATA.PATH_TO_DATA_DIR
, DATA.PATH_PREFIX
, DATA.INDEX_LABEL_MAPPING_FILE
and LOAD_CKPT_FILE
variables to fit the paths on your server.
Below is the evaluation script for k400 dataset.
ROOT=PATH_TO_FROSTER_WORKSPACE
CKPT=PATH_TO_FROSTER_WORKSPACE
OUT_DIR=$CKPT/testing
OAD_CKPT_FILE=$ROOT/basetraining/B2N_k400_froster/wa_checkpoints/swa_2_22.pth
# TRAIN_FILE can be set as train_1.csv or train_2.csv or train_3.csv;
# TEST_FILE can be set as val.csv (base set) or test.csv (novel set).
# rephrased_file can be set as train_rephrased.json (base set) or test_rephrased.json (novel set)
B2N_k400_file=B2N_k400
TRAIN_FILE=train_1.csv
VAL_FILE=val.csv
TEST_FILE=val.csv
rephrased_file=train_rephrased.json
cd $ROOT
python -W ignore -u tools/run_net.py \
--cfg configs/Kinetics/TemporalCLIP_vitb16_8x16_STAdapter_K400.yaml \
--opts DATA.PATH_TO_DATA_DIR $ROOT/zs_label_db/$B2N_k400_file \
TRAIN_FILE $TRAIN_FILE \
VAL_FILE $VAL_FILE \
TEST_FILE $TEST_FILE \
DATA.PATH_PREFIX $ROOT/data/k400 \
DATA.PATH_LABEL_SEPARATOR , \
DATA.INDEX_LABEL_MAPPING_FILE $ROOT/zs_label_db/B2N_k400/$rephrased_file \
TRAIN.ENABLE False \
OUTPUT_DIR $OUT_DIR \
TEST.BATCH_SIZE 480 \
NUM_GPUS 8 \
DATA.DECODING_BACKEND "pyav" \
MODEL.NUM_CLASSES 200 \
TEST.CUSTOM_LOAD True \
TEST.CUSTOM_LOAD_FILE $LOAD_CKPT_FILE \
TEST.SAVE_RESULTS_PATH temp.pyth \
TEST.NUM_ENSEMBLE_VIEWS 3 \
TEST.NUM_SPATIAL_CROPS 1 \
TEST.PATCHING_MODEL False \
TEST.PATCHING_RATIO $PATCHING_RATIO \
TEST.CLIP_ORI_PATH ~/.cache/clip/ViT-B-16.pt \
DATA_LOADER.NUM_WORKERS 4 \
- Cross-Dataset Setting
Please use hmdb_clip.sh
, ucf_clip.sh
, and k600_clip.sh
for the evaluation on HMDB51, UCF101, and K600, respectively, where you need to modify the ROOT
, CKPT
, DATA.PATH_TO_DATA_DIR
, DATA.PATH_PREFIX
, DATA.INDEX_LABEL_MAPPING_FILE
and LOAD_CKPT_FILE
variables to fit the paths on your server.
This repository is built upon OpenVCLIP
, PySlowFast
and CLIP
. Thanks for those well-organized codebases.
@inproceedings{
huang2024froster,
title={FROSTER: Frozen CLIP is a Strong Teacher for Open-Vocabulary Action Recognition},
author={Xiaohu Huang and Hao Zhou and Kun Yao and Kai Han},
booktitle={International Conference on Learning Representations},
year={2024}
}