sizes=(2 8 32 128 512)

for size in "${sizes[@]}"
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/ratios/qwen3_goemotions_0.01.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 \
            --block_size ${size} \
            --obfus_method ours
done

for size in "${sizes[@]}"
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/ratios/qwen3_goemotions_0.01.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 full-tuning \
            --offload_device cpu \
            --nvme_path ./mnt/nvme \
            --block_size ${size} \
            --obfus_method ours
done

for size in "${sizes[@]}"
do
deepspeed --include localhost:0,1,2,3 --master_port 12345 ./attack/reconstruct_pi_goemotions.py \
          --victim_model_path ./outputs/victim/qwen3/goemotions/final_merged_model \
          --pretrained_model_path ./models/qwen3-4b \
          --recover_data_path attack/data/ratios/qwen3_goemotions_0.01.json \
          --test_data_path ./data/goemotions \
          --src_len 64 \
          --train_micro_batch_size_per_gpu 8 \
          --gradient_accumulation_steps 2 \
          --max_lr 1e-3 \
          --initial_lr 1e-4 \
          --min_lr 1e-8 \
          --weight_decay 0.01 \
          --adam_beta1 0.9 \
          --adam_beta2 0.999\
          --epochs 8 \
          --ds_config_path ./config/ds_config_attack.json \
          --offload_device cpu \
          --block_size 512 \
          --nvme_path ./mnt/nvme
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/ratios/qwen3_goemotions_0.01.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 1 \
            --ds_config_path ./config/ds_config_attack.json \
            --finetune_method full-tuning \
            --offload_device cpu \
            --nvme_path ./mnt/nvme \
            --block_size 32 \
            --obfus_method ours

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/ratios/qwen3_goemotions_0.01.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 1 \
            --ds_config_path ./config/ds_config_attack.json \
            --finetune_method full-tuning \
            --offload_device cpu \
            --nvme_path ./mnt/nvme \
            --block_size 512 \
            --obfus_method ours


for size in "${sizes[@]}"
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/ratios/llama_finqa_0.01.json \
        --test_data_path ./data/finqa/test.json \
        --src_len 2048 \
        --tgt_len 128 \
        --train_micro_batch_size_per_gpu 2 \
        --gradient_accumulation_steps 8 \
        --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 \
        --block_size ${size} \
        --obfus_method ours
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/ratios/llama_finqa_0.01.json \
        --test_data_path ./data/finqa/test.json \
        --src_len 2048 \
        --tgt_len 128 \
        --train_micro_batch_size_per_gpu 2 \
        --gradient_accumulation_steps 8 \
        --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 1 \
        --finetune_method full-tuning \
        --ds_config_path ./config/ds_config_attack.json \
        --offload_device cpu \
        --nvme_path ./mnt/nvme \
        --block_size 32 \
        --obfus_method ours

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/ratios/llama_finqa_0.01.json \
        --test_data_path ./data/finqa/test.json \
        --src_len 2048 \
        --tgt_len 128 \
        --train_micro_batch_size_per_gpu 2 \
        --gradient_accumulation_steps 8 \
        --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 1 \
        --finetune_method full-tuning \
        --ds_config_path ./config/ds_config_attack.json \
        --offload_device cpu \
        --nvme_path ./mnt/nvme \
        --block_size 512 \
        --obfus_method ours


for size in "${sizes[@]}"
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/ratios/llama_finqa_0.01.json \
        --test_data_path ./data/finqa/test.json \
        --src_len 2048 \
        --tgt_len 128 \
        --train_micro_batch_size_per_gpu 2 \
        --gradient_accumulation_steps 8 \
        --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 lora \
        --lora_target_modules q_proj,k_proj,v_proj,o_proj \
        --lora_alpha 32 \
        --lora_dropout 0.05 \
        --lora_r 16 \
        --ds_config_path ./config/ds_config_attack.json \
        --offload_device cpu \
        --nvme_path ./mnt/nvme \
        --block_size ${size} \
        --obfus_method ours
done

deepspeed --include localhost:0,1,2,3 --master_port 12345 ./attack/reconstruct_pi_finqa.py \
          --victim_model_path ./outputs/victim/llama3.2/finqa/final_model \
          --pretrained_model_path models/Llama-3.2-3B-Instruct \
          --recover_data_path ./attack/data/ratios/llama_finqa_0.01.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-3 \
          --initial_lr 1e-4 \
          --min_lr 1e-8 \
          --weight_decay 0.01 \
          --adam_beta1 0.9 \
          --adam_beta2 0.999\
          --epochs 10 \
          --ds_config_path ./config/ds_config_attack.json \
          --offload_device cpu \
          --block_size 512 \
          --nvme_path ./mnt/nvme
