#!/bin/bash

# python train_cbm.py --raw_set data/CUB --dataset cub --concept_set data/concept_sets/cub_filtered.txt --batch_size 64 --model gnn --lr 1e-4 --epoch 150 --coarsening
# wait

# for ratio in 0.9 0.1 0.8 0.2 0.7 0.3 0.6 0.4 0.5
# do
#     for seed in 2 22 42 62 92 12 32 52 72 82
#     do  
#         python train_graph_cbm.py --raw_set data/CUB --dataset cub --concept_set data/concept_sets/cub_filtered.txt --epoch 100 --lr 9e-4 --saved_activations --ratio $ratio --seed $seed
#         wait
#     done
# done
# for seed in 22 32 42 52 62 72 82 92
# do
#     python train_graph_cbm.py --raw_set data/CUB --dataset cub --concept_set data/concept_sets/cub_filtered.txt --epoch 100 --lr 9e-4 --saved_activations --seed $seed
# done

# python train_graph_cbm.py --raw_set data/CUB --dataset cub --concept_set data/concept_sets/cub_filtered.txt --epoch 100 --lr 9e-4 --saved_activations --ratio 0.2 --seed 2
# wait
# python train_graph_cbm.py --raw_set data/CUB --dataset cub --concept_set data/concept_sets/cub_filtered.txt --epoch 100 --lr 9e-4 --saved_activations --ratio 0.9 --seed 2
# wait
# python train_graph_cbm.py --raw_set data/CUB --dataset cub --concept_set data/concept_sets/cub_filtered.txt --epoch 100 --lr 9e-4 --saved_activations --ratio 1 --seed 2
# wait

# for ratio in 0.9 0.1 0.8 0.2 0.7 0.3 0.6 0.4 0.5
# do
#     for seed in 2 22 42 62 92 12 32 52 72 82
#     do  
#         python train_graph_cbm.py --raw_set data/CUB --dataset cub --concept_set data/concept_sets/cub_filtered.txt  --lr 0.01 --ratio $ratio --seed $seed --pooling sag --epoch=100 --saved_activations --scheduler cosine --logger
#         wait
#     done
# done
# for seed 
# sudo poweroff

# for seed in 2 12 22 32 42 52 62 72 82 92
# do
#     python train_graph_cbm.py --raw_set data/CUB --dataset cub --concept_set data/concept_sets/cub_filtered.txt  --lr 0.01 --ratio 0.2 --seed $seed --pooling sag --epoch 50 --module gat --scheduler cosine --saved_activation --random_concept --logger
# done

# for seed in 42 52 62 72 82 92
# do
#     python train_graph_cbm.py  --dataset cifar10 --concept_set data/concept_sets/cifar10_filtered.txt  --lr 0.01 --ratio 0.2 --seed $seed --pooling sag --epoch=30 --saved_activations --module gat --scheduler cosine --end2end --logger
#     python train_graph_cbm.py  --dataset cifar10 --concept_set data/concept_sets/cifar10_filtered.txt  --lr 0.01 --ratio 0.2 --seed $seed --pooling sag --epoch=30 --saved_activations --module gat --scheduler cosine --logger
#     wait
#     # python train_graph_cbm.py  --dataset cifar100 --concept_set data/concept_sets/cifar100_filtered.txt  --lr 0.01 --ratio 0.2 --seed $seed --pooling sag --epoch=30 --saved_activations --module gat --scheduler cosine --end2end --logger
#     # python train_graph_cbm.py  --dataset cifar100 --concept_set data/concept_sets/cifar100_filtered.txt  --lr 0.01 --ratio 0.2 --seed $seed --pooling sag --epoch=30 --saved_activations --module gat --scheduler cosine --logger
# done

# for seed in 2 12 22 32 42 52 62 72 82 92
# do
#     python train_graph_cbm.py --raw_set data/CUB --dataset cub --concept_set data/concept_sets/cub_filtered.txt  --lr 0.01 --ratio 0.2 --seed $seed --pooling sag --epoch 1000 --module gat --scheduler cosine --random_concept --end2end --logger --use_concept_vectors
#     wait
#     python train_graph_cbm.py --raw_set data/CUB --dataset cub --concept_set data/concept_sets/cub_filtered.txt  --lr 0.01 --ratio 0.2 --seed $seed --pooling sag --epoch 1000 --module gat --scheduler cosine --end2end --logger --use_concept_vectors
#     wait
#     python train_graph_cbm.py --raw_set data/CUB --dataset cub --concept_set data/concept_sets/cub_filtered.txt  --lr 0.01 --ratio 0.2 --seed $seed --pooling sag --epoch 100 --module gat --scheduler cosine --random_concept --sparsity 0.99 --logger --use_concept_vectors
#     wait
#     python train_graph_cbm.py --raw_set data/CUB --dataset cub --concept_set data/concept_sets/cub_filtered.txt  --lr 0.01 --ratio 0.2 --seed $seed --pooling sag --epoch 100 --module gat --scheduler cosine --sparsity 0.999 --logger --use_concept_vectors
# done

