π₯Update:
- Thanks to the issue#4, the implementation of HSIC is incorrect due to the misunderstanding of
torch.diag
. Note that the issue even exists in our referred work ReBias (ICML'21). We have corrected this issue here mmaction/models/heads/debias_head.py#L137 but do not guarantee good performance. - For a reasonable AUC evaluation, threshold is not necessary in practice. We recommend use the updated evaluation code script here:
experiments/compare_openness_new.py
, but do not guarantee a good performance.
International Conference on Computer Vision (ICCV Oral), 2021.
We propose the Deep Evidential Action Recognition (DEAR) method to recognize actions in an open world. Specifically, we formulate the action recognition problem from the evidential deep learning (EDL) perspective and propose a novel model calibration method to regularize the EDL training. Besides, to mitigate the static bias of video representation, we propose a plug-and-play module to debias the learned representation through contrastive learning. Our DEAR model trained on UCF-101 dataset achieves significant and consistent performance gains based on multiple action recognition models, i.e., I3D, TSM, SlowFast, TPN, with HMDB-51 or MiT-v2 dataset as the unknown.
The following figures show the inference results by the SlowFast + DEAR model trained on UCF-101 dataset.
UCF-101 |
||||
HMDB-51 |
This repo is developed from MMAction2 codebase. Since MMAction2 is updated in a fast pace, most of the requirements and installation steps are similar to the version MMAction2 v0.9.0.
Here we only list our used requirements and dependencies. It would be great if you can work around with the latest versions of the listed softwares and hardwares on the latest MMAction2 codebase.
- Linux: Ubuntu 18.04 LTS
- GPU: GeForce RTX 3090, A100-SXM4
- CUDA: 11.0
- GCC: 7.5
- Python: 3.7.9
- Anaconda: 4.9.2
- PyTorch: 1.7.1+cu110
- TorchVision: 0.8.2+cu110
- OpenCV: 4.4.0
- MMCV: 1.2.1
- MMAction2: 0.9.0
The following steps are modified from MMAction2 (v0.9.0) installation document. If you encountered problems, you may refer to more details in the official document, or raise an issue in this repo.
a. Create a conda virtual environment of this repo, and activate it:
conda create -n mmaction python=3.7 -y
conda activate mmaction
b. Install PyTorch and TorchVision following the official instructions, e.g.,
conda install pytorch=1.7.1 cudatoolkit=11.0 torchvision=0.8.2 -c pytorch
c. Install mmcv, we recommend you to install the pre-build mmcv as below.
pip install mmcv-full==1.2.1 -f https://download.openmmlab.com/mmcv/dist/cu110/torch1.7.1/index.html
Important: If you have already installed mmcv
and try to install mmcv-full
, you have to uninstall mmcv
first by running pip uninstall mmcv
. Otherwise, there will be ModuleNotFoundError
.
d. Clone the source code of this repo:
git clone https://github.com/Cogito2012/DEAR.git mmaction2
cd mmaction2
e. Install build requirements and then install DEAR.
pip install -r requirements/build.txt
pip install -v -e . # or "python setup.py develop"
If no error appears in your installation steps, then you are all set!
This repo uses standard video action datasets, i.e., UCF-101 for closed set training, and HMDB-51 and MiT-v2 test sets as two different unknowns. Please refer to the default MMAction2 dataset setup steps to setup these three datasets correctly.
Note: You can just ignore the Step 3. Extract RGB and Flow
in the referred setup steps since all codes related to our paper do not rely on extracted frames and optical flow. This will save you large amount of disk space!
To test our pre-trained models (see the Model Zoo), you need to download a model file and unzip it under work_dir
. Let's take the I3D
-based DEAR model as an example. First, download the pre-trained I3D-based models, where the full DEAR model is saved in the folder finetune_ucf101_i3d_edlnokl_avuc_debias
. The following directory tree is for your reference to place the downloaded files.
work_dirs
βββ i3d
β βββ finetune_ucf101_i3d_bnn
β βΒ Β βββ latest.pth
β βββ finetune_ucf101_i3d_dnn
β βΒ Β βββ latest.pth
β βββ finetune_ucf101_i3d_edlnokl
β βΒ Β βββ latest.pth
β βββ finetune_ucf101_i3d_edlnokl_avuc_ced
β βΒ Β βββ latest.pth
β βββ finetune_ucf101_i3d_edlnokl_avuc_debias
β βΒ Β βββ latest.pth
β βββ finetune_ucf101_i3d_rpl
β βββ latest.pth
βββ slowfast
βββ tpn_slowonly
βββ tsm
a. Closed Set Evaluation.
Top-K accuracy and mean class accuracy will be reported.
cd experiments/i3d
bash evaluate_i3d_edlnokl_avuc_debias_ucf101.sh 0
b. Get Uncertainty Threshold.
The threshold value of one model will be reported.
cd experiments/i3d
# run the thresholding with BATCH_SIZE=2 on GPU_ID=0
bash run_get_threshold.sh 0 edlnokl_avuc_debias 2
c. Out-of-Distribution Detection.
The uncertainty distribution figure of a specified model will be reported.
cd experiments/i3d
bash run_ood_detection.sh 0 HMDB edlnokl_avuc_debias
d. Open Set Evaluation and Comparison.
The open set evaluation metrics and openness curves will be reported.
Note: Make sure the threshold values of different models are from the reported results in step b.
cd experiments/i3d
bash run_openness.sh HMDB # use HMDB-51 test set as the Unknown
bash run_openness.sh MiT # use MiT-v2 test set as the Unknown
e. Draw Open Set Confusion Matrix
The confusion matrix with unknown dataset used will be reported.
cd experiments/i3d
bash run_draw_confmat.sh HMDB # or MiT
Let's still take the I3D-based DEAR model as an example.
cd experiments/i3d
bash finetune_i3d_edlnokl_avuc_debias_ucf101.sh 0
Since model training is time consuming, we strongly recommend you to run the above training script in a backend way if you are using SSH remote connection.
nohup bash finetune_i3d_edlnokl_avuc_debias_ucf101.sh 0 >train.log 2>&1 &
# monitoring the training status whenever you open a new terminal
tail -f train.log
Visualizing the training curves (losses, accuracies, etc.) on TensorBoard:
cd work_dirs/i3d/finetune_ucf101_i3d_edlnokl_avuc_debias/tf_logs
tensorboard --logdir=./ --port 6008
Then, you will see the generated url address http://localhost:6008
. Open this address with your Internet Browser (such as Chrome), you will monitoring the status of training.
If you are using SSH connection to a remote server without monitor, tensorboard visualization can be done on your local machine by manually mapping the SSH port number:
ssh -L 16008:localhost:6008 {your_remote_name}@{your_remote_ip}
Then, you can monitor the tensorboard by the port number 16008
by typing http://localhost:16008
in your browser.
The pre-trained weights (checkpoints) are available below.
Model | Checkpoint | Train Config | Test Config | Open maF1 (%) | Open Set AUC (%) | Closed Set ACC (%) |
---|---|---|---|---|---|---|
I3D + DEAR | ckpt | train | test | 77.24 / 69.98 | 77.08 / 81.54 | 93.89 |
TSM + DEAR | ckpt | train | test | 84.69 / 70.15 | 78.65 / 83.92 | 94.48 |
TPN + DEAR | ckpt | train | test | 81.79 / 71.18 | 79.23 / 81.80 | 96.30 |
SlowFast + DEAR | ckpt | train | test | 85.48 / 77.28 | 82.94 / 86.99 | 96.48 |
For other checkpoints of the compared baseline models, please download them in the Google Drive.
If you find the code useful in your research, please cite:
@inproceedings{BaoICCV2021DEAR,
author = "Bao, Wentao and Yu, Qi and Kong, Yu",
title = "Evidential Deep Learning for Open Set Action Recognition",
booktitle = "International Conference on Computer Vision (ICCV)",
year = "2021"
}
In addition to the MMAction2 codebase, this repo contains modified codes from:
- pytorch-classification-uncertainty: for implementation of the EDL (NeurIPS-2018).
- ARPL: for implementation of baseline method RPL (ECCV-2020).
- OSDN: for implementation of baseline method OpenMax (CVPR-2016).
- bayes-by-backprop: for implementation of the baseline method Bayesian Neural Networks (BNNs).
- rebias: for implementation of HSIC regularizer used in ReBias (ICML-2020)
We sincerely thank the owners of all these great repos!