# temp scaling
CUDA_VISIBLE_DEVICES=7 python train.py --dataset cifar100 --layers 40 --widen-factor 10 --tensorboard \
    --loss cross_entropy \
    --model wideresnet_50_2 --dataset imagenet \
    --model_seed 1 --data_seed 100 \
    --split_size=1181167 --batch-size=128 --val_batch_size=128 --use_split train_val \
    --use_temp --temp_model const --min_temp 0.2 \
    --lr 0.01 --scheduler onecycle --epochs 5 --wd=0.0 --optimizer sgd \
    --resume ./runs/imagenet/WRN-50-2-modelseed-1-dataseed-100-split-1181167-100epochs/checkpoint.pth.tar \
    --resume_from_ddp \
    --name  imagenet/temp_model/const_sgd_lr_0.01_onecycle_5epochs &

# temp scaling, ece loss
CUDA_VISIBLE_DEVICES=6 python train.py --dataset cifar100 --layers 40 --widen-factor 10 --tensorboard \
    --loss cross_entropy \
    --model wideresnet_50_2 --dataset imagenet \
    --model_seed 1 --data_seed 100 \
    --split_size=1181167 --batch-size=128 --val_batch_size=128 --use_split train_val \
    --use_temp --temp_model const --min_temp 0.2 \
    --nll_weight 0.0 --ece_weight 10.0 --ece_num_partitions_train 5 \
    --lr 0.01 --scheduler onecycle --epochs 5 --wd=0.0 --optimizer sgd \
    --resume ./runs/imagenet/WRN-50-2-modelseed-1-dataseed-100-split-1181167-100epochs/checkpoint.pth.tar \
    --resume_from_ddp \
    --name  imagenet/temp_model/const_eceloss_w_10.0_B_5_sgd_lr_0.01_onecycle_5epochs &

# individualized temp scaling
CUDA_VISIBLE_DEVICES=5 python train.py --dataset cifar100 --layers 40 --widen-factor 10 --tensorboard \
    --loss cross_entropy \
    --model wideresnet_50_2 --dataset imagenet \
    --model_seed 1 --data_seed 100 \
    --split_size=1181167 --batch-size=128 --val_batch_size=128 --use_split train_val \
    --use_temp --temp_model nn_on_reps --temp_model_depth 2 --temp_model_width 512 --min_temp 0.2 \
    --lr 0.01 --scheduler onecycle --epochs 5 --wd=0.0 --optimizer sgd \
    --resume ./runs/imagenet/WRN-50-2-modelseed-1-dataseed-100-split-1181167-100epochs/checkpoint.pth.tar \
    --resume_from_ddp \
    --name  imagenet/temp_model/nn_on_reps_[5]_2layer_sgd_lr_0.01_onecycle_5epochs &

# individualized temp scaling, ece loss
CUDA_VISIBLE_DEVICES=4 python train.py --dataset cifar100 --layers 40 --widen-factor 10 --tensorboard \
    --loss cross_entropy \
    --model wideresnet_50_2 --dataset imagenet \
    --model_seed 1 --data_seed 100 \
    --split_size=1181167 --batch-size=128 --val_batch_size=128 --use_split train_val \
    --use_temp --temp_model nn_on_reps --temp_model_depth 2 --temp_model_width 512 --min_temp 0.2 \
    --nll_weight 0.0 --ece_weight 10.0 --ece_num_partitions_train 5 \
    --lr 0.01 --scheduler onecycle --epochs 5 --wd=0.0 --optimizer sgd \
    --resume ./runs/imagenet/WRN-50-2-modelseed-1-dataseed-100-split-1181167-100epochs/checkpoint.pth.tar \
    --resume_from_ddp \
    --name  imagenet/temp_model/nn_on_reps_[5]_2layer_eceloss_w_10.0_B_5_sgd_lr_0.01_onecycle_5epochs &

