#!/usr/bin/env bash
# Parameters for DS-FedDRO (Algorithm 3)
DATALIST=(cifar10)
BATCHSIZE=(16)
EPOCH=120  # Number of global rounds (T in Algorithm 3)
MODEL=resnet20
CHECKPOINTS=ckps
R=.pth.tar
DR=10
GPUS=(1 2 3 4)
ALGNAME=( DS_FedDRO_M)  # Updated to DS-FedDRO algorithm
LAMDA1=(50)
WLR_X=(0.5 0.1 0.1 0.7)  # Learning rate for x (ita_x)
WLR_Y=(0.01 0.05 0.1 0.2) # Learning rate for y (ita_y)
PLR=(1e-4 5e-5 5e-4)
IMRATIO=(0.02 0.2)
RHO=(0.01 0.05 0.1 0.5 1)
BETA=(0.6)
CLASSTAU=(0.05 0.1 0.15)
COMM_ROUNDS=1  # Set communication rounds (I in Algorithm 3)

for ((wlr_x=1; wlr_x<2; wlr_x++)); do
{
  for ((wlr_y=0; wlr_y<1; wlr_y++)); do
  {
    for ((agm=0; agm<1; agm++)); do
    {
      for ((rpt=40; rpt<41; rpt++)); do
      {
        for ((da=0; da<1; da++)); do
        {
          for ((r=3; r<4; r++)); do
          {
            for ((plr=0; plr<1; plr++)); do
            {
              for ((lbd=0; lbd<1; lbd++)); do
              {
                for ((b=0; b<1; b++)); do
                {
                  for ((ctu=0; ctu<1; ctu++)); do
                  {
                    python3 -W ignore main.py \
                      --dataset ${DATALIST[$da]} \
                      --model $MODEL \
                      --saveFolder ${DATALIST[$da]}/${ALGNAME[$agm]}/Wm_${ALGNAME[$agm]}_wlr_x_${WLR_X[$wlr_x]}_wlr_y_${WLR_Y[$wlr_y]}_rho_${RHO[$r]}_beta_${BETA[$b]}_plr_${PLR[$plr]}_lambda1_${LAMDA1[$lbd]}_batch_${BATCHSIZE}_epochs_${EPOCH}_model_${MODEL}_DR_${DR}_Repeats_${rpt} \
                      --res_filename ${DATALIST[$da]}_${ALGNAME[$agm]}_wlr_x_${WLR_X[$wlr_x]}_wlr_y_${WLR_Y[$wlr_y]}_rho_${RHO[$r]}_beta_${BETA[$b]}_plr_${PLR[$plr]}_lambda0_${LAMDA0[$lbd]}_batch_${BATCHSIZE}_epochs_${EPOCH}_model_${MODEL}_DR_${DR}_Repeats_${rpt}_class_tau_${CLASSTAU[$ctu]} \
                      --epochs ${EPOCH} \
                      --batch-size ${BATCHSIZE} \
                      --gpus 1 \
                      --lr_x ${WLR_X[$wlr_x]} \   # Learning rate for x
                      --lr_y ${WLR_Y[$wlr_y]} \   # Learning rate for y
                      --restart_init_loop 1 \
                      --lamda ${LAMDA1[$lbd]} \
                      --lamda1 ${LAMDA1[$lbd]} \
                      --alg ${ALGNAME[$agm]} \
                      --momentum 0.5 \
                      --im_ratio ${IMRATIO[$da]} \
                      --DR ${DR} \
                      --sampleType uniform \
                      --plr ${PLR[$plr]} \
                      --rho ${RHO[$r]} \
                      --beta ${BETA[$b]} \
                      --class_tau ${CLASSTAU[$ctu]} \
                      --lrlambda 0.00001 \
                      --lamda0 1e-3 \
                      --random_seed ${rpt} \
                      --print_freq 50 \
                      --local_ep 1 \
                      --update_x_k v0 \
                      --local_bs 64 \
                      --local_opt sgd \
                      --local_lr 0.1 \
                      --num_users 32 \
                      --I ${COMM_ROUNDS}  # Communication rounds
                  }
                  done
                }
                done
              }
              done
            }
            done
          }
          done
        }
        done
      }
      done
    }
    done
  }
  done
}&
done
}
done
}
done