# python train_graph_cbm.py --raw_set data/CUB --dataset cub --concept_set data/concept_sets/cub_filtered.txt  --lr 0.1 --ratio 0.8 --seed 32 --pooling sag --epoch=1000 --saved_activations  --sparsity 0.9 --use_concept_vectors --scheduler cosine --end2end --logger
# python train_graph_cbm.py --raw_set data/CUB --dataset cub --concept_set data/concept_sets/cub_filtered.txt  --lr 0.1 --ratio 0.8 --seed 32 --pooling sag --epoch=30 --saved_activations  --sparsity 0.9 --use_concept_vectors --scheduler cosine --logger
# python train_graph_cbm.py --raw_set data/CUB --dataset cub --concept_set data/concept_sets/cub_filtered.txt --pooling sag --saved_activations --scheduler cosine --independent --independent_epoch 500 --epoch=10 --ratio 0.8 --seed 32 --linear_lr 0.01 --lr 0.01 --linear_schedule cosine --logger

# python train_graph_cbm.py --raw_set data/CUB --dataset cub --concept_set data/concept_sets/cub_filtered.txt  --lr 0.1 --ratio 0.2 --seed 32 --pooling sag --epoch=30 --saved_activations  --sparsity 0.9 --use_concept_vectors --scheduler cosine --logger
# python train_graph_cbm.py --raw_set data/CUB --dataset cub --concept_set data/concept_sets/cub_filtered.txt  --lr 0.1 --ratio 0.5 --seed 32 --pooling sag --epoch=30 --saved_activations  --sparsity 0.9 --use_concept_vectors --scheduler cosine --logger

# for ratio in 0.2 0.5 0.8
# do
#     for seed in 2 12 22 32 42 52 62 72 82 92
#     do
#         python train_graph_cbm.py --raw_set data/CUB --dataset cub --concept_set data/concept_sets/cub_filtered.txt  --lr 0.1 --ratio $ratio --seed $seed --pooling sag --epoch=20 --saved_activations  --sparsity 0.9 --use_concept_vectors --scheduler cosine --independent --independent_epoch 100 --linear_lr 0.1 --linear_schedule cosine --logger
#     done
# done

# for seed in 42
# do
#     for alpha in 0.1 0
#     do
#         python train_structure_cbm.py --dataset cub --seed $seed --concept_set data/concept_sets/cub_filtered.txt --epoch 50  --lr 0.01 --batch_size 256 --scheduler cosine --tau 0.5 --init_beta 0.9 --reg_alpha $alpha --learnable_graph --logger
#     done

#     python train_structure_cbm.py --dataset cub --seed $seed --concept_set data/concept_sets/cub_filtered.txt --epoch 50  --lr 0.01 --batch_size 256 --scheduler cosine --tau 0.5 --init_beta 0.9 --reg_alpha 0 --logger --graph
# done

# for seed in 2 12 22 32 42 52 62 72 82 92
# do
#     for alpha in 0.1 0
#     do
#         python train_structure_cbm.py --dataset cifar10 --seed $seed --concept_set data/concept_sets/cifar10_filtered.txt --epoch 30  --lr 0.01 --batch_size 256 --scheduler cosine --tau 0.5 --init_beta 0.8 --reg_alpha $alpha --learnable_graph --logger
#     done

#     python train_structure_cbm.py --dataset cifar10 --seed $seed --concept_set data/concept_sets/cifar10_filtered.txt --epoch 30  --lr 0.01 --batch_size 256 --scheduler cosine --tau 0.5 --init_beta 0.9 --reg_alpha 0 --logger --graph
# done

# for seed in 2 12 22 32 42 52 62 72 82 92
# do
#     for beta in 0.89 0.91
#     do
#         for alpha in 0.0 0.1 0.2
#         do
#             python train_structure_cbm.py --dataset cifar100 --seed $seed --concept_set data/concept_sets/cifar100_filtered.txt --epoch 30  --lr 0.01 --batch_size 128 --scheduler cosine --tau 0.3 --init_beta $beta --reg_alpha $alpha --learnable_graph --logger
#         done
#     done
#     # python train_structure_cbm.py --dataset cifar100 --seed $seed --concept_set data/concept_sets/cifar100_filtered.txt --epoch 30  --lr 0.01 --batch_size 128 --scheduler cosine --tau 0.5 --init_beta 0.9 --reg_alpha 0 --logger --graph
# done

# for seed in 2 12 22 32 42 52 62 72 82 92
# do
#     for alpha in 0.1 0
#     do
#         python train_structure_cbm.py --dataset imagenet --seed $seed --concept_set data/concept_sets/imagenet_filtered.txt --epoch 30  --lr 0.01 --batch_size 256 --scheduler cosine --tau 0.5 --init_beta 0.9 --reg_alpha $alpha --learnable_graph --logger
#     done

#     python train_structure_cbm.py --dataset imagenet --seed $seed --concept_set data/concept_sets/imagenet_filtered.txt --epoch 30  --lr 0.01 --batch_size 256 --scheduler cosine --tau 0.5 --init_beta 0.9 --reg_alpha 0 --logger --graph
# done

# for seed in 2 12 22 32 42 52 62 72 82 92
# do
#     for alpha in 0.1 0
#     do
#         python train_structure_cbm.py --dataset places365 --seed $seed --concept_set data/concept_sets/places365_filtered.txt --epoch 30  --lr 0.01 --batch_size 256 --scheduler cosine --tau 0.5 --init_beta 0.9 --reg_alpha $alpha --learnable_graph --logger
#     done

#     python train_structure_cbm.py --dataset places365 --seed $seed --concept_set data/concept_sets/places365_filtered.txt --epoch 30  --lr 0.01 --batch_size 256 --scheduler cosine --tau 0.5 --init_beta 0.9 --reg_alpha 0 --logger --graph
# done


# sudo poweroff

