#!/bin/bash

obfus_methods=('tsqp')

for method in "${obfus_methods[@]}"
do
    deepspeed --include localhost:0,1,2,3 --master_port 12345 ./attack/arrowmatch.py \
            --pretrained_model_path ./models/gpt2 \
            --victim_model_path ./outputs/tsqp/gpt2/mnli/final_model \
            --src_len 512 \
            --tgt_len 128 \
            --test_data_path ./data/mnli \
            --recover_data_path ./attack/data/tsqp/gpt2_mnli.json \
            --num_labels 3 \
            --train_micro_batch_size_per_gpu 16 \
            --gradient_accumulation_steps 1 \
            --max_lr 1e-4 \
            --initial_lr 1e-5 \
            --min_lr 1e-6 \
            --weight_decay 0.01 \
            --adam_beta1 0.9 \
            --adam_beta2 0.999\
            --epochs 3 \
            --ds_config_path ./config/ds_config_attack.json \
            --finetune_method full-tuning \
            --offload_device cpu \
            --nvme_path ./mnt/nvme \
            --obfus_method ${method}
done

for method in "${obfus_methods[@]}"
do
    deepspeed --include localhost:0,1,2,3 --master_port 12345 ./attack/arrowmatch.py \
            --pretrained_model_path ./models/gpt2 \
            --victim_model_path ./outputs/tsqp/gpt2/qqp/final_model \
            --src_len 512 \
            --tgt_len 128 \
            --test_data_path ./data/qqp \
            --recover_data_path ./attack/data/tsqp/gpt2_qqp.json \
            --num_labels 2 \
            --train_micro_batch_size_per_gpu 16 \
            --gradient_accumulation_steps 1 \
            --max_lr 1e-4 \
            --initial_lr 1e-5 \
            --min_lr 1e-6 \
            --weight_decay 0.01 \
            --adam_beta1 0.9 \
            --adam_beta2 0.999\
            --epochs 3 \
            --ds_config_path ./config/ds_config_attack.json \
            --finetune_method full-tuning \
            --offload_device cpu \
            --nvme_path ./mnt/nvme \
            --obfus_method ${method}
done

for method in "${obfus_methods[@]}"
do
    deepspeed --include localhost:0,1,2,3 --master_port 12345 ./attack/arrowmatch.py \
            --pretrained_model_path ./models/gpt2 \
            --victim_model_path ./outputs/tsqp/gpt2/sst2/final_model \
            --src_len 512 \
            --tgt_len 128 \
            --test_data_path ./data/sst2 \
            --recover_data_path ./attack/data/tsqp/gpt2_sst2.json \
            --num_labels 2 \
            --train_micro_batch_size_per_gpu 16 \
            --gradient_accumulation_steps 1 \
            --max_lr 1e-4 \
            --initial_lr 1e-5 \
            --min_lr 1e-6 \
            --weight_decay 0.01 \
            --adam_beta1 0.9 \
            --adam_beta2 0.999\
            --epochs 3 \
            --ds_config_path ./config/ds_config_attack.json \
            --finetune_method full-tuning \
            --offload_device cpu \
            --nvme_path ./mnt/nvme \
            --obfus_method ${method}
done

for method in "${obfus_methods[@]}"
do
    deepspeed --include localhost:0,1,2,3 --master_port 12345 ./attack/arrowmatch.py \
            --pretrained_model_path ./models/gpt2 \
            --victim_model_path ./outputs/tsqp/gpt2/qnli/final_model \
            --src_len 512 \
            --tgt_len 128 \
            --test_data_path ./data/qnli \
            --recover_data_path ./attack/data/tsqp/gpt2_qnli.json \
            --num_labels 2 \
            --train_micro_batch_size_per_gpu 16 \
            --gradient_accumulation_steps 1 \
            --max_lr 1e-4 \
            --initial_lr 1e-5 \
            --min_lr 1e-6 \
            --weight_decay 0.01 \
            --adam_beta1 0.9 \
            --adam_beta2 0.999\
            --epochs 3 \
            --ds_config_path ./config/ds_config_attack.json \
            --finetune_method full-tuning \
            --offload_device cpu \
            --nvme_path ./mnt/nvme \
            --obfus_method ${method}
done

