#!/usr/bin/env bash
set -euo pipefail

ROOT_DIR=$(cd "$(dirname "${BASH_SOURCE[0]}")/../.." && pwd)

submit_size() {
    local size="$1"
    local time="$2"
    local job_file="$ROOT_DIR/MMAS/scripts/jobs_${size}.txt"

    "$ROOT_DIR/MMAS/scripts/make_job_list.sh" "$job_file" "$size"

    local count
    count=$(wc -l < "$job_file")
    if [[ "$count" -le 0 ]]; then
        echo "No jobs for size $size." >&2
        return 1
    fi

    while IFS=',' read -r job_size heatmap local_search seed gamma threshold; do
        local gamma_tag
        gamma_tag=$(printf 'gemma_%.1f' "$gamma")
        local thr_tag
        thr_tag=$(printf 'thr%.4f' "$threshold")
        thr_tag=${thr_tag//./p}
        local job_name="${heatmap}/TSP${job_size}/${gamma_tag}/${thr_tag}/${local_search}/seed${seed}"
        local log_dir="$ROOT_DIR/logs/${heatmap}/TSP${job_size}/${gamma_tag}/${thr_tag}/${local_search}/seed${seed}"
        mkdir -p "$log_dir"

        sbatch \
            --job-name="$job_name" \
            --time="$time" \
            --output="$log_dir/run.out" \
            --error="$log_dir/run.err" \
            --export=ALL,SIZE="$job_size",HEATMAP_TYPE="$heatmap",LOCAL_SEARCH="$local_search",SEED="$seed",GAMMA="$gamma",THRESHOLD="$threshold" \
            "$ROOT_DIR/MMAS/scripts/mmas_job.sbatch"
    done < "$job_file"
}

submit_size 500 01:00:00
submit_size 1000 02:00:00
submit_size 10000 04:00:00