# intervention
# python intervention.py --dataset cifar100 --concept_set data/concept_sets/cifar100_filtered.txt --batch_size 128 --random_intervention --graph --model_dir_name cifar100_seed_2_no_graph --size 159
# python intervention.py --dataset cxr11 --concept_set data/concept_sets/cxr11_filtered.txt --batch_size 256 --graph --model_dir_name num_epochs_50_cxr11_seed_22_no_graph --size 69
# python train_structure_cbm.py --dataset places365 --seed 42 --concept_set data/concept_sets/places365_filtered.txt --epoch 30  --lr 0.01 --batch_size 256 --scheduler cosine --tau 0.5 --init_beta 0.9 --reg_alpha 0.1 --learnable_graph --logger
# CUDA_VISIBLE_DEVICES=7 python intervene_graph_cbm.py --dataset {dataset} --concept_set data/concept_sets/{dataset}_filtered.txt --batch_size 128 --saved_model {saved_model} --seed {seed} --ratio {ratio} --logger
# CUDA_VISIBLE_DEVICES=6 python intervene_graph_cbm.py --dataset cub --concept_set data/concept_sets/cub_filtered.txt --batch_size 128 --saved_model backbone_ViT-B16_num_epochs_100_cub_seed_42_num_edges_22_alpha_0.2_beta_0.8_tau_0.1 --seed 42 --ratio 0.1 --logger
# CUDA_VISIBLE_DEVICES=3 python intervene_graph_cbm.py --dataset ham10000 --concept_set data/concept_sets/ham10000_filtered.txt --batch_size 128 --saved_model saved_models/backbone_ViT-B16_num_epochs_100_ham10000_seed_2_num_edges_101_alpha_0.05_beta_0.8_tau_0.1 --seed 2 --ratio 0.1 --logger
# CUDA_VISIBLE_DEVICES=1 python intervene_graph_cbm.py --dataset cifar100 --concept_set data/concept_sets/cifar100_filtered.txt --batch_size 128 --saved_model saved_models/backbone_ViT-B16_num_epochs_100_ham10000_seed_2_num_edges_101_alpha_0.05_beta_0.8_tau_0.1 --seed 2 --ratio 0.1 --logger
# CUDA_VISIBLE_DEVICES=1 python intervene_graph_cbm.py --dataset cifar100 --concept_set data/concept_sets/cifar100_filtered.txt --batch_size 128 --logger --filtering submodular --filtering_size 50 --seed 2 --ratio 0.1 --saved_model saved_models/backbone_ViT-B16_num_epochs_30_cifar100_seed_2_no_graph --graph
# CUDA_VISIBLE_DEVICES=1 python intervene_graph_cbm.py --dataset cifar100 --concept_set data/concept_sets/cifar100_filtered.txt --batch_size 128 --logger --filtering submodular --filtering_size 50 --seed 2 --ratio 0.1 --saved_model saved_models/backbone_ViT-B16_num_epochs_30_cifar100_seed_2_no_graph --graph
# CUDA_VISIBLE_DEVICES=7 python intervene_standard_cbm.py --dataset cub --concept_set data/concept_sets/cub_filtered.txt --batch_size 128 --saved_model /home/hxu2/CBM-Graph/cbm_supervision_outputs/cub_joint_supervised_seed_2_lr_0.003_epoch_100_alpha_0.1_beta_0.1 --seed 2 --ratio 0.1 --logger --graph

# CUDA_VISIBLE_DEVICES=4 python intervene_on_nodes.py --dataset cub --concept_set data/concept_sets/cub_filtered.txt --batch_size 128 --saved_model saved_models/backbone_ViT-B16_num_epochs_100_cub_seed_42_num_edges_22_alpha_0.2_beta_0.8_tau_0.1 --seed 42 --ratio 0.1 --logger
# for seed in 42 
# do
#     for alpha in 0.1 0
#     do
#         python train_structure_cbm.py --dataset cub --seed $seed --concept_set data/concept_sets/cub_filtered.txt --epoch 50  --lr 0.01 --batch_size 256 --scheduler cosine --tau 0.5 --init_beta 0.9 --reg_alpha $alpha --learnable_graph --logger
#     done

#     python train_structure_cbm.py --dataset cub --seed $seed --concept_set data/concept_sets/cub_filtered.txt --epoch 50  --lr 0.01 --batch_size 256 --scheduler cosine --tau 0.5 --init_beta 0.9 --reg_alpha 0 --logger --graph
# done

# python train_structure_cbm.py --dataset fitzpatrick --concept_set data/concept_sets/fitzpatrick_filtered.txt --epoch 30  --lr 0.01 --batch_size 128 --scheduler cosine --tau 0.3 --init_beta 0.1 --reg_alpha 0.9 --learnable_graph --logger --with_supervision --ddi_name deepderm

# for tau in 0.1 0.5
# do
#     python train_structure_cbm.py --dataset cifar100 --seed 42 --concept_set data/concept_sets/cifar100_filtered.txt --epoch 30  --lr 0.01 --batch_size 128 --scheduler cosine --tau 0.3 --init_beta 0.9 --reg_alpha 0.2 --learnable_graph --logger

#     # python train_structure_cbm.py --dataset cifar100 --seed $seed --concept_set data/concept_sets/cifar100_filtered.txt --epoch 30  --lr 0.01 --batch_size 128 --scheduler cosine --tau 0.5 --init_beta 0.9 --reg_alpha 0 --logger --graph
# done