# qwen3 wic
for method in "${obfus_methods[@]}"
do
    deepspeed --include localhost:0,1,2,3 --master_port 12345 ./attack/arrowmatch.py \
            --pretrained_model_path ./models/qwen3-4b \
            --victim_model_path ./outputs/tsqp/qwen3/wic/final_merged_model \
            --src_len 512 \
            --tgt_len 128 \
            --test_data_path ./data/wic \
            --recover_data_path ./attack/data/tsqp/qwen3_wic.json \
            --num_labels 2 \
            --train_micro_batch_size_per_gpu 2 \
            --gradient_accumulation_steps 4 \
            --max_lr 1e-4 \
            --initial_lr 1e-5 \
            --min_lr 1e-6 \
            --weight_decay 0.01 \
            --adam_beta1 0.9 \
            --adam_beta2 0.999\
            --epochs 3 \
            --ds_config_path ./config/ds_config_attack.json \
            --finetune_method lora \
            --lora_target_modules q_proj,k_proj,v_proj,o_proj \
            --lora_alpha 32 \
            --lora_dropout 0.05 \
            --lora_r 16 \
            --offload_device cpu \
            --nvme_path ./mnt/nvme \
            --obfus_method ${method}
done

# gemma3 wic
for method in "${obfus_methods[@]}"
do
    deepspeed --include localhost:0,1,2,3 --master_port 12345 ./attack/arrowmatch.py \
            --pretrained_model_path models/gemma3-1b-it \
            --victim_model_path ./outputs/tsqp/gemma3/wic/final_merged_model \
            --src_len 512 \
            --tgt_len 128 \
            --test_data_path ./data/wic \
            --recover_data_path ./attack/data/tsqp/gemma3_wic.json \
            --num_labels 2 \
            --train_micro_batch_size_per_gpu 8 \
            --gradient_accumulation_steps 1 \
            --max_lr 1e-4 \
            --initial_lr 1e-5 \
            --min_lr 1e-6 \
            --weight_decay 0.01 \
            --adam_beta1 0.9 \
            --adam_beta2 0.999\
            --epochs 3 \
            --ds_config_path ./config/ds_config_attack.json \
            --finetune_method lora \
            --lora_target_modules q_proj,k_proj,v_proj,o_proj \
            --lora_alpha 32 \
            --lora_dropout 0.05 \
            --lora_r 16 \
            --offload_device cpu \
            --nvme_path ./mnt/nvme \
            --obfus_method ${method}
done

# llama3.2 wic
for method in "${obfus_methods[@]}"
do
    deepspeed --include localhost:0,1,2,3 --master_port 12345 ./attack/arrowmatch.py \
            --pretrained_model_path models/Llama-3.2-3B-Instruct \
            --victim_model_path ./outputs/tsqp/llama3.2/wic/final_merged_model \
            --src_len 512 \
            --tgt_len 128 \
            --test_data_path ./data/wic \
            --recover_data_path ./attack/data/tsqp/llama3.2_wic.json \
            --num_labels 2 \
            --train_micro_batch_size_per_gpu 4 \
            --gradient_accumulation_steps 2 \
            --max_lr 1e-4 \
            --initial_lr 1e-5 \
            --min_lr 1e-6 \
            --weight_decay 0.01 \
            --adam_beta1 0.9 \
            --adam_beta2 0.999\
            --epochs 3 \
            --ds_config_path ./config/ds_config_attack.json \
            --finetune_method lora \
            --lora_target_modules q_proj,k_proj,v_proj,o_proj \
            --lora_alpha 32 \
            --lora_dropout 0.05 \
            --lora_r 16 \
            --offload_device cpu \
            --nvme_path ./mnt/nvme \
            --obfus_method ${method}
done

# qwen3 goemotions
for method in "${obfus_methods[@]}"
do
    deepspeed --include localhost:0,1,2,3 --master_port 12345 ./attack/arrowmatch_goemotions.py \
            --pretrained_model_path ./models/qwen3-4b \
            --victim_model_path ./outputs/tsqp/qwen3/goemotions/final_merged_model \
            --src_len 64 \
            --tgt_len 128 \
            --test_data_path ./data/goemotions \
            --recover_data_path ./attack/data/tsqp/qwen3_goemotions.json \
            --train_micro_batch_size_per_gpu 4 \
            --gradient_accumulation_steps 4 \
            --max_lr 1e-4 \
            --initial_lr 1e-5 \
            --min_lr 1e-6 \
            --weight_decay 0.01 \
            --adam_beta1 0.9 \
            --adam_beta2 0.999\
            --epochs 3 \
            --ds_config_path ./config/ds_config_attack.json \
            --finetune_method lora \
            --lora_target_modules q_proj,k_proj,v_proj,o_proj \
            --lora_alpha 32 \
            --lora_dropout 0.05 \
            --lora_r 16 \
            --offload_device cpu \
            --nvme_path ./mnt/nvme \
            --obfus_method ${method}
