-
Notifications
You must be signed in to change notification settings - Fork 62
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
52 changed files
with
508 additions
and
397 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1 +1 @@ | ||
We appreciate all contributions to improve OpenMixup. We follow the developing standard of MMLab. Please refer to [CONTRIBUTING.md](https://github.com/open-mmlab/mmcv/blob/master/CONTRIBUTING.md) in MMCV for more details about the contributing guideline. | ||
We appreciate all contributions to improve OpenMixup. Currently, we follow the developing standard of MMLab. Please refer to [CONTRIBUTING.md](https://github.com/open-mmlab/mmcv/blob/master/CONTRIBUTING.md) in MMCV for more details about the contributing guideline. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
include requirements/*.txt | ||
recursive-include openmixup/.mim/configs *.py *.yml | ||
recursive-include openmixup/.mim/tools *.sh *.py |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,6 +1,7 @@ | ||
# OpenMixup | ||
[data:image/s3,"s3://crabby-images/771eb/771eb9964faef3d355ecb9249a72edcacb61d41c" alt="Release"](https://github.com/Westlake-AI/openmixup/releases) | ||
[data:image/s3,"s3://crabby-images/d546e/d546eb7c5d784d5bef2a7a6b4ea47df984bc6c13" alt="Docs"](https://openmixup.readthedocs.io/en/latest/) | ||
[data:image/s3,"s3://crabby-images/771eb/771eb9964faef3d355ecb9249a72edcacb61d41c" alt="release"](https://github.com/Westlake-AI/openmixup/releases) | ||
[data:image/s3,"s3://crabby-images/a69ca/a69ca8dbb4d034bfd10ecd3a5235ebf2eff60bac" alt="PyPI"](https://pypi.org/project/openmixup) | ||
[data:image/s3,"s3://crabby-images/d546e/d546eb7c5d784d5bef2a7a6b4ea47df984bc6c13" alt="docs"](https://openmixup.readthedocs.io/en/latest/) | ||
[data:image/s3,"s3://crabby-images/32e92/32e92076f185e5676507110d730826d8717b5de6" alt="license"](https://github.com/Westlake-AI/openmixup/blob/main/LICENSE) | ||
data:image/s3,"s3://crabby-images/73f79/73f79369ea780091a96b22dd25dfec480584ac6a" alt="open issues" | ||
[data:image/s3,"s3://crabby-images/7fd17/7fd1746b1af6422a990ac48883fb4d04928d8638" alt="issue resolution"](https://github.com/Westlake-AI/openmixup/issues) | ||
|
@@ -12,14 +13,6 @@ | |
[🔍Awesome MIM](https://openmixup.readthedocs.io/en/latest/awesome_selfsup/MIM.html) | | ||
[🆕News](https://openmixup.readthedocs.io/en/latest/changelog.html) | ||
|
||
## News and Updates | ||
|
||
[2022-12-16] `OpenMixup` v0.2.7 is released (issue [#35](https://github.com/Westlake-AI/openmixup/issues/35)). | ||
|
||
[2022-12-02] Update new features and documents of `OpenMixup` v0.2.6 (issue [#24](https://github.com/Westlake-AI/openmixup/issues/24), issue [#25](https://github.com/Westlake-AI/openmixup/issues/25), issue [#31](https://github.com/Westlake-AI/openmixup/issues/31), and issue [#33](https://github.com/Westlake-AI/openmixup/issues/33)). Update the official implementation of [MogaNet](https://arxiv.org/abs/2211.03295). | ||
|
||
[2022-09-14] `OpenMixup` v0.2.6 is released (issue [#20](https://github.com/Westlake-AI/openmixup/issues/20)). | ||
|
||
## Introduction | ||
|
||
The main branch works with **PyTorch 1.8** (required by some self-supervised methods) or higher (we recommend **PyTorch 1.12**). You can still use **PyTorch 1.6** for supervised classification methods. | ||
|
@@ -63,13 +56,18 @@ The main branch works with **PyTorch 1.8** (required by some self-supervised met | |
</ol> | ||
</details> | ||
|
||
<p align="right">(<a href="#top">back to top</a>)</p> | ||
## News and Updates | ||
|
||
[2022-12-16] `OpenMixup` v0.2.7 is released (issue [#35](https://github.com/Westlake-AI/openmixup/issues/35)). | ||
|
||
[2022-12-02] Update new features and documents of `OpenMixup` v0.2.6 (issue [#24](https://github.com/Westlake-AI/openmixup/issues/24), issue [#25](https://github.com/Westlake-AI/openmixup/issues/25), issue [#31](https://github.com/Westlake-AI/openmixup/issues/31), and issue [#33](https://github.com/Westlake-AI/openmixup/issues/33)). Update the official implementation of [MogaNet](https://arxiv.org/abs/2211.03295). | ||
|
||
[2022-09-14] `OpenMixup` v0.2.6 is released (issue [#20](https://github.com/Westlake-AI/openmixup/issues/20)). | ||
|
||
## Installation | ||
|
||
OpenMixup is compatible with **Python 3.7/3.8/3.9** and **PyTorch >= 1.8**. Here are installation steps for development: | ||
OpenMixup is compatible with **Python 3.6/3.7/3.8/3.9** and **PyTorch >= 1.6**. Here are quick installation steps for development: | ||
|
||
### From Source | ||
```shell | ||
conda create -n openmixup python=3.8 pytorch=1.12 cudatoolkit=11.3 torchvision -c pytorch -y | ||
conda activate openmixup | ||
|
@@ -79,63 +77,30 @@ git clone https://github.com/Westlake-AI/openmixup.git | |
cd openmixup | ||
python setup.py develop | ||
``` | ||
### From PyPI | ||
```shell | ||
conda create -n openmixup python=3.8 pytorch=1.12 cudatoolkit=11.3 torchvision -c pytorch -y | ||
conda activate openmixup | ||
pip install openmim | ||
mim install mmcv-full | ||
pip install openmixup | ||
cd openmixup | ||
python setup.py develop | ||
``` | ||
|
||
Please refer to [install.md](docs/en/install.md) for more detailed installation and dataset preparation instructions. | ||
Please refer to [install.md](docs/en/install.md) for more detailed installation and dataset preparation. | ||
|
||
## Getting Started | ||
|
||
OpenMixup supports Linux, macOS and Windows. It enables easy implementation and extensions of mixup data augmentation methods in existing supervised, self-, and semi-supervised visual recognition models. Please see [get_started.md](docs/en/get_started.md) for the basic usage of OpenMixup. | ||
OpenMixup supports Linux and macOS. It enables easy implementation and extensions of mixup data augmentation methods in existing supervised, self-, and semi-supervised visual recognition models. Please see [get_started.md](docs/en/get_started.md) for the basic usage of OpenMixup. | ||
|
||
### Quick Start | ||
This is an example of how to quickly set up the OpenMixup on your device. You can get a local copy up by running the belowing example steps. | ||
#### Step0: Create your environment | ||
```shell | ||
conda create -n openmixup python=3.8 pytorch=1.12 cudatoolkit=11.3 torchvision -c pytorch -y | ||
conda activate openmixup | ||
``` | ||
#### Step1: Install the required packages | ||
```shell | ||
pip install -U openmim | ||
mim install mmcv-full | ||
``` | ||
### Training and Evaluation Scripts | ||
|
||
#### Step2: Clone and develop the project | ||
```shell | ||
git clone https://github.com/Westlake-AI/openmixup.git | ||
cd openmixup | ||
python setup.py develop | ||
``` | ||
Now you can use the image you just built for your own project. | ||
|
||
### Training Script | ||
|
||
Here, we provide example scripts for you to quickly start the accelerated end-to-end multiple GPUs training with specified `CONFIG_FILE`. | ||
Here, we provide scripts for starting a quick end-to-end training with multiple `GPUs` and the specified `CONFIG_FILE`. | ||
```shell | ||
bash tools/dist_train.sh ${CONFIG_FILE} ${GPUS} [optional arguments] | ||
``` | ||
To be more specific, you can run the script below to train a designated mixup CIFAR100 classification algorithm with 4 GPUs: | ||
For example, you can run the script below to train a ResNet-50 classifier on ImageNet with 4 GPUs: | ||
```shell | ||
CUDA_VISIBLE_DEVICES=0,1,2,3 bash tools/dist_train.sh openmixup\configs\classification\cifar100\mixups\basic\r18_mixups_CE_none.py 4 | ||
CUDA_VISIBLE_DEVICES=0,1,2,3 PORT=29500 bash tools/dist_train.sh configs/classification/imagenet/resnet/resnet50_4xb64_cos_ep100.py 4 | ||
``` | ||
|
||
### Evaluation Script | ||
After trianing, you can test the trained models with the corresponding evaluation script. An example with 4 GPUs evaluation is as follows: | ||
|
||
After trianing, you can test the trained models with the corresponding evaluation script: | ||
```shell | ||
CUDA_VISIBLE_DEVICES=0,1,2,3 bash tools/dist_test.sh ${CONFIG_FILE} ${GPUS} ${PATH_TO_MODEL} [optional arguments] | ||
bash tools/dist_test.sh ${CONFIG_FILE} ${GPUS} ${PATH_TO_MODEL} [optional arguments] | ||
``` | ||
|
||
### Develop | ||
### Development | ||
|
||
Please see [Tutorials](docs/en/tutorials) for more developing examples and tech details: | ||
|
||
- [config files](docs/en/tutorials/0_config.md) | ||
|
@@ -276,7 +241,7 @@ This project is released under the [Apache 2.0 license](LICENSE). See `LICENSE` | |
|
||
## Citation | ||
|
||
If you find this project useful in your research, please consider cite our GitHub repo or [tech report](https://arxiv.org/abs/2209.04851): | ||
If you find this project useful in your research, please consider star our GitHub repo and cite [tech report](https://arxiv.org/abs/2209.04851): | ||
|
||
```BibTeX | ||
@misc{2022openmixup, | ||
|
@@ -301,14 +266,12 @@ If you find this project useful in your research, please consider cite our GitHu | |
|
||
## Contributors and Contact | ||
|
||
For now, the direct contributors include: Siyuan Li ([@Lupin1998](https://github.com/Lupin1998)), Zedong Wang ([@Jacky1128](https://github.com/Jacky1128)), Zicheng Liu ([@pone7](https://github.com/pone7)), Di Wu ([@wudi-bu](https://github.com/wudi-bu)), Tengfei Wang ([@wang-tf](https://github.com/wang-tf)), and Minglong Liu ([@minhlong94](https://github.com/minhlong94)). We thank contributors from MMSelfSup and MMClassification and all public contributors! | ||
For help, new features, or reporting bugs associated with OpenMixup, please open a [GitHub issue](https://github.com/Westlake-AI/openmixup/issues) and [pull request](https://github.com/Westlake-AI/openmixup/pulls) with the tag "help wanted" or "enhancement". For now, the direct contributors include: Siyuan Li ([@Lupin1998](https://github.com/Lupin1998)), Zedong Wang ([@Jacky1128](https://github.com/Jacky1128)), and Zicheng Liu ([@pone7](https://github.com/pone7)). We thank all public contributors and contributors from MMSelfSup and MMClassification! | ||
|
||
This repo is currently maintained by: | ||
|
||
- Siyuan Li ([email protected]), Westlake University | ||
- Zedong Wang ([email protected]), Westlake University | ||
- Zicheng Liu ([email protected]), Westlake University | ||
|
||
If you have suggestions that would make OpenMixup better, please fork the repo and create a pull request. It is also encouraged to open an issue with the tag "help wanted" or "enhancement". Don't forget to give our OpenMixup a star! Thanks again! | ||
|
||
<p align="right">(<a href="#top">back to top</a>)</p> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
43 changes: 43 additions & 0 deletions
43
configs/classification/imagenet/deit/deit_base_adan_8xb256_fp16_ep150.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,43 @@ | ||
_base_ = [ | ||
'../../_base_/models/deit/deit_base_p16_sz224.py', | ||
'../../_base_/datasets/imagenet/swin_sz224_8xbs128.py', | ||
'../../_base_/default_runtime.py', | ||
] | ||
|
||
# data | ||
data = dict(imgs_per_gpu=256, workers_per_gpu=12) | ||
sampler = "RepeatAugSampler" # the official repo uses `repeated_aug` for more stable training | ||
|
||
# additional hooks | ||
update_interval = 1 # 256 x 8gpus x 1 accumulates = bs2048 | ||
|
||
# optimizer | ||
optimizer = dict( | ||
type='Adan', | ||
lr=1.5e-2, # lr = 1.5e-2 / bs2048 | ||
weight_decay=0.02, eps=1e-8, betas=(0.98, 0.92, 0.99), | ||
max_grad_norm=5.0, | ||
paramwise_options={ | ||
'(bn|ln|gn)(\d+)?.(weight|bias)': dict(weight_decay=0.), | ||
'norm': dict(weight_decay=0.), | ||
'bias': dict(weight_decay=0.), | ||
'cls_token': dict(weight_decay=0.), | ||
'pos_embed': dict(weight_decay=0.), | ||
}) | ||
|
||
# fp16 | ||
use_fp16 = True | ||
fp16 = dict(type='mmcv', loss_scale='dynamic') | ||
optimizer_config = dict(update_interval=update_interval) | ||
|
||
# lr scheduler | ||
lr_config = dict( | ||
policy='CosineAnnealing', | ||
by_epoch=False, min_lr=1e-8, | ||
warmup='linear', | ||
warmup_iters=60, warmup_by_epoch=True, # warmup 60 epochs. | ||
warmup_ratio=1e-8, | ||
) | ||
|
||
# runtime settings | ||
runner = dict(type='EpochBasedRunner', max_epochs=150) |
4 changes: 4 additions & 0 deletions
4
configs/classification/imagenet/deit/deit_base_adan_8xb256_fp16_ep300.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
_base_ = './deit_base_adan_8xb256_fp16_ep150.py' | ||
|
||
# runtime settings | ||
runner = dict(type='EpochBasedRunner', max_epochs=300) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.