#!/bin/bash
# Run unbounded synthetic function experiments for multiple sigma and epsilon_y values
# Tests unbounded certifier (C, G) and alpha-smoothing methods on unbounded functions

# Parameters
N_SAMPLES=5000  # Reduced for faster execution (synthetic functions don't need as many samples)
N_TEST_POINTS=10
# Test all 3 unbounded functions
FUNCTION="all_unbounded"  # Options: "all_unbounded" (3 functions), or specific function name

# Sigma values to test
SIGMA_VALUES=(0.1 0.2 0.5)

# Epsilon_y values to test
EPS_Y_VALUES=(0.2 0.5)

# Alpha-trimming values to test
ALPHA_VALUES=(0.35 0.49)

# Success probability P for alpha-smoothing (also used as confidence for unbounded certifier)
# P=0.9 means 90% success probability = 10% failure probability
P=0.9

# Output directory
OUTPUT_DIR="unbounded_synthetic_experiments_results"
mkdir -p "$OUTPUT_DIR"

echo "=========================================="
echo "Running Unbounded Synthetic Function Experiments"
echo "=========================================="
echo "Sigma values: ${SIGMA_VALUES[@]}"
echo "Epsilon_y values: ${EPS_Y_VALUES[@]}"
echo "Alpha-trimming values: ${ALPHA_VALUES[@]}"
echo "P (success probability) = $P (10% failure budget for both methods)"
echo "N_samples = $N_SAMPLES"
echo "N_test_points = $N_TEST_POINTS"
echo "Functions: $FUNCTION"
echo "Output directory: $OUTPUT_DIR"
echo "=========================================="
echo ""

# Counter for tracking progress
total_runs=$((${#SIGMA_VALUES[@]} * ${#EPS_Y_VALUES[@]} * ${#ALPHA_VALUES[@]}))
current_run=0

# Run experiments for each combination
for sigma in "${SIGMA_VALUES[@]}"; do
    for eps_y in "${EPS_Y_VALUES[@]}"; do
        for alpha in "${ALPHA_VALUES[@]}"; do
            current_run=$((current_run + 1))
            
            echo ""
            echo "=========================================="
            echo "Run $current_run/$total_runs: sigma=$sigma, eps_y=$eps_y, alpha=$alpha"
            echo "=========================================="
            
            # Create output filename with unique timestamp
            timestamp=$(date +%Y%m%d_%H%M%S)
            output_file="${OUTPUT_DIR}/unbounded_sigma${sigma}_epsy${eps_y}_alpha${alpha}_${timestamp}.json"
            
            # Run the experiment
            python3 scripts/analysis/test_unbounded_certifiers_synthetic.py \
                --function "$FUNCTION" \
                --sigma "$sigma" \
                --eps_y "$eps_y" \
                --alpha_trim "$alpha" \
                --P "$P" \
                --N_samples "$N_SAMPLES" \
                --n_test_points "$N_TEST_POINTS" \
                --compute_true_radius \
                --output "$output_file"
            
            if [ $? -eq 0 ]; then
                echo "✓ Successfully completed: sigma=$sigma, eps_y=$eps_y, alpha=$alpha"
                echo "  Output: $output_file"
            else
                echo "✗ Failed: sigma=$sigma, eps_y=$eps_y, alpha=$alpha"
            fi
            echo ""
        done
    done
done

echo "=========================================="
echo "All experiments completed!"
echo "=========================================="
echo ""
echo "Results saved in: $OUTPUT_DIR"
echo ""
