#!/bin/bash

# To fix the Exception: Current loss scale already at minimum - cannot decrease scale anymore, You can (close fp16 and bf16) or (set bf16=True)

# obfus_methods=('black-box' 'random' 'shadownet' 'soter' 'translinkguard' 'ours')

# 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/victim/gpt2/mnli/final_model \
    #         --src_len 512 \
    #         --tgt_len 128 \
    #         --test_data_path ./data/mnli \
    #         --recover_data_path ./attack/data/victim/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/victim/gpt2/qqp/final_model \
    #         --src_len 512 \
    #         --tgt_len 128 \
    #         --test_data_path ./data/qqp \
    #         --recover_data_path ./attack/data/victim/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 10 \
    #         --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/victim/gpt2/sst2/final_model \
    #         --src_len 512 \
    #         --tgt_len 128 \
    #         --test_data_path ./data/sst2 \
    #         --recover_data_path ./attack/data/victim/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/victim/gpt2/qnli/final_model \
    #         --src_len 512 \
    #         --tgt_len 128 \
    #         --test_data_path ./data/qnli \
    #         --recover_data_path ./attack/data/victim/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 10 \
    #         --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/victim/qwen3/wic/final_merged_model \
    #         --src_len 512 \
    #         --tgt_len 128 \
    #         --test_data_path ./data/wic \
    #         --recover_data_path ./attack/data/victim/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/victim/gemma3/wic/final_merged_model \
    #         --src_len 512 \
    #         --tgt_len 128 \
    #         --test_data_path ./data/wic \
    #         --recover_data_path ./attack/data/victim/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/victim/llama3.2/wic/final_merged_model \
    #         --src_len 512 \
    #         --tgt_len 128 \
    #         --test_data_path ./data/wic \
    #         --recover_data_path ./attack/data/victim/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 black-box, we set the epoch as 10)
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/victim/qwen3/goemotions/final_merged_model \
            --src_len 64 \
            --tgt_len 128 \
            --test_data_path ./data/goemotions \
            --recover_data_path ./attack/data/victim/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

deepspeed --include localhost:0,1,2,3 --master_port 12345 ./attack/arrowmatch_goemotions.py \
            --pretrained_model_path ./models/qwen3-4b \
            --victim_model_path ./outputs/victim/qwen3/goemotions/final_merged_model \
            --src_len 64 \
            --tgt_len 128 \
            --test_data_path ./data/goemotions \
            --recover_data_path ./attack/data/victim/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 10 \
            --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 black-box

# 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/victim/gemma3/goemotions/final_merged_model \
            --src_len 64 \
            --tgt_len 128 \
            --test_data_path ./data/goemotions \
            --recover_data_path ./attack/data/victim/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

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/victim/gemma3/goemotions/final_merged_model \
            --src_len 64 \
            --tgt_len 128 \
            --test_data_path ./data/goemotions \
            --recover_data_path ./attack/data/victim/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 10 \
            --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 black-box


# 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/victim/llama3.2/goemotions/final_merged_model \
            --src_len 64 \
            --tgt_len 128 \
            --test_data_path ./data/goemotions \
            --recover_data_path ./attack/data/victim/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

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/victim/llama3.2/goemotions/final_merged_model \
            --src_len 64 \
            --tgt_len 128 \
            --test_data_path ./data/goemotions \
            --recover_data_path ./attack/data/victim/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 10 \
            --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 black-box

# # 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/victim/qwen3/finqa/final_model \
    #         --recover_data_path ./attack/data/victim/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

# deepspeed --include localhost:0,1,2,3 --master_port 12345 ./attack/arrowmatch_finqa.py \
#             --pretrained_model_path models/qwen3-4b \
#             --victim_model_path ./outputs/victim/qwen3/finqa/final_model \
#             --recover_data_path ./attack/data/victim/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 10 \
#             --finetune_method full-tuning \
#             --ds_config_path ./config/ds_config_attack.json \
#             --offload_device cpu \
#             --nvme_path ./mnt/nvme \
#             --obfus_method black-box


# # 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/victim/llama3.2/finqa/final_model \
    #         --recover_data_path ./attack/data/victim/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

# 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/victim/llama3.2/finqa/final_model \
#             --recover_data_path ./attack/data/victim/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 10 \
#             --finetune_method full-tuning \
#             --ds_config_path ./config/ds_config_attack.json \
#             --offload_device cpu \
#             --nvme_path ./mnt/nvme \
#             --obfus_method black-box

# # 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/victim/gemma3/finqa/final_model \
    #         --recover_data_path ./attack/data/victim/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

# 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/victim/gemma3/finqa/final_model \
#         --recover_data_path ./attack/data/victim/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 10 \
#         --finetune_method full-tuning \
#         --ds_config_path ./config/ds_config_attack.json \
#         --offload_device cpu \
#         --nvme_path ./mnt/nvme \
#         --obfus_method black-box


# # 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/victim/qwen3/pubmedqa/final_model \
    #         --recover_data_path ./attack/data/victim/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

# deepspeed --include localhost:0,1,2,3 --master_port 12345 ./attack/arrowmatch_pubmedqa.py \
#         --pretrained_model_path models/qwen3-4b \
#         --victim_model_path ./outputs/victim/qwen3/pubmedqa/final_model \
#         --recover_data_path ./attack/data/victim/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 20 \
#         --finetune_method full-tuning \
#         --ds_config_path ./config/ds_config_attack.json \
#         --offload_device cpu \
#         --nvme_path ./mnt/nvme \
#         --obfus_method black-box

# # 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/victim/llama3.2/pubmedqa/final_model \
#             --recover_data_path ./attack/data/victim/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

# 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/victim/llama3.2/pubmedqa/final_model \
#         --recover_data_path ./attack/data/victim/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 10 \
#         --finetune_method full-tuning \
#         --ds_config_path ./config/ds_config_attack.json \
#         --offload_device cpu \
#         --nvme_path ./mnt/nvme \
#         --obfus_method black-box

# # 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/victim/gemma3/pubmedqa/final_model \
#             --recover_data_path ./attack/data/victim/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

# 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/victim/gemma3/pubmedqa/final_model \
#             --recover_data_path ./attack/data/victim/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 10 \
#             --finetune_method full-tuning \
#             --ds_config_path ./config/ds_config_attack.json \
#             --offload_device cpu \
#             --nvme_path ./mnt/nvme \
#             --obfus_method black-box