The official PyTorch implementation of our CVPR 2023 poster paper:
DKT: Diverse Knowledge Transfer Transformer for Class Incremental Learning
GitHub maintainer: Xinyuan Gao
We use the
python == 3.9
torch == 1.11.0
torchvision == 0.12.0
timm == 0.5.4
continuum == 1.2.3
We provide the accuracy of every phase in different settings in the following table. You can also get them in the logs. (We run the official code again, it may be slightly different from the paper).
CIFAR 20—20 | 1 | 2 | 3 | 4 | 5 | AVG |
---|---|---|---|---|---|---|
% | 88.3 | 80.2 | 76.92 | 71.95 | 67.17 | 76.91 |
CIFAR 10—10 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | AVG |
---|---|---|---|---|---|---|---|---|---|---|---|
% | 94.2 | 86.95 | 83.0 | 77.53 | 74.12 | 74.05 | 70.53 | 67.9 | 65.12 | 63.45 | 75.69 |
CIFAR 5—5 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | AVG |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
% | 97.8 | 94.0 | 90.27 | 87.3 | 84.16 | 81.67 | 78.54 | 75.38 | 73.91 | 72.42 | 70.36 | 70.42 | 67.82 | 66.46 | 65.45 | 64.8 | 63.96 | 62.48 | 61.03 | 59.2 | 74.37 |
ImageNet100 10—10 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | AVG |
---|---|---|---|---|---|---|---|---|---|---|---|
% | 91.6 | 85.8 | 81.53 | 79.35 | 77.28 | 76.57 | 73.49 | 71.6 | 70.2 | 68.74 | 77.62 |
ImageNet1000 100—100 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | AVG |
---|---|---|---|---|---|---|---|---|---|---|---|
% | 85.02 | 80.12 | 76.5 | 73.7 | 70.26 | 68.36 | 66.35 | 64.1 | 61.81 | 58.93 | 70.52 |
If you want to run our experiment on different numbers of GPUs, you should set the Batch_size * GPUs == 512. For example, one GPU, the Batch size 512 and two GPUs, the Batch size 256 (CIFAR-100 and ImageNet100). If you want to change it, please try to change the hyperparameters. \
For CIFAR-100, you can use a single GPU with bs 512 or two GPUs with bs 256. (The accuracy is in the logs)
For ImageNet-100, we use two GPUs with bs 256
For ImageNet-1000, we use four GPUs with bs 256
Due to the rush in organizing time, if you encounter any situation, please contact my email [[email protected]]. Thanks
Our code is heavily based on the great codebase of Dytox, thanks for its wonderful code frame.
Also, a part of our code is inspired by the CSCCT, thanks for its code.
You can use the following command to run the code like the Dytox:
bash train.sh 0,1
--options options/data/cifar100_10-10.yaml options/data/cifar100_order1.yaml options/model/cifar_DKT.yaml
--name DKT
--data-path MY_PATH_TO_DATASET
--output-basedir PATH_TO_SAVE_CHECKPOINTS
--memory-size 2000
If any parts of our paper and code help your research, please consider citing us and giving a star to our repository.
@InProceedings{Gao_2023_CVPR,
author = {Gao, Xinyuan and He, Yuhang and Dong, Songlin and Cheng, Jie and Wei, Xing and Gong, Yihong},
title = {DKT: Diverse Knowledge Transfer Transformer for Class Incremental Learning},
booktitle = {Proceedings of the IEEE/CVF Conference on Computer Vision and Pattern Recognition (CVPR)},
month = {June},
year = {2023},
pages = {24236-24245}
}