#!/bin/bash

export CUDA_VISIBLE_DEVICES="0"
# --- 参数 (Parameters) ---
MODEL_NAME="/mnt/Models/Qwen3-4B" # "Qwen/Qwen3-8B" or "Qwen/Qwen3-4B"
ATTN_TYPE="PRKV" # "lim":LessIsMore; "tidal":TidalDecode; "None": full attention
N_ATTEMPTS=4
MAX_GEN_LEN=32768 # 32768
TEMPERATURE=0.6
SPARSE_START_LAYER=2
CORRECTION_LAYER=12 #8B:12; 4B:20;
ATTENTION_SINK=4
TASKS=("math") #  "aime2025" "gpqa" "math"
LIM_RATIO=(0.75) # default 0.75, only matters When ATTN_TYPE is "lim"
TOP_K_VALUES=(1024) # fake full cache 

# --- 目录 (Directories) ---
# 使用当前工作目录
SUBMIT_DIR=$(pwd)
# 使用时间戳作为唯一的作业ID，这是一个很好的替代方案
JOB_ID=$(date +%s)
RESULTS_DIR="${SUBMIT_DIR}/results/"
LOG_DIR_PYTHON="${SUBMIT_DIR}/logs/"
mkdir -p "${RESULTS_DIR}"
mkdir -p "${LOG_DIR_PYTHON}"

# --- 主要执行逻辑 (Main Execution Logic) ---
SCRIPT_PATH="${SUBMIT_DIR}/eval_reasoning.py"

echo "Starting Reasoning evaluation runs..."
for TASK in "${TASKS[@]}"; do
  for SCALE in "${LIM_RATIO[@]}"; do
    for TOP_K in "${TOP_K_VALUES[@]}"; do
      echo "----------------------------------------------------------------------"
      # 使用我们自己定义的JOB_ID来命名日志文件
      RUN_LOG_FILE="${LOG_DIR_PYTHON}/eval_${TASK}_model-${MODEL_NAME//\//_}_attn-${ATTN_TYPE}_job-${JOB_ID}_r${SCALE}_k${TOP_K}.out"

      echo "Running task: ${TASK}, scale: ${SCALE}, top_k: ${TOP_K}"
      echo "Log file: ${RUN_LOG_FILE}"

      python "${SCRIPT_PATH}" \
        --model_name "${MODEL_NAME}" \
        --attn_type "${ATTN_TYPE}" \
        --top_k "${TOP_K}" \
        --n "${N_ATTEMPTS}" \
        --max_gen_len "${MAX_GEN_LEN}" \
        --temperature "${TEMPERATURE}" \
        --correction_layer "${CORRECTION_LAYER}" \
        --sparse_layer_start "${SPARSE_START_LAYER}" \
        --attention_sink "${ATTENTION_SINK}" \
        --lim_ratio "${SCALE}" \
        --task "${TASK}" \
        > "${RUN_LOG_FILE}" 2>&1
        
      echo "Finished task: ${TASK}, scale: ${SCALE}, top_k: ${TOP_K}"
    done
  done
done

echo "All runs have finished."
echo "Check Python script JSON results in: ${RESULTS_DIR}"
echo "Check individual run logs in: ${LOG_DIR_PYTHON}"