# for seed in 72 82 92
# do
#     python train_structure_cbm.py --dataset flower --seed $seed --concept_set data/concept_sets/flower_filtered.txt --epoch 30  --lr 0.01 --batch_size 256 --scheduler cosine --tau 0.3 --init_beta 0.9 --reg_alpha 0 --logger --graph
#     for beta in 0.8 0.85 0.9
#     do
#         for alpha in 0.2 0.1 0
#         do
#             python train_structure_cbm.py --dataset flower --seed $seed --concept_set data/concept_sets/flower_filtered.txt --epoch 30  --lr 0.01 --batch_size 256 --scheduler cosine --tau 0.3 --init_beta $beta --reg_alpha $alpha --learnable_graph --logger
#         done
#     done
# done
# sudo poweroff

# python train_structure_cbm.py --dataset cxr8 --concept_set data/concept_sets/cxr8_filtered.txt --epoch 100  --lr 0.01 --batch_size 512 --scheduler cosine --tau 0.3 --init_beta 0.9 --reg_alpha 0 --logger --graph --clip_name BioViL_T
# python train_structure_cbm.py --dataset cxr8 --concept_set data/concept_sets/cxr8_filtered.txt --epoch 100  --lr 0.01 --batch_size 512 --scheduler cosine --tau 0.3 --init_beta 0.9 --reg_alpha 0.1 --learnable_graph --logger --clip_name BioViL_T
# CUDA_VISIBILE_DEVICES=0 python finetune_structure_cbm.py --dataset cxr8 --concept_set data/concept_sets/cxr8_filtered.txt --foundation_model BioViL_T

# CUDA_VISIBILE_DEVICES=0 python finetune_structure_cbm.py --dataset cxr8 --foundation_model BioViL_T --concept_set data/concept_sets/cxr8_filtered.txt --epoch 20 --batch_size 128 --scheduler cosine --init_beta 0.9 --reg_alpha 0.1 --graph --lr 3e-4 --logger
# CUDA_VISIBILE_DEVICES=0 python finetune_structure_cbm.py --dataset cxr8 --foundation_model BioViL_T --concept_set data/concept_sets/cxr8_filtered.txt --epoch 20 --batch_size 128 --scheduler cosine --init_beta 0.9 --reg_alpha 0.2 --learnable_graph --lr 3e-4 --logger
# CUDA_VISIBILE_DEVICES=0 python finetune_structure_cbm.py --dataset cxr8 --foundation_model BioViL_T --concept_set data/concept_sets/cxr8_filtered.txt --epoch 20 --batch_size 128 --scheduler cosine --init_beta 0.9 --reg_alpha 0.5 --learnable_graph --lr 3e-4 --logger
# CUDA_VISIBILE_DEVICES=0 python finetune_structure_cbm.py --dataset cxr8 --foundation_model BioViL_T --concept_set data/concept_sets/cxr8_filtered.txt --epoch 20 --batch_size 128 --scheduler cosine --init_beta 0.9 --reg_alpha 0.7 --learnable_graph --lr 3e-4 --logger

# for seed in 2 12 22 32 42 52 62 72 82 92
# do
#     for tau in 0.7 0.5 0.3 0.1
#     do
#         for beta in 0.9 0.85 0.91 0.86 0.92 0.87 0.88 0.89
#         do
#             CUDA_VISIBLE_DEVICES=3 python train_structure_cbm.py --dataset cxr11 --concept_set data/concept_sets/cxr11_filtered.txt --seed $seed --epoch 50  --lr 0.01 --batch_size 512 --scheduler cosine --tau $tau --init_beta $beta --reg_alpha 0 --learnable_graph --logger --clip_name BioViL_T &
#             CUDA_VISIBLE_DEVICES=7 python train_structure_cbm.py --dataset cxr11 --concept_set data/concept_sets/cxr11_filtered.txt --seed $seed --epoch 50  --lr 0.01 --batch_size 512 --scheduler cosine --tau $tau --init_beta $beta --reg_alpha 0.1 --learnable_graph --logger --clip_name BioViL_T &
#             CUDA_VISIBLE_DEVICES=6 python train_structure_cbm.py --dataset cxr11 --concept_set data/concept_sets/cxr11_filtered.txt --seed $seed --epoch 50  --lr 0.01 --batch_size 512 --scheduler cosine --tau $tau --init_beta $beta --reg_alpha 0.2 --learnable_graph --logger --clip_name BioViL_T &
#             CUDA_VISIBLE_DEVICES=4 python train_structure_cbm.py --dataset cxr11 --concept_set data/concept_sets/cxr11_filtered.txt --seed $seed --epoch 50  --lr 0.01 --batch_size 512 --scheduler cosine --tau $tau --init_beta $beta --reg_alpha 0.03 --learnable_graph --logger --clip_name BioViL_T &
#             CUDA_VISIBLE_DEVICES=5 python train_structure_cbm.py --dataset cxr11 --concept_set data/concept_sets/cxr11_filtered.txt --seed $seed --epoch 50  --lr 0.01 --batch_size 512 --scheduler cosine --tau $tau --init_beta $beta --reg_alpha 0.05 --learnable_graph --logger --clip_name BioViL_T &
#             wait
#         done
#     done
#     python train_structure_cbm.py --dataset cxr11 --concept_set data/concept_sets/cxr11_filtered.txt --seed $seed --epoch 50  --lr 0.01 --batch_size 512 --scheduler cosine --tau 0.3 --init_beta 0.9 --reg_alpha 0 --logger --graph --clip_name BioViL_T
# done