# generalized calibration, ece loss
CUDA_VISIBLE_DEVICES=3 python train.py --dataset cifar100 --layers 40 --widen-factor 10 --tensorboard \
    --loss cross_entropy \
    --model wideresnet_50_2 --dataset imagenet \
    --model_seed 1 --data_seed 100 \
    --split_size=1181167 --batch-size=128 --val_batch_size=128 --use_split train_val \
    --use_calib --calib_model nn_on_reps --temp_model_depth 2 --temp_model_width 512 --min_temp 0.2 \
    --neg_slope 2.0 --min_temp 0.2 --temp_init_increment 0.5 \
    --nll_weight 0.0 --ece_weight 10.0 --ece_num_partitions_train 5 \
    --lr 0.01 --scheduler onecycle --epochs 5 --wd=0.0 --optimizer sgd \
    --resume ./runs/imagenet/WRN-50-2-modelseed-1-dataseed-100-split-1181167-100epochs/checkpoint.pth.tar \
    --resume_from_ddp \
    --name  imagenet/calib_model/nn_on_reps_[5]_2layer_initinc_0.5_slope_2.0_eceloss_w_10.0_B_5_sgd_lr_0.01_onecycle_5epochs &

CUDA_VISIBLE_DEVICES=2 python train.py --dataset cifar100 --layers 40 --widen-factor 10 --tensorboard \
    --loss cross_entropy \
    --model wideresnet_50_2 --dataset imagenet \
    --model_seed 1 --data_seed 100 \
    --split_size=1181167 --batch-size=128 --val_batch_size=128 --use_split train_val \
    --use_calib --calib_model nn_on_reps --temp_model_depth 2 --temp_model_width 512 --min_temp 0.2 \
    --neg_slope 1.5 --min_temp 0.2 --temp_init_increment 0.5 \
    --nll_weight 0.0 --ece_weight 10.0 --ece_num_partitions_train 5 \
    --lr 0.01 --scheduler onecycle --epochs 5 --wd=0.0 --optimizer sgd \
    --resume ./runs/imagenet/WRN-50-2-modelseed-1-dataseed-100-split-1181167-100epochs/checkpoint.pth.tar \
    --resume_from_ddp \
    --name  imagenet/calib_model/nn_on_reps_[5]_2layer_initinc_0.5_slope_1.5_eceloss_w_10.0_B_5_sgd_lr_0.01_onecycle_5epochs &

CUDA_VISIBLE_DEVICES=1 python train.py --dataset cifar100 --layers 40 --widen-factor 10 --tensorboard \
    --loss cross_entropy \
    --model wideresnet_50_2 --dataset imagenet \
    --model_seed 1 --data_seed 100 \
    --split_size=1181167 --batch-size=128 --val_batch_size=128 --use_split train_val \
    --use_calib --calib_model nn_on_reps --temp_model_depth 2 --temp_model_width 512 --min_temp 0.2 \
    --neg_slope 0.8 --min_temp 0.2 --temp_init_increment 0.5 \
    --nll_weight 0.0 --ece_weight 10.0 --ece_num_partitions_train 5 \
    --lr 0.01 --scheduler onecycle --epochs 5 --wd=0.0 --optimizer sgd \
    --resume ./runs/imagenet/WRN-50-2-modelseed-1-dataseed-100-split-1181167-100epochs/checkpoint.pth.tar \
    --resume_from_ddp \
    --name  imagenet/calib_model/nn_on_reps_[5]_2layer_initinc_0.5_slope_0.8_eceloss_w_10.0_B_5_sgd_lr_0.01_onecycle_5epochs &

CUDA_VISIBLE_DEVICES=0 python train.py --dataset cifar100 --layers 40 --widen-factor 10 --tensorboard \
    --loss cross_entropy \
    --model wideresnet_50_2 --dataset imagenet \
    --model_seed 1 --data_seed 100 \
    --split_size=1181167 --batch-size=128 --val_batch_size=128 --use_split train_val \
    --use_calib --calib_model nn_on_reps --temp_model_depth 2 --temp_model_width 512 --min_temp 0.2 \
    --neg_slope 0.5 --min_temp 0.2 --temp_init_increment 0.5 \
    --nll_weight 0.0 --ece_weight 10.0 --ece_num_partitions_train 5 \
    --lr 0.01 --scheduler onecycle --epochs 5 --wd=0.0 --optimizer sgd \
    --resume ./runs/imagenet/WRN-50-2-modelseed-1-dataseed-100-split-1181167-100epochs/checkpoint.pth.tar \
    --resume_from_ddp \
    --name  imagenet/calib_model/nn_on_reps_[5]_2layer_initinc_0.5_slope_0.5_eceloss_w_10.0_B_5_sgd_lr_0.01_onecycle_5epochs