#!/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

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

# 定义基础路径
BASE_PATH="/TO/MY/PATH/code/Understanding_Performance_Collapse/iter_shortgpt_output/calib_arc_challenge/qwen3-4b-instruct/prun/ContinuePrun-from-ShortGPT-31Layer"
TASK=hellaswag

# 定义模型路径和对应的剪枝比例
declare -A MODELS=(
    ["PR_11.1%"]="Qwen3-4B-Instruct-2507-modelscope_shortgpt_32"
    ["PR_30.56%"]="Qwen3-4B-Instruct-2507-modelscope_shortgpt_25"
    ["PR_50%"]="Qwen3-4B-Instruct-2507-modelscope_shortgpt_18"
)

# 定义输出基础路径
OUTPUT_BASE="/TO/MY/PATH/code/Understanding_Performance_Collapse/tools/results/1-qwen3-4b-instruct/results_option_logits/${TASK}"

# 循环处理每个模型
for PR_RATIO in "${!MODELS[@]}"; do
    MODEL_NAME="${MODELS[$PR_RATIO]}"
    MODEL_PATH="${BASE_PATH}/${MODEL_NAME}"
    OUTPUT_DIR="${OUTPUT_BASE}/${PR_RATIO}/"
    
    echo "========================================"
    echo "Processing: ${PR_RATIO}"
    echo "Model path: ${MODEL_PATH}"
    echo "Output dir: ${OUTPUT_DIR}"
    echo "========================================"
    
    ${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 36
    
    echo ""
done

OUTPUT_DIR="${OUTPUT_BASE}/Dense/"
${PYTHON} /TO/MY/PATH/code/Understanding_Performance_Collapse/TALE/trace_layerwise_option_logits.py \
    --model_name_or_path /TO/MY/PATH/ckpt/Qwen3-4B-Instruct-2507-modelscope \
    --sft_dataset ${TASK} \
    --eval_split validation \
    --num_eval_samples 500 \
    --output_dir "${OUTPUT_DIR}" \
    --dense_layers 36
echo "All models processed!"
