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

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

submit_prob() {
    local prob="$1"
    local time="$2"
    local job_file="$ROOT_DIR/MMAS_TSPLIB/scripts/jobs_${prob}.txt"

    "$ROOT_DIR/MMAS_TSPLIB/scripts/make_job_list.sh" "$job_file" "$prob"

    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_prob 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}/${job_prob}/${gamma_tag}/${thr_tag}/${local_search}/seed${seed}"
        local log_dir="$ROOT_DIR/logs/${heatmap}/${job_prob}/${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,PROB="$job_prob",HEATMAP_TYPE="$heatmap",LOCAL_SEARCH="$local_search",SEED="$seed",GAMMA="$gamma",THRESHOLD="$threshold" \
            "$ROOT_DIR/MMAS_TSPLIB/scripts/mmas_job.sbatch"
    done < "$job_file"
}

submit_prob pcb442 00:10:00
submit_prob pr1002 00:10:00
submit_prob pr2392 00:10:00
