#!/bin/bash

# 默认值
DATASET="OAS"
TRAIN_MODE=0
USE_CALIBRATION=false
USE_PERTURBATION=false
ETA_C=1.0
ETA_P=1.0

# 只解析用于日志命名的参数，其余参数全部透传
ARGS=("$@")
for ((i=0; i<$#; i++)); do
    case ${ARGS[$i]} in
        --dataset)
            DATASET="${ARGS[$((i+1))]}"
            ;;
        --train_mode)
            TRAIN_MODE="${ARGS[$((i+1))]}"
            ;;
        --use_calibration)
            USE_CALIBRATION="${ARGS[$((i+1))]}"
            ;;
        --use_perturbation)
            USE_PERTURBATION="${ARGS[$((i+1))]}"
            ;;
        --eta_c)
            ETA_C="${ARGS[$((i+1))]}"
            ;;
        --eta_p)
            ETA_P="${ARGS[$((i+1))]}"
            ;;
    esac
done

# 日志目录
LOG_BASE_DIR="./log"
DATASET_LOG_DIR="${LOG_BASE_DIR}/${DATASET}"
mkdir -p "${DATASET_LOG_DIR}"

# 日志文件名
FILENAME="train_mode_${TRAIN_MODE}_calibration_${USE_CALIBRATION}_perturbation_${USE_PERTURBATION}_eta_c_${ETA_C}_eta_p_${ETA_P}"
LOG_FILE="${DATASET_LOG_DIR}/${FILENAME}.log"

# 打印配置
echo "=== Configuration ==="
echo "Dataset: ${DATASET}"
echo "Train Mode: ${TRAIN_MODE}"
echo "Use Calibration: ${USE_CALIBRATION}"
echo "Use Perturbation: ${USE_PERTURBATION}"
echo "Eta_c: ${ETA_C}"
echo "Eta_p: ${ETA_P}"
echo "Log File: ${LOG_FILE}"
echo "===================="

# 运行主程序，所有参数都透传
nohup python ./main/cb_main.py "$@" > "${LOG_FILE}" 2>&1 &

PID=$!
echo "Process started with PID: ${PID}"
echo "Log file: ${LOG_FILE}"
echo "To monitor the log: tail -f ${LOG_FILE}"
echo "To check process status: ps aux | grep ${PID}" 