#!/bin/bash
#SBATCH --job-name=per_layer_margin_eval_plot_sweep
#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

PLOT=/TO/MY/PATH/code/Understanding_Performance_Collapse/tools/plot_margin_phase_transition.py

# 你的结果根目录：里面应有多个 margin_arc_easy_ratio_xxx% 子目录
ROOT=/TO/MY/PATH/code/Understanding_Performance_Collapse/tools/results/calib_arc_challenge

# 层数与剪枝率的对应（按你给的）
# LAYERS=(31 30 29 28 27 26 25)
# RATIOS=("3.1%" "6.2%" "9.4%" "12.5%" "15.6%" "18.8%" "21.9%")
# RATIOS_VALUE=("3.1" "6.2" "9.4" "12.5" "15.6" "18.8" "21.9")
LAYERS=(24 23 22 21 20 19 18)
RATIOS=("25%" "28.1%" "31.2%" "34.4%" "37.5%" "40.6%" "43.8%")
RATIOS_VALUE=("25.0" "28.1" "31.2" "34.4" "37.5" "40.6" "43.8")

for i in "${!LAYERS[@]}"; do
  L=${LAYERS[$i]}
  R=${RATIOS[$i]}
  R_V=${RATIOS_VALUE[$i]}

  OUTDIR="${ROOT}/margin_arc_easy_ratio_${R}"
  JSONL="${OUTDIR}/metrics.jsonl"

  if [ ! -f "$JSONL" ]; then
    echo "[WARN] missing $JSONL, skip."
    continue
  fi

  echo "== Plot pruned: layer=$L ratio=$R =="

  $PYTHON "$PLOT" \
    --metrics_jsonl "$JSONL" \
    --out_dir "${OUTDIR}/plots_pruned_polish" \
    --which pruned \
    --font_size 14 \
    --prune_ratio ${R_V}
done
