This repository contains our PyTorch training code, evaluation code and pretrained models for AttentiveNAS.
[Update 06/21] Recenty, we have improved AttentiveNAS using an adaptive knowledge distillation training strategy, see our AlphaNet repo for more details of this work. AlphaNet has been accepted by ICML'21.
[Update 07/21] We provide an example code for searching the best models of FLOPs vs. accuracy trade-offs at here.
For more details, please see AttentiveNAS: Improving Neural Architecture Search via Attentive Sampling by Dilin Wang, Meng Li, Chengyue Gong and Vikas Chandra.
If you find this repo useful in your research, please consider citing our work:
@article{wang2020attentivenas,
title={AttentiveNAS: Improving Neural Architecture Search via Attentive Sampling},
author={Wang, Dilin and Li, Meng and Gong, Chengyue and Chandra, Vikas},
journal={arXiv preprint arXiv:2011.09011},
year={2020}
}
To reproduce our results:
-
Please first download our pretrained AttentiveNAS models from a Google Drive path and put the pretrained models under your local folder ./attentive_nas_data
-
To evaluate our pre-trained AttentiveNAS models, from AttentiveNAS-A0 to A6, on ImageNet with a single GPU, please run:
python test_attentive_nas.py --config-file ./configs/eval_attentive_nas_models.yml --model a[0-6]
Expected results:
Name MFLOPs Top-1 (%) AttentiveNAS-A0 203 77.3 AttentiveNAS-A1 279 78.4 AttentiveNAS-A2 317 78.8 AttentiveNAS-A3 357 79.1 AttentiveNAS-A4 444 79.8 AttentiveNAS-A5 491 80.1 AttentiveNAS-A6 709 80.7
To train our AttentiveNAS models from scratch, please run
python train_attentive_nas.py --config-file configs/train_attentive_nas_models.yml --machine-rank ${machine_rank} --num-machines ${num_machines} --dist-url ${dist_url}
We adopt SGD training on 64 GPUs. The mini-batch size is 32 per GPU; all training hyper-parameters are specified in train_attentive_nas_models.yml.
- A (sub-network config, FLOPs) lookup table could be used for constructing the architecture distribution under FLOPs-constraints.
- A accuracy predictor trained via scikit-learn, which takes a subnetwork configuration as input, and outputs its predicted accuracy on ImageNet.
- Convert a subnetwork configuration to our accuracy predictor compatibale inputs:
res = [cfg['resolution']] for k in ['width', 'depth', 'kernel_size', 'expand_ratio']: res += cfg[k] input = np.asarray(res).reshape((1, -1))
The majority of AttentiveNAS is licensed under CC-BY-NC, however portions of the project are available under separate license terms: Once For All is licensed under the Apache 2.0 license.
We actively welcome your pull requests! Please see CONTRIBUTING and CODE_OF_CONDUCT for more info.