#! /bin/sh
rootdir="./results"

config="configs/common.yaml"
optim_name="fedproxdowl_init_eta1e-2_init_mu1.0_wd1e-8_warmup0"
optim_config="configs/optimizers/${optim_name}.yaml"

loglevel="INFO"
nduplicate=1

seed=17
data_seed=11

N=7
node_config="configs/nodes/node${N}.yaml"

lrs=(1e-2 )
lr_mins=(1e-2 )
datasets=("mnist" "cifar-100" "cifar-10" )
models=("mlp" "resnet18_ng4_dp0.4" "resnet18_ng4_dp0.4" )

alphas=(100.0 )
nsteps=(10000)
t_initial=8000
inner_loops=(100)
batch_size=64
min_size_rate=0.8

for nstep in ${nsteps[@]}; do
for inner_loop in ${inner_loops[@]}; do
for alpha in ${alphas[@]}; do
for dataset_idx in `seq 0 $((${#datasets[@]}-1))`; do
for lr_idx in `seq 0 $((${#lrs[@]}-1))`; do

dataset=${datasets[dataset_idx]}
model=${models[dataset_idx]}
lr=${lrs[lr_idx]}
lr_min=${lr_mins[lr_idx]}
model_config="configs/models/${model}_${dataset}.yaml"
train_config="configs/trains/${dataset}.yaml"

if [ ${inner_loop} -eq 100 ]; then
  outer_loop=1
elif [ ${inner_loop} -eq 10 ]; then
  outer_loop=10
elif [ ${inner_loop} -eq 1 ]; then
  outer_loop=100
fi

dataset_config="configs/datasets/${dataset}_dirichlet_alpha${alpha}_min_size_rate${min_size_rate}_label_sort.yaml"
outdir="${rootdir}/n${N}_${model}_${dataset}_ds${data_seed}_b${batch_size}_alpha${alpha}_${optim_name}_lr${lr}-${lr_min}_s${nstep}-${outer_loop}-${inner_loop}"
bash ~/proxy.sh
python main.py ${outdir} ${config} ${node_config} ${dataset_config} ${model_config} ${optim_config} ${train_config} \
  --nstep ${nstep} --nouter ${outer_loop} --ninner ${inner_loop} --batch_size ${batch_size} \
  --lr ${lr} --lr_min ${lr_min} --seed ${seed} --data_seed ${data_seed} --data_nduplicate ${nduplicate} \
  --t_initial ${t_initial} \
  --logfile ${outdir}/stdout.txt --loglevel ${loglevel} --quiet 

done
done
done
done
done



