source scripts/common_setting.sh

tune_ckpt_path="buddy"
#base_model="$llama2"
#model_name="llama2"
base_model="$qwen7b"
model_name="qwen7b"
data_path="yahma/alpaca-cleaned"
data_name="alpaca"
lora_r=8

sensitivity_types=(
  "None"
  "ppl"
  "taylor"
  "similarity"
)

sensitivity_paths=(
  "None"
  "utils/sensitivity/${model_name}_output/ppl/all_ppl_unsorted.csv"
  "utils/sensitivity/${model_name}_output/taylor/block_score_all.csv"
  "utils/sensitivity/${model_name}_output/similarity/block_score_all.csv"
)

gpu_ids=(0 1 2 3)

run_tuning_and_evaluation(){

  local gpu_id=$1
  local sensitivity_type=$2
  local sensitivity_path=$3

  echo "base_model: ${base_model}"
  echo "Lora Config: lora_r=($lora_r),"
  current_time=$(date "+%Y-%m-%d %H:%M:%S")
  echo "Start tuning on gpu: $gpu_id, $current_time"

  CUDA_VISIBLE_DEVICES=$gpu_id python finetune.py \
     --base_model $base_model \
     --data_name $data_name \
     --data_path $data_path \
     --output_dir tune_log/$model_name/${tune_ckpt_path}_${lora_r}/$data_name/ablation/${sensitivity_type}/ \
     --lora_r $lora_r \
     --cutoff_len 512 \
     --lambda_reg 0.5 \
     --sensitivity_type ${sensitivity_type} \
     --sensitivity_path ${sensitivity_path} \
     --num_epochs 2 \
     --learning_rate 1e-4 \
     --gradient_accumulation_steps 16 \
     --batch_size 8

 # ---------------- eval acc ------------------
   num_remove_blocks=(
    4 8 12 16
   )
   eval_gpus=(
    0 1 2 3
   )

  echo "base_model: ${base_model}"
  current_time=$(date "+%Y-%m-%d %H:%M:%S")
  echo "Start evaluation on gpu: $gpu_id, $current_time"

  for ((k=0; k<${#num_remove_blocks[@]}; k+=1)); do
    remove_blocks=${num_remove_blocks[$k]}
    eval_gpu=${eval_gpus[$k]}
    CUDA_VISIBLE_DEVICES=$eval_gpu python zero_shot_eval.py --model hf \
        --pretrained ${base_model} \
        --peft tune_log/$model_name/${tune_ckpt_path}_${lora_r}/$data_name/ablation/${sensitivity_type}/ \
        --num_remove_blocks ${remove_blocks} \
        --lambda_reg 0.1 \
        --sensitivity_type ${sensitivity_type} \
        --sensitivity_path ${sensitivity_path} \
        --tasks openbookqa,piqa,boolq,social_iqa,hellaswag,arc_easy,winogrande,arc_challenge \
        --device cuda:0 \
        --batch_size 4 \
        --output_path results/$model_name/${tune_ckpt_path}_rm${remove_blocks}_lora${lora_r}/$data_name/ablation/${sensitivity_type}/
  done
  wait
  current_time=$(date "+%Y-%m-%d %H:%M:%S")
  echo "End evaluation on gpu: $gpu_id, $current_time"
}

for ((j=0; j<${#sensitivity_types[@]}; j+=4)); do
  for i in "${!gpu_ids[@]}"; do
      idx=$((j+i))
      if ((idx>=${#sensitivity_types[@]}));then
        break
      fi

      gpu_id=${gpu_ids[$i]}
      sensitivity_type=${sensitivity_types[$idx]}
      sensitivity_path=${sensitivity_paths[$idx]}

      run_tuning_and_evaluation "$gpu_id" "$sensitivity_type" "$sensitivity_path" &
  done
  wait  # Wait for all tuning and evaluation processes to finish
done