# bash scripts/run.sh > formal_exps.log 2>&1 &

for method in coopt; do
    # ## tab2

    # # CIFAR10, CIFAR100
    # for dataset in CIFAR10 CIFAR100; do
    #     python main.py --method $method  \
    #     --save_frequency 1 --model resnet18_modified --dataset $dataset \
    #     --align_method align_to_best --avg_method no_equal_avg --client_comb 'comb_table2' \
    #     --devices [0]

    #     python eval.py --method $method --dataset $dataset \
    #     --align_method align_to_best --avg_method no_equal_avg --client_comb 'comb_table2' \
    #     --model resnet18_modified --devices [0]
        
    # done
    
    # # Tiny ImageNet
    # for dataset in TinyImageNet; do
    #     python main.py --method $method --dataset $dataset \
    #     --save_frequency 1 --model resnet18_modified   \
    #     --align_method align_to_best --avg_method no_equal_avg --client_comb 'comb_table2' \
    #     --devices [0]

    #     python eval.py --method $method --dataset $dataset \
    #     --align_method align_to_best --avg_method no_equal_avg --client_comb 'comb_table2' \
    #     --model resnet18_modified --devices [0]
    # done
    
    # # # ImageNet-1k
    # # for dataset in ImageNet-1K; do
    # #     python main.py --method $method --dataset $dataset \
    # #     --save_frequency 1 --model resnet50   \
    # #     --align_method align_to_best --avg_method no_equal_avg --client_comb 'comb_table2' \
    # #     --devices [0,1]

    # #     python eval.py --method $method --dataset $dataset \
    # #     --align_method align_to_best --avg_method no_equal_avg --client_comb 'comb_table2' \
    # #     --model resnet50  --devices [0,1]
    # # done

    # ## tab3
    
    # # CIFAR10, CIFAR100
    # for dataset in CIFAR10 CIFAR100; do
    #     for client_comb in comb_table3_cf10 comb_table3_cf100 comb_table3_tin comb_table3_in1k; do
    #         python main.py --method $method  \
    #         --save_frequency 1 --model resnet18_modified --dataset $dataset \
    #         --align_method align_to_best --avg_method no_equal_avg --client_comb $client_comb \
    #         --devices [0]

    #         python eval.py --method $method --dataset $dataset \
    #         --align_method align_to_best --avg_method no_equal_avg --client_comb $client_comb \
    #         --model resnet18_modified --devices [0]
    #     done
    # done

    # # Tiny ImageNet
    # for dataset in TinyImageNet; do
    #     for client_comb in comb_table3_cf10 comb_table3_cf100 comb_table3_tin comb_table3_in1k; do
    #         python main.py --method $method  \
    #         --save_frequency 1 --model resnet18_modified --dataset $dataset \
    #         --align_method align_to_best --avg_method no_equal_avg --client_comb $client_comb \
    #         --devices [0]

    #         python eval.py --method $method --dataset $dataset \
    #         --align_method align_to_best --avg_method no_equal_avg --client_comb $client_comb \
    #         --model resnet18_modified --devices [0]
    #     done
    # done

    # # # ImageNet-1k
    # # for dataset in ImageNet-1k; do
    # #     for client_comb in comb_table3_cf10 comb_table3_cf100 comb_table3_tin comb_table3_in1k; do
    # #         python main.py --method $method  \
    # #         --save_frequency 1 --model resnet50 --dataset $dataset \
    # #         --align_method align_to_best --avg_method no_equal_avg --client_comb $client_comb \
    # #         --devices [0,1]

    # #         python eval.py --method $method --dataset $dataset \
    # #         --align_method align_to_best --avg_method no_equal_avg --client_comb $client_comb \
    # #         --model resnet50 --devices [0,1]
    # #     done
    # # done
    
    # ## tab5

    # for client_comb in comb_table5_0.5_model; do
        
    #     # CIFAR10, CIFAR100
    #     for dataset in CIFAR10 CIFAR100; do
    #         python main.py --method $method  \
    #         --save_frequency 1 --model resnet18_modified --dataset $dataset \
    #         --align_method align_to_best --avg_method no_equal_avg --client_comb $client_comb \
    #         --devices [1]

    #         python eval.py --method $method --dataset $dataset \
    #         --align_method align_to_best --avg_method no_equal_avg --client_comb $client_comb \
    #         --model resnet18_modified --devices [1]
            
    #     done
    
    #     # Tiny ImageNet
    #     for dataset in TinyImageNet; do
    #         python main.py --method $method --dataset $dataset \
    #         --save_frequency 1 --model resnet18_modified   \
    #         --align_method align_to_best --avg_method no_equal_avg --client_comb $client_comb \
    #         --devices [1]

    #         python eval.py --method $method --dataset $dataset \
    #         --align_method align_to_best --avg_method no_equal_avg --client_comb $client_comb \
    #         --model resnet18_modified --devices [1]
    #     done

    #     # # ImageNet-1k
    #     # for dataset in ImageNet-1K; do
    #     #     python main.py --method $method --dataset $dataset \
    #     #     --save_frequency 1 --model resnet50   \
    #     #     --align_method align_to_best --avg_method no_equal_avg --client_comb $client_comb \
    #     #     --devices [0,1]

    #     #     python eval.py --method $method --dataset $dataset \
    #     #     --align_method align_to_best --avg_method no_equal_avg --client_comb $client_comb \
    #     #     --model resnet50  --devices [0,1]
    #     # done
    
    # done

    ## tab6 (Ablation Study)

    # # no align
    # for dataset in TinyImageNet; do
    #     python main.py --method $method --p_data_align 0 \
    #     --save_frequency 1 --model resnet18_modified --dataset $dataset \
    #     --align_method align_to_best --avg_method no_equal_avg --client_comb comb_table6_cf100 \
    #     --devices [0]

    #     python eval.py --method $method --p_data_align 0 --dataset $dataset \
    #     --align_method align_to_best --avg_method no_equal_avg --client_comb comb_table6_cf100 \
    #     --model resnet18_modified --devices [0] 
    # done
    
    # align to medium/worst (best has been tested before)
    for align_method in align_to_worst; do
        for dataset in TinyImageNet; do
            python main.py --method $method  \
            --save_frequency 1 --model resnet18_modified --dataset $dataset \
            --align_method $align_method --avg_method no_equal_avg --client_comb comb_table6_cf100 \
            --devices [0]

            python eval.py --method $method --dataset $dataset \
            --align_method $align_method --avg_method no_equal_avg --client_comb comb_table6_cf100 \
            --model resnet18_modified --devices [0] 
        done
    done
    
    # # fig11 (Ablation Study)

    # # equal_avg (avg ensemble) (no_equal_avg has been tested before)
    # for dataset in CIFAR100; do
    #     python main.py --method $method  \
    #     --save_frequency 1 --model resnet18_modified --dataset $dataset \
    #     --align_method align_to_best --avg_method equal_avg --client_comb comb_fig11_cf100 \
    #     --devices [0]

    #     python eval.py --method $method --dataset $dataset \
    #     --align_method align_to_best --avg_method equal_avg --client_comb comb_fig11_cf100 \
    #     --model resnet18_modified --devices [0] 
    # done

    # # table4
    # python main.py --method $method --dataset CIFAR10 \
    # --save_frequency 1 --model resnet18_modified   \
    # --align_method align_to_best --avg_method no_equal_avg --client_comb comb_tab4_cf10 \
    # --devices [0]

    # python eval.py --method $method --dataset CIFAR10 \
    # --align_method align_to_best --avg_method no_equal_avg --client_comb comb_tab4_cf10 \
    # --model resnet18_modified --devices [0]

    # python main.py --method $method --dataset CIFAR100 \
    # --save_frequency 1 --model resnet18_modified   \
    # --align_method align_to_best --avg_method no_equal_avg --client_comb comb_tab4_cf100 \
    # --devices [0]

    # python eval.py --method $method --dataset CIFAR100 \
    # --align_method align_to_best --avg_method no_equal_avg --client_comb comb_tab4_cf100 \
    # --model resnet18_modified --devices [0]

    # python main.py --method $method --dataset TinyImageNet  \
    # --save_frequency 1 --model resnet18_modified   \
    # --align_method align_to_best --avg_method no_equal_avg --client_comb comb_tab4_tin \
    # --devices [0]

    # python eval.py --method $method --dataset TinyImageNet \
    # --align_method align_to_best --avg_method no_equal_avg --client_comb comb_tab4_tin \
    # --model resnet18_modified --devices [0]
done



