#!/bin/bash

ratios=(0.01 0.1 0.2 0.3 0.4 0.5 0.6)
# # ratios=(0.3 0.4 0.5 0.6)

# for ratio in "${ratios[@]}"
# do
# python ./attack/recover_dataset_finqa.py \
#         --model_name_or_path ./outputs/victim/llama3.2/finqa/final_model \
#         --data_path ./data/finqa/train.json \
#         --ratio ${ratio} \
#         --output_path ./attack/data/ratios/llama_finqa_${ratio}.json \
#         --src_len 2048 \
#         --tgt_len 128 
# done

# gemma3 wic
for ratio in "${ratios[@]}"
do
python ./attack/recover_dataset.py \
        --model_name_or_path ./outputs/victim/gemma3/wic/final_merged_model \
        --data_path ./data/wic \
        --num_labels 2 \
        --ratio ${ratio} \
        --output_path ./attack/data/ratios/gemma3_wic_${ratio}.json \
        --batch_size 32 \
        --src_len 512 \
        --tgt_len 128 
done

# # gpt2 mnli
# for ratio in "${ratios[@]}"
# do
# python ./attack/recover_dataset.py \
#         --model_name_or_path ./outputs/victim/gpt2/mnli/final_model \
#         --data_path ./data/mnli \
#         --num_labels 3 \
#         --ratio ${ratio} \
#         --batch_size 128 \
#         --output_path ./attack/data/ratios/gpt2_mnli_${ratio}.json \
#         --src_len 512 \
#         --tgt_len 128 
# done

# for ratio in "${ratios[@]}"
# do
# python ./attack/recover_dataset_goemotions.py \
#         --model_name_or_path ./outputs/victim/qwen3/goemotions/final_merged_model \
#         --data_path ./data/goemotions \
#         --ratio ${ratio} \
#         --output_path ./attack/data/ratios/qwen3_goemotions_${ratio}.json \
#         --batch_size 8 \
#         --src_len 64 \
#         --tgt_len 128 
# done

# # gpt2 mnli full-tuning
# 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/ratios/gpt2_mnli_0.6.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 black-box

# 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/ratios/gpt2_mnli_0.4.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 ours

# # gpt2 mnli lora
# 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/ratios/gpt2_mnli_0.6.json \
#         --num_labels 3 \
#         --train_micro_batch_size_per_gpu 64 \
#         --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 5 \
#         --ds_config_path ./config/ds_config_attack.json \
#         --finetune_method lora \
#         --lora_target_modules c_attn,c_proj \
#         --lora_alpha 32 \
#         --lora_dropout 0.05 \
#         --lora_r 16 \
#         --offload_device cpu \
#         --nvme_path ./mnt/nvme \
#         --obfus_method black-box

# for ratio in "${ratios[@]}"
# 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/ratios/gpt2_mnli_${ratio}.json \
#                 --num_labels 3 \
#                 --train_micro_batch_size_per_gpu 64 \
#                 --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 lora \
#                 --lora_target_modules c_attn,c_proj \
#                 --lora_alpha 32 \
#                 --lora_dropout 0.05 \
#                 --lora_r 16 \
#                 --offload_device cpu \
#                 --nvme_path ./mnt/nvme \
#                 --obfus_method ours
# done


# # gemma3 wic lora
# 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/ratios/gemma3_wic_0.6.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 black-box

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/ratios/gemma3_wic_0.3.json \
        --num_labels 2 \
        --train_micro_batch_size_per_gpu 8 \
        --gradient_accumulation_steps 1 \
        --max_lr 1e-3 \
        --initial_lr 1e-4 \
        --min_lr 1e-6 \
        --weight_decay 0.01 \
        --adam_beta1 0.9 \
        --adam_beta2 0.999\
        --epochs 20 \
        --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 ours

# # gemma3 wic full-tuning
# 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/ratios/gemma3_wic_0.6.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 full-tuning \
#         --offload_device cpu \
#         --nvme_path ./mnt/nvme \
#         --obfus_method black-box

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/ratios/gemma3_wic_0.4.json \
        --num_labels 2 \
        --train_micro_batch_size_per_gpu 8 \
        --gradient_accumulation_steps 1 \
        --max_lr 1e-3 \
        --initial_lr 1e-4 \
        --min_lr 1e-6 \
        --weight_decay 0.01 \
        --adam_beta1 0.9 \
        --adam_beta2 0.999\
        --epochs 5 \
        --ds_config_path ./config/ds_config_attack.json \
        --finetune_method full-tuning \
        --offload_device cpu \
        --nvme_path ./mnt/nvme \
        --obfus_method ours

# # qwen3 goemotions lora
# 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 \
#             --obfus_method black-box

# 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.3.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 5 \
#             --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

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.1.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 5 \
            --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 ours

# # qwen3 goemotions full-tuning
# 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.6.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 full-tuning \
#             --offload_device cpu \
#             --nvme_path ./mnt/nvme \
#             --obfus_method black-box

# 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.2.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 full-tuning \
#             --offload_device cpu \
#             --nvme_path ./mnt/nvme \
#             --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 10 \
            --ds_config_path ./config/ds_config_attack.json \
            --finetune_method full-tuning \
            --offload_device cpu \
            --nvme_path ./mnt/nvme \
            --obfus_method ours

# llama finqa full-tuning
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 \
        --obfus_method black-box

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.1.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 7 \
        --finetune_method full-tuning \
        --ds_config_path ./config/ds_config_attack.json \
        --offload_device cpu \
        --nvme_path ./mnt/nvme \
        --obfus_method black-box

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.6.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 5 \
        --finetune_method full-tuning \
        --ds_config_path ./config/ds_config_attack.json \
        --offload_device cpu \
        --nvme_path ./mnt/nvme \
        --obfus_method black-box

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.6.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 5 \
        --finetune_method full-tuning \
        --ds_config_path ./config/ds_config_attack.json \
        --offload_device cpu \
        --nvme_path ./mnt/nvme \
        --obfus_method ours

# llama finqa lora
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 20 \
        --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 \
        --obfus_method black-box

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.1.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 20 \
        --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 \
        --obfus_method black-box

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.6.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 \
        --obfus_method black-box

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.6.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 \
        --obfus_method ours