
























set -e


SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
cd "$SCRIPT_DIR"




N_OMEGA=30
SEEDS="0 1 2"
N_GPUS=2
WORKERS_PER_GPU=2
QUICK_MODE=false
NO_SKIP=false
K=6
TOTAL_STEPS=20000
WARMUP_STEPS=3000
RAMP_STEPS=5000
OUTPUT_DIR="results"


while [[ $# -gt 0 ]]; do
    case $1 in
        --n_gpus)
            N_GPUS="$2"
            shift 2
            ;;
        --n_omega)
            N_OMEGA="$2"
            shift 2
            ;;
        --seeds)
            SEEDS="$2"
            shift 2
            ;;
        --quick)
            QUICK_MODE=true
            shift
            ;;
        --no_skip)
            NO_SKIP=true
            shift
            ;;
        --workers_per_gpu)
            WORKERS_PER_GPU="$2"
            shift 2
            ;;
        --K)
            K="$2"
            shift 2
            ;;
        --total_steps)
            TOTAL_STEPS="$2"
            shift 2
            ;;
        *)
            echo "Unknown option: $1"
            echo "Usage: bash run.sh [--quick] [--n_gpus N] [--n_omega N] [--seeds '0 1 2'] [--no_skip]"
            exit 1
            ;;
    esac
done


if [ "$QUICK_MODE" = true ]; then
    N_OMEGA=5
    SEEDS="0"
    TOTAL_STEPS=5000
    WARMUP_STEPS=1000
    RAMP_STEPS=1500
    echo "Quick mode: Running with $N_OMEGA angles, 1 seed, reduced steps"
fi





if command -v nvidia-smi &> /dev/null; then
    DETECTED_GPUS=$(nvidia-smi --query-gpu=name --format=csv,noheader | wc -l)
    echo "Detected $DETECTED_GPUS GPU(s):"
    nvidia-smi --query-gpu=index,name,memory.total --format=csv
    echo ""
else
    DETECTED_GPUS=0
    echo "No NVIDIA GPUs detected, will use CPU"
fi


if [ "$DETECTED_GPUS" -gt "$N_GPUS" ]; then
    echo "Note: Using $N_GPUS of $DETECTED_GPUS available GPUs"
fi




N_SEEDS=$(echo $SEEDS | wc -w)
TOTAL_EXPS=$((N_OMEGA * 4 * 2 * N_SEEDS))

echo "Configuration:"
echo "  - Number of angles: $N_OMEGA"
echo "  - BC types: DD, NN, DN, ND"
echo "  - Methods: naive, constraint"
echo "  - Seeds: $SEEDS"
echo "  - GPUs to use: $N_GPUS"
echo "  - Workers per GPU: $WORKERS_PER_GPU"
echo "  - K (MSN terms): $K"
echo "  - Total steps: $TOTAL_STEPS (warmup: $WARMUP_STEPS, ramp: $RAMP_STEPS)"
echo "  - Output directory: $OUTPUT_DIR"
echo ""
echo "Total experiments to run: $TOTAL_EXPS"
echo "  = $N_OMEGA angles × 4 BC types × 2 methods × $N_SEEDS seeds"
echo ""


EST_TIME_PER_EXP=100
if [ "$QUICK_MODE" = true ]; then
    EST_TIME_PER_EXP=25
fi
EST_TIME_SEC=$((TOTAL_EXPS * EST_TIME_PER_EXP / (N_GPUS * WORKERS_PER_GPU)))
EST_TIME_MIN=$((EST_TIME_SEC / 60))
EST_TIME_HR=$((EST_TIME_MIN / 60))
echo "Estimated time: ~${EST_TIME_MIN} minutes (~${EST_TIME_HR} hours)"
echo ""





CMD="python run_experiment.py \
    --n_omega $N_OMEGA \
    --n_gpus $N_GPUS \
    --seeds $SEEDS \
    --K $K \
    --total_steps $TOTAL_STEPS \
    --warmup_steps $WARMUP_STEPS \
    --ramp_steps $RAMP_STEPS \
    --output_dir $OUTPUT_DIR \
    --workers_per_gpu $WORKERS_PER_GPU"

if [ "$NO_SKIP" = true ]; then
    CMD="$CMD --no_skip"
fi

echo "Running: $CMD"
echo ""
eval $CMD




python aggregate_results.py \
    --results_dir $OUTPUT_DIR \
    --output exp.csv \
    --summary exp_summary.txt \
    --stats_json exp_stats.json