done

# gemma3 goemotions
for method in "${obfus_methods[@]}"
do
    deepspeed --include localhost:0,1,2,3 --master_port 12345 ./attack/arrowmatch_goemotions.py \
            --pretrained_model_path models/gemma3-1b-it \
            --victim_model_path ./outputs/tsqp/gemma3/goemotions/final_merged_model \
            --src_len 64 \
            --tgt_len 128 \
            --test_data_path ./data/goemotions \
            --recover_data_path ./attack/data/tsqp/gemma3_goemotions.json \
            --train_micro_batch_size_per_gpu 8 \
            --gradient_accumulation_steps 2 \
            --max_lr 1e-4 \
            --initial_lr 1e-5 \
            --min_lr 1e-6 \
            --weight_decay 0.01 \
            --adam_beta1 0.9 \
            --adam_beta2 0.999\
            --epochs 3 \
            --ds_config_path ./config/ds_config_attack.json \
            --finetune_method lora \
            --lora_target_modules q_proj,k_proj,v_proj,o_proj \
            --lora_alpha 32 \
            --lora_dropout 0.05 \
            --lora_r 16 \
            --offload_device cpu \
            --nvme_path ./mnt/nvme \
            --obfus_method ${method}
done

# llama3.2 goemotions
for method in "${obfus_methods[@]}"
do
    deepspeed --include localhost:0,1,2,3 --master_port 12345 ./attack/arrowmatch_goemotions.py \
            --pretrained_model_path models/Llama-3.2-3B-Instruct \
            --victim_model_path ./outputs/tsqp/llama3.2/goemotions/final_merged_model \
            --src_len 64 \
            --tgt_len 128 \
            --test_data_path ./data/goemotions \
            --recover_data_path ./attack/data/tsqp/llama3.2_goemotions.json \
            --train_micro_batch_size_per_gpu 4 \
            --gradient_accumulation_steps 4 \
            --max_lr 1e-4 \
            --initial_lr 1e-5 \
            --min_lr 1e-6 \
            --weight_decay 0.01 \
            --adam_beta1 0.9 \
            --adam_beta2 0.999\
            --epochs 3 \
            --ds_config_path ./config/ds_config_attack.json \
            --finetune_method lora \
            --lora_target_modules q_proj,k_proj,v_proj,o_proj \
            --lora_alpha 32 \
            --lora_dropout 0.05 \
            --lora_r 16 \
            --offload_device cpu \
            --nvme_path ./mnt/nvme \
            --obfus_method ${method}
done

# qwen3 finqa
for method in "${obfus_methods[@]}"
do
    deepspeed --include localhost:0,1,2,3 --master_port 12345 ./attack/arrowmatch_finqa.py \
            --pretrained_model_path models/qwen3-4b \
            --victim_model_path ./outputs/tsqp/qwen3/finqa/final_model \
            --recover_data_path ./attack/data/tsqp/qwen3_finqa.json \
            --test_data_path ./data/finqa/test.json \
            --src_len 2048 \
            --tgt_len 128 \
            --train_micro_batch_size_per_gpu 1 \
            --gradient_accumulation_steps 16 \
            --max_lr 1e-4 \
            --initial_lr 1e-6 \
            --min_lr 1e-8 \
            --weight_decay 0.01 \
            --adam_beta1 0.9 \
            --adam_beta2 0.999\
            --epochs 3 \
            --finetune_method full-tuning \
            --ds_config_path ./config/ds_config_attack.json \
            --offload_device cpu \
            --nvme_path ./mnt/nvme \
            --obfus_method ${method}
done

# llama3.2 finqa
for method in "${obfus_methods[@]}"
do
    deepspeed --include localhost:0,1,2,3 --master_port 12345 ./attack/arrowmatch_finqa.py \
            --pretrained_model_path models/Llama-3.2-3B-Instruct \
            --victim_model_path ./outputs/tsqp/llama3.2/finqa/final_model \
            --recover_data_path ./attack/data/tsqp/llama3.2_finqa.json \
            --test_data_path ./data/finqa/test.json \
            --src_len 2048 \
            --tgt_len 128 \
            --train_micro_batch_size_per_gpu 1 \
            --gradient_accumulation_steps 16 \
            --max_lr 1e-4 \
            --initial_lr 1e-6 \
            --min_lr 1e-8 \
            --weight_decay 0.01 \
            --adam_beta1 0.9 \
            --adam_beta2 0.999\
            --epochs 3 \
            --finetune_method full-tuning \
            --ds_config_path ./config/ds_config_attack.json \
            --offload_device cpu \
            --nvme_path ./mnt/nvme \
            --obfus_method ${method}
