#!/bin/bash
#SBATCH --job-name=trace_option_contrib
#SBATCH --partition=lvjq
#SBATCH --nodes=1
#SBATCH --ntasks-per-node=1
#SBATCH --cpus-per-task=3
#SBATCH --gres=gpu:1
#SBATCH -o %J.out
#SBATCH -e %J.err

module load anaconda3
source activate come_llama2

export CUDA_HOME=/usr/local/cuda
export PATH=$CUDA_HOME/bin:$PATH
export LD_LIBRARY_PATH=$CUDA_HOME/lib64:$LD_LIBRARY_PATH

PYTHON=~/.conda/envs/come/bin/python

# 定义基础路径
TASK=hellaswag
BASE_PATH="/TO/MY/PATH/code/Understanding_Performance_Collapse/iter_shortgpt_output/calib_arc_challenge/llama2-7b-chat-hf/prun"
OUTPUT_BASE="/TO/MY/PATH/code/Understanding_Performance_Collapse/tools/results/0-llama2-7b-chat/results_option_logits/${TASK}"

# 定义数组
PR_RATIOS=("Dense" "PR_12.5%" "PR_37.5%" "PR_50%")
MODEL_PATHS=(
    "/TO/MY/PATH/ckpt/llama2-7b-chat-hf"
    "${BASE_PATH}/ContinuePrun-from-ShortGPT-31Layer/llama2-7b-chat-hf_shortgpt_28"
    "${BASE_PATH}/ContinuePrun-from-ShortGPT-23Layer/llama2-7b-chat-hf_shortgpt_23_shortgpt_20"
    "${BASE_PATH}/ContinuePrun-from-ShortGPT-23Layer/llama2-7b-chat-hf_shortgpt_23_shortgpt_16"
)
DENSE_LAYERS=(32 32 32 32)  # 所有模型都是32层

# 循环处理
for i in "${!PR_RATIOS[@]}"; do
    PR_RATIO="${PR_RATIOS[i]}"
    MODEL_PATH="${MODEL_PATHS[i]}"
    LAYERS="${DENSE_LAYERS[i]}"
    OUTPUT_DIR="${OUTPUT_BASE}/${PR_RATIO}/"
    
    echo "Processing: ${PR_RATIO}"
    echo "Model path: ${MODEL_PATH}"
    
    ${PYTHON} /TO/MY/PATH/code/Understanding_Performance_Collapse/TALE/trace_layerwise_option_logits.py \
        --model_name_or_path "${MODEL_PATH}" \
        --sft_dataset ${TASK} \
        --eval_split validation \
        --num_eval_samples 500 \
        --output_dir "${OUTPUT_DIR}" \
        --dense_layers "${LAYERS}"
    
    echo "----------------------------------------"
done

echo "All models processed!"