# for seed in 2 12 22 32 42 52 62 72 82 92 
# do
#     # CUDA_VISIBLE_DEVICES=2 python train_structure_cbm.py --dataset cxr11 --concept_set data/concept_sets/cxr11_filtered.txt --seed $seed --epoch 50  --lr 0.001 --batch_size 512 --scheduler cosine --tau 0.1 --init_beta 0.8 --reg_alpha 0.05 --learnable_graph --logger --clip_name BioViL_T &
#     # CUDA_VISIBLE_DEVICES=3 python train_structure_cbm.py --dataset cxr11 --concept_set data/concept_sets/cxr11_filtered.txt --seed $seed --epoch 50  --lr 0.01 --batch_size 512 --scheduler cosine --tau 0.1 --init_beta 0.8 --reg_alpha 0.05 --graph --logger --clip_name BioViL_T &
#     CUDA_VISIBLE_DEVICES=7 python train_structure_cbm.py --dataset ham10000 --concept_set data/concept_sets/ham10000_filtered.txt --seed $seed --epoch 100  --lr 1e-3 --batch_size 512 --scheduler cosine --tau 0.0 --init_beta 0.8 --reg_alpha 0.01 --learnable_graph --logger &
#     # CUDA_VISIBLE_DEVICES=5 python train_structure_cbm.py --dataset ham10000 --concept_set data/concept_sets/ham10000_filtered.txt --seed $seed --epoch 100  --lr 0.01 --batch_size 512 --scheduler cosine --tau 0.1 --init_beta 0.8 --reg_alpha 0.05 --graph --logger &
#     CUDA_VISIBLE_DEVICES=6 python train_structure_cbm.py --dataset cub --concept_set data/concept_sets/cub_filtered.txt --seed $seed --epoch 100  --lr 0.001 --batch_size 512 --scheduler cosine --tau 0.0 --init_beta 0.8 --reg_alpha 0.1 --learnable_graph --logger &
#     CUDA_VISIBLE_DEVICES=7 python train_structure_cbm.py --dataset flower --concept_set data/concept_sets/flower_filtered.txt --seed $seed --epoch 100  --lr 0.01 --batch_size 512 --scheduler cosine --tau 0.0 --init_beta 0.8 --reg_alpha 0.01 --learnable_graph --logger &
#     # CUDA_VISIBLE_DEVICES=6 python train_structure_cbm.py --dataset cub --concept_set data/concept_sets/cub_filtered.txt --seed $seed --epoch 100  --lr 0.01 --batch_size 512 --scheduler cosine --tau 0.1 --init_beta 0.8 --reg_alpha 0.1 --graph --logger &
#     wait
#     # for tau in 0.7 0.5 0.3 0.1
#     # do
#     #     for beta in 0.90 0.89 0.88
#     #     do
#     #         # CUDA_VISIBLE_DEVICES=0 python train_structure_cbm.py --dataset cifar100 --concept_set data/concept_sets/cifar100_filtered.txt --seed $seed --epoch 30  --lr 0.01 --batch_size 128 --scheduler cosine --tau $tau --init_beta $beta --reg_alpha 0 --learnable_graph --logger &
#     #         # CUDA_VISIBLE_DEVICES=1 python train_structure_cbm.py --dataset cifar100 --concept_set data/concept_sets/cifar100_filtered.txt --seed $seed --epoch 30  --lr 0.01 --batch_size 128 --scheduler cosine --tau $tau --init_beta $beta --reg_alpha 0.05 --learnable_graph --logger &
#     #         # CUDA_VISIBLE_DEVICES=2 python train_structure_cbm.py --dataset cifar100 --concept_set data/concept_sets/cifar100_filtered.txt --seed $seed --epoch 30  --lr 0.01 --batch_size 128 --scheduler cosine --tau $tau --init_beta $beta --reg_alpha 0.1 --learnable_graph --logger &
#     #         # CUDA_VISIBLE_DEVICES=3 python train_structure_cbm.py --dataset cifar100 --concept_set data/concept_sets/cifar100_filtered.txt --seed $seed --epoch 30  --lr 0.01 --batch_size 128 --scheduler cosine --tau $tau --init_beta $beta --reg_alpha 0.2 --learnable_graph --logger &
#     #         # CUDA_VISIBLE_DEVICES=6 python train_structure_cbm.py --dataset cifar100 --concept_set data/concept_sets/cifar100_filtered.txt --seed $seed --epoch 30  --lr 0.01 --batch_size 128 --scheduler cosine --tau $tau --init_beta $beta --reg_alpha 0.3 --learnable_graph --logger &
#     #         # CUDA_VISIBLE_DEVICES=7 python train_structure_cbm.py --dataset cifar100 --concept_set data/concept_sets/cifar100_filtered.txt --seed $seed --epoch 30  --lr 0.01 --batch_size 128 --scheduler cosine --tau $tau --init_beta $beta --reg_alpha 0.5 --learnable_graph --logger &
#     #         # wait
#     #         CUDA_VISIBLE_DEVICES=7 python train_structure_cbm.py --dataset cifar100 --concept_set data/concept_sets/cifar100_filtered.txt --seed 12 --epoch 30  --lr 0.01 --batch_size 512 --scheduler cosine --tau 0.1 --init_beta 0.8 --reg_alpha 0.05 --learnable_graph --filtering submodular --filtering_size 50 --logger &
#     #         CUDA_VISIBLE_DEVICES=6 python train_structure_cbm.py --dataset cifar100 --concept_set data/concept_sets/cifar100_filtered.txt --seed 12 --epoch 30  --lr 0.01 --batch_size 512 --scheduler cosine --tau 0.1 --init_beta 0.8 --reg_alpha 0.1 --graph --filtering submodular --filtering_size 50 --logger &
#     #         wait
#     #     done
#     # done
#     # python train_structure_cbm.py --dataset cifar100 --concept_set data/concept_sets/cifar100_filtered.txt --seed $seed --epoch 30  --lr 0.01 --batch_size 512 --scheduler cosine --tau 0.3 --init_beta 0.9 --reg_alpha 0 --logger --graph
#     # python train_structure_cbm.py --dataset cifar100 --concept_set data/concept_sets/cifar100_filtered.txt --seed $seed --epoch 50  --lr 0.01 --batch_size 512 --scheduler cosine --tau 0.3 --init_beta 0.9 --reg_alpha 0 --logger --graph --clip_name BioViL_T
#     # CUDA_VISIBLE_DEVICES=6 python train_structure_cbm.py --dataset cifar100 --concept_set data/concept_sets/cifar100_filtered.txt --seed 2 --epoch 30  --lr 0.01 --batch_size 512 --scheduler cosine --tau 0.1 --init_beta 0.8 --reg_alpha 0.05 --graph --filtering submodular --filtering_size 50 --logger
# done