done

# gemma3 finqa
for method in "${obfus_methods[@]}"
do
    deepspeed --include localhost:0,1,2,3 --master_port 12345 ./attack/arrowmatch_finqa.py \
            --pretrained_model_path models/gemma3-1b-it \
            --victim_model_path ./outputs/tsqp/gemma3/finqa/final_model \
            --recover_data_path ./attack/data/tsqp/gemma3_finqa.json \
            --test_data_path ./data/finqa/test.json \
            --src_len 2048 \
            --tgt_len 128 \
            --train_micro_batch_size_per_gpu 1 \
            --gradient_accumulation_steps 16 \
            --max_lr 1e-4 \
            --initial_lr 1e-6 \
            --min_lr 1e-8 \
            --weight_decay 0.01 \
            --adam_beta1 0.9 \
            --adam_beta2 0.999\
            --epochs 3 \
            --finetune_method full-tuning \
            --ds_config_path ./config/ds_config_attack.json \
            --offload_device cpu \
            --nvme_path ./mnt/nvme \
            --obfus_method ${method}
done


# qwen3 pubmedqa
for method in "${obfus_methods[@]}"
do
    deepspeed --include localhost:0,1,2,3 --master_port 12345 ./attack/arrowmatch_pubmedqa.py \
            --pretrained_model_path models/qwen3-4b \
            --victim_model_path ./outputs/tsqp/qwen3/pubmedqa/final_model \
            --recover_data_path ./attack/data/tsqp/qwen3_pubmedqa.json \
            --test_data_path ./data/pubmedqa/split \
            --src_len 2048 \
            --tgt_len 128 \
            --train_micro_batch_size_per_gpu 1 \
            --gradient_accumulation_steps 16 \
            --max_lr 1e-4 \
            --initial_lr 1e-6 \
            --min_lr 1e-8 \
            --weight_decay 0.01 \
            --adam_beta1 0.9 \
            --adam_beta2 0.999\
            --epochs 3 \
            --finetune_method full-tuning \
            --ds_config_path ./config/ds_config_attack.json \
            --offload_device cpu \
            --nvme_path ./mnt/nvme \
            --obfus_method ${method}
done

# llama3.2 pubmedqa
for method in "${obfus_methods[@]}"
do
    deepspeed --include localhost:0,1,2,3 --master_port 12345 ./attack/arrowmatch_pubmedqa.py \
            --pretrained_model_path models/Llama-3.2-3B-Instruct \
            --victim_model_path ./outputs/tsqp/llama3.2/pubmedqa/final_model \
            --recover_data_path ./attack/data/tsqp/llama3.2_pubmedqa.json \
            --test_data_path ./data/pubmedqa/split \
            --src_len 2048 \
            --tgt_len 128 \
            --train_micro_batch_size_per_gpu 1 \
            --gradient_accumulation_steps 16 \
            --max_lr 1e-4 \
            --initial_lr 1e-6 \
            --min_lr 1e-8 \
            --weight_decay 0.01 \
            --adam_beta1 0.9 \
            --adam_beta2 0.999\
            --epochs 3 \
            --finetune_method full-tuning \
            --ds_config_path ./config/ds_config_attack.json \
            --offload_device cpu \
            --nvme_path ./mnt/nvme \
            --obfus_method ${method}
done

# gemma3 pubmedqa
for method in "${obfus_methods[@]}"
do
    deepspeed --include localhost:0,1,2,3 --master_port 12345 ./attack/arrowmatch_pubmedqa.py \
            --pretrained_model_path models/gemma3-1b-it \
            --victim_model_path ./outputs/tsqp/gemma3/pubmedqa/final_model \
            --recover_data_path ./attack/data/tsqp/gemma3_pubmedqa.json \
            --test_data_path ./data/pubmedqa/split \
            --src_len 2048 \
            --tgt_len 128 \
            --train_micro_batch_size_per_gpu 1 \
            --gradient_accumulation_steps 16 \
            --max_lr 1e-4 \
            --initial_lr 1e-6 \
            --min_lr 1e-8 \
            --weight_decay 0.01 \
            --adam_beta1 0.9 \
            --adam_beta2 0.999\
            --epochs 3 \
            --finetune_method full-tuning \
            --ds_config_path ./config/ds_config_attack.json \
            --offload_device cpu \
            --nvme_path ./mnt/nvme \
            --obfus_method ${method}
done