# for seed in 2 12 22 32 42 
# do
#     # CUDA_VISIBLE_DEVICES=6 python train_structure_cbm.py --dataset cifar10 --concept_set data/concept_sets/cifar10_filtered.txt --seed $seed --epoch 50  --lr 0.001 --batch_size 512 --scheduler cosine --tau 0.0 --init_beta 0.8 --reg_alpha 0.01 --learnable_graph --filtering submodular --filtering_size 30  --logger &
#     # CUDA_VISIBLE_DEVICES=7 python train_structure_cbm.py --dataset cifar100 --concept_set data/concept_sets/cifar100_filtered.txt --seed $seed --epoch 30  --lr 0.001 --batch_size 512 --scheduler cosine --tau 0.0 --init_beta 0.8 --reg_alpha 0.01 --learnable_graph --filtering submodular --filtering_size 50 --logger&
#     CUDA_VISIBLE_DEVICES=6 python train_structure_cbm.py --dataset cub --concept_set data/concept_sets/cub_filtered.txt --seed $seed --epoch 100  --lr 0.001 --batch_size 512 --scheduler cosine --tau 0.1 --init_beta 0.8 --reg_alpha 0.1 --learnable_graph --logger &
#     CUDA_VISIBLE_DEVICES=6 python train_structure_cbm.py --dataset cub --concept_set data/concept_sets/cub_filtered.txt --seed $seed --epoch 100  --lr 0.001 --batch_size 512 --scheduler cosine --tau 0.1 --init_beta 0.8 --reg_alpha 0.3 --learnable_graph --logger &
#     # CUDA_VISIBLE_DEVICES=6 python train_structure_cbm.py --dataset cub --concept_set data/concept_sets/cub_filtered.txt --seed $seed --epoch 100  --lr 0.001 --batch_size 512 --scheduler cosine --tau 0.1 --init_beta 0.8 --reg_alpha  --learnable_graph --logger &
#     # CUDA_VISIBLE_DEVICES=6 python train_structure_cbm.py --dataset cub --concept_set data/concept_sets/cub_filtered.txt --seed $seed --epoch 100  --lr 0.001 --batch_size 512 --scheduler cosine --tau 0.1 --init_beta 0.8 --reg_alpha 0.7 --learnable_graph --logger &
#     # CUDA_VISIBLE_DEVICES=6 python train_structure_cbm.py --dataset cub --concept_set data/concept_sets/cub_filtered.txt --seed $seed --epoch 100  --lr 0.001 --batch_size 512 --scheduler cosine --tau 0.1 --init_beta 0.8 --reg_alpha 1 --learnable_graph --logger &
#     # wait
# done

# for seed in 2 12 22 32 42 52 62 72 82 92
# do
#     for tau in 0.7 0.5 0.3  0.1
#     do
#         for beta in 0.9 0.89 0.88 0.86 0.85 0.8
#         do
#             CUDA_VISIBLE_DEVICES=0 python train_structure_cbm.py --dataset ham10000 --concept_set data/concept_sets/ham10000_filtered.txt --seed $seed --epoch 100  --lr 0.01 --batch_size 512 --scheduler cosine --tau $tau --init_beta $beta --reg_alpha 0 --learnable_graph --logger & # --clip_name BioViL_T
#             CUDA_VISIBLE_DEVICES=1 python train_structure_cbm.py --dataset ham10000 --concept_set data/concept_sets/ham10000_filtered.txt --seed $seed --epoch 100  --lr 0.01 --batch_size 512 --scheduler cosine --tau $tau --init_beta $beta --reg_alpha 0.1 --learnable_graph --logger &
#             CUDA_VISIBLE_DEVICES=2 python train_structure_cbm.py --dataset ham10000 --concept_set data/concept_sets/ham10000_filtered.txt --seed $seed --epoch 100  --lr 0.01 --batch_size 512 --scheduler cosine --tau $tau --init_beta $beta --reg_alpha 0.2 --learnable_graph --logger &
#             CUDA_VISIBLE_DEVICES=3 python train_structure_cbm.py --dataset ham10000 --concept_set data/concept_sets/ham10000_filtered.txt --seed $seed --epoch 100  --lr 0.01 --batch_size 512 --scheduler cosine --tau $tau --init_beta $beta --reg_alpha 0.03 --learnable_graph --logger &
#             CUDA_VISIBLE_DEVICES=5 python train_structure_cbm.py --dataset ham10000 --concept_set data/concept_sets/ham10000_filtered.txt --seed $seed --epoch 100  --lr 0.01 --batch_size 512 --scheduler cosine --tau $tau --init_beta $beta --reg_alpha 0.05 --learnable_graph --logger &
#             wait
#         done
#     done
#     python train_structure_cbm.py --dataset ham10000 --concept_set data/concept_sets/ham10000_filtered.txt --seed $seed --epoch 100  --lr 0.01 --batch_size 512 --scheduler cosine --tau 0.3 --init_beta 0.9 --reg_alpha 0 --logger --graph #--clip_name BioViL_T
# done

# CUDA_VISIBLE_DEVICES=6 python train_structure_cbm.py --dataset cifar10 --concept_set data/concept_sets/cifar10_filtered.txt --seed 72 --epoch 50  --lr 0.001 --batch_size 512 --scheduler cosine --tau 0.1 --init_beta 0.8 --reg_alpha 0.1 --learnable_graph --filtering submodular --filtering_size 30 --ssl

# CUDA_VISIBLE_DEVICES=7 python train_structure_cbm.py --dataset cifar100 --concept_set data/concept_sets/cifar100_filtered.txt --seed 22 --epoch 30  --lr 0.01 --batch_size 512 --scheduler cosine --tau 0.1 --init_beta 0.8 --reg_alpha 0.1 --learnable_graph --filtering submodular --filtering_size 50 --ssl

# CUDA_VISIBLE_DEVICES=7 python train_structure_cbm.py --dataset cub --concept_set data/concept_sets/cub_filtered.txt --seed 72 --epoch 100  --lr 0.001 --batch_size 512 --scheduler cosine --tau 0.1 --init_beta 0.8 --reg_alpha 0.2 --learnable_graph --logger --ssl

# CUDA_VISIBLE_DEVICES=7 python train_structure_cbm.py --dataset flower --concept_set data/concept_sets/cub_filtered.txt --seed 72 --epoch 500  --lr 0.001 --batch_size 512 --scheduler cosine --tau 0.1 --init_beta 0.8 --reg_alpha 0.05 --learnable_graph --logger --ssl

# CUDA_VISIBLE_DEVICES=6 python train_structure_cbm.py --dataset ham10000 --concept_set data/concept_sets/ham10000_filtered.txt --seed 12 --epoch 100  --lr 5e-4 --batch_size 512 --tau 0.1 --init_beta 0.8 --reg_alpha 0.05 --learnable_graph --scheduler cosine --logger --ssl

# CUDA_VISIBLE_DEVICES=7 python train_structure_cbm.py --dataset cub --concept_set data/concept_sets/cub_filtered.txt --epoch 100  --lr 0.001 --batch_size 512 --scheduler cosine --tau 0.1 --init_beta 0.8 --reg_alpha 0.2 --learnable_graph --ground_graph

# CUDA_VISIBLE_DEVICES=2 python train_structure_cbm.py --dataset cifar100 --concept_set data/concept_sets/cifar100_filtered.txt --seed 22 --epoch 100  --lr 0.01 --batch_size 512 --scheduler cosine --tau 0.1 --init_beta 0.8 --reg_alpha 0.1 --learnable_graph --ssl --score_type mi2



########################
# standard CBM
# CUDA_VISIBLE_DEVICES=6 python train_standard_cbm.py --dataset cub --batch_size 512 --lr 0.001 --scheduler cosine --epoch 100 --scheme joint --use_graph --beta 0.0 --alpha 0.05 --clip_name RN18 --seed 2
for seed in 2 12 22 32 42 52 62 72 82 92
do
    CUDA_VISIBLE_DEVICES=0 python train_standard_cbm.py --dataset chestxpert --seed $seed --batch_size 512 --lr 0.003 --scheduler cosine --epoch 50 --scheme joint --supervision --use_graph --beta 0.0 --alpha 0.0
    # CUDA_VISIBLE_DEVICES=7 python train_standard_cbm.py --dataset chestxpert --seed $seed --batch_size 512 --lr 0.003 --scheduler cosine --epoch 50 --scheme joint --supervision --use_graph --beta 0.0 --alpha 0.01 &
    # CUDA_VISIBLE_DEVICES=2 python train_standard_cbm.py --dataset chestxpert --seed $seed --batch_size 512 --lr 0.003 --scheduler cosine --epoch 50 --scheme joint --supervision --use_graph --beta 0.0 --alpha 0.03 &
    # CUDA_VISIBLE_DEVICES=4 python train_standard_cbm.py --dataset chestxpert --seed $seed --batch_size 512 --lr 0.003 --scheduler cosine --epoch 50 --scheme joint --supervision --use_graph --beta 0.0 --alpha 0.05 &
    # CUDA_VISIBLE_DEVICES=5 python train_standard_cbm.py --dataset chestxpert --seed $seed --batch_size 512 --lr 0.003 --scheduler cosine --epoch 50 --scheme joint --supervision --use_graph --beta 0.0 --alpha 0.07 &
    # CUDA_VISIBLE_DEVICES=6 python train_standard_cbm.py --dataset chestxpert --seed $seed --batch_size 512 --lr 0.003 --scheduler cosine --epoch 50 --scheme joint --supervision --use_graph --beta 0.0 --alpha 0.1 
done

# CUDA_VISIBLE_DEVICES=2 python intervene_standard_cbm.py --dataset cub --concept_set data/concept_sets/cub_filtered.txt --batch_size 128 --saved_model /home/hxu2/CBM-Graph/cbm_supervision_outputs/cub_joint_supervised_seed_2_lr_0.003_epoch_100_alpha_0.05_beta_0.0_graph --seed 2 --ratio 0.1 --logger --use_graph --alpha 0.05 --beta 0.0
# CUDA_VISIBLE_DEVICES=2 python intervene_standard_cbm.py --dataset cub --concept_set data/concept_sets/cub_filtered.txt --batch_size 128 --saved_model /home/hxu2/CBM-Graph/cbm_supervision_outputs/cub_joint_supervised_seed_2_lr_0.003_epoch_100_alpha_0.1_beta_0.1 --seed 2 --ratio 0.1 --logger --graph

CUDA_VISIBLE_DEVICES=6 python train_structure_cbm.py --dataset cub --concept_set data/concept_sets/cub1_filtered.txt --seed 2 --epoch 100  --lr 0.001 --batch_size 512 --scheduler cosine --tau 0.1 --init_beta 0.8 --reg_alpha 0.3 --learnable_graph --logger
CUDA_VISIBLE_DEVICES=6 python train_structure_cbm.py --dataset cub --concept_set data/concept_sets/cub2_filtered.txt --seed 2 --epoch 100  --lr 0.001 --batch_size 512 --scheduler cosine --tau 0.1 --init_beta 0.8 --reg_alpha 0.3 --learnable_graph --logger
CUDA_VISIBLE_DEVICES=4 python train_structure_cbm.py --dataset cub --concept_set data/concept_sets/cub3_filtered.txt --seed 2 --epoch 100  --lr 0.001 --batch_size 512 --scheduler cosine --tau 0.1 --init_beta 0.8 --reg_alpha 0.3 --learnable_graph --logger
CUDA_VISIBLE_DEVICES=5 python train_structure_cbm.py --dataset cub --concept_set data/concept_sets/cub4_filtered.txt --seed 2 --epoch 100  --lr 0.001 --batch_size 512 --scheduler cosine --tau 0.1 --init_beta 0.8 --reg_alpha 0.3 --learnable_graph --logger
CUDA_VISIBLE_DEVICES=7 python train_structure_cbm.py --dataset cub --concept_set data/concept_sets/cub5_filtered.txt --seed 2 --epoch 100  --lr 0.001 --batch_size 512 --scheduler cosine --tau 0.1 --init_beta 0.8 --reg_alpha 0.3 --learnable_graph --logger

for seed in [82,92]:
    os.system(f'CUDA_VISIBLE_DEVICES=7 python train_structure_cbm.py --dataset cub --concept_set data/concept_sets/cub1_filtered.txt --seed {seed} --epoch 50  --lr 0.001 --batch_size 512 --scheduler cosine --tau 0.1 --init_beta 0.8 --reg_alpha 0.2 --learnable_graph --logger --clip_name ViT-L/14')

CUDA_VISIBLE_DEVICES=4 python train_standard_cbm.py --dataset cub --seed 2 --batch_size 512 --lr 0.003 --scheduler cosine --epoch 100 --scheme cem --supervision --use_graph --beta 0.0 --alpha 0.07

CUDA_VISIBLE_DEVICES=1 python intervene_graph_cbm.py --dataset places365 --concept_set data/concept_sets/places365_filtered.txt --batch_size 1024 --logger --filtering submodular --filtering_size 200 --seed 2 --ratio 0.1 --saved_model saved_models/backbone_ViT-B16_num_epochs_30_cifar100_seed_2_no_graph --graph

CUDA_VISIBLE_DEVICES=0 python intervene_graph_cbm.py --dataset imagenet --concept_set data/concept_sets/imagenet_filtered.txt --batch_size 256 --logger --filtering submodular --filtering_size 200 --saved_model saved_models/submodular_backbone_ViT-B16_num_epochs_10_imagenet_seed_42_no_graph --graph --seed 42 --ratio 0.25
CUDA_VISIBLE_DEVICES=1 python intervene_graph_cbm.py --dataset imagenet --concept_set data/concept_sets/imagenet_filtered.txt --batch_size 256 --logger --filtering submodular --filtering_size 200 --saved_model saved_models/submodular_backbone_ViT-B16_num_epochs_10_imagenet_seed_42_no_graph --graph --seed 42 --ratio 0.5
CUDA_VISIBLE_DEVICES=2 python intervene_graph_cbm.py --dataset imagenet --concept_set data/concept_sets/imagenet_filtered.txt --batch_size 256 --logger --filtering submodular --filtering_size 200 --saved_model saved_models/submodular_backbone_ViT-B16_num_epochs_10_imagenet_seed_42_no_graph --graph --seed 42 --ratio 0.75
CUDA_VISIBLE_DEVICES=3 python intervene_graph_cbm.py --dataset imagenet --concept_set data/concept_sets/imagenet_filtered.txt --batch_size 256 --logger --filtering submodular --filtering_size 200 --saved_model saved_models/submodular_backbone_ViT-B16_num_epochs_10_imagenet_seed_42_no_graph --graph --seed 42 --ratio 1.0

CUDA_VISIBLE_DEVICES=0 python intervene_graph_cbm.py --dataset imagenet --concept_set data/concept_sets/imagenet_filtered.txt --batch_size 256 --logger --filtering submodular --filtering_size 200 --saved_model saved_models/submodular_backbone_ViT-B16_num_epochs_10_imagenet_seed_42_num_edges_71_alpha_0.17_beta_0.8_tau_0.1 --seed 42 --ratio 0.25
