#!/bin/bash

# === RQ1 Code-Only Batch Launcher ===
# Runs all 4 tasks with code-only triplet variant × 10 seeds (0-9)
# Tests the impact of removing both temporal and value information from triplet representations
# Simple logging with timing, git info, and system details

LOG_FILE="rq1_code_only_run_log.txt"
touch "$LOG_FILE"

TASKS=(
  "mortality/in_hospital/first_24h"
  "mortality/in_icu/first_24h"
  "mortality/post_hospital_discharge/1y"
  "readmission/30d"
)

VARIANT="code_only"
EPOCHS=10
SEEDS=(0 1 2 3 4 5 6 7 8 9)  # 10 seeds as requested

# === System Info ===
BATCH_START_TIME=$(date '+%Y-%m-%d %H:%M:%S')
HOSTNAME=$(hostname)
PYTHON_VERSION=$(python --version 2>&1)
GIT_BRANCH="unknown"
GIT_COMMIT="unknown"

# Set correct branch name for this experiment
GIT_BRANCH="rq1_triplet_code_only"
GIT_COMMIT="unknown"

# Get git commit if available
if command -v git &> /dev/null; then
  cd meds-torch 2>/dev/null && {
    GIT_COMMIT=$(git rev-parse --short HEAD 2>/dev/null || echo "unknown")
  }
  cd .. 2>/dev/null
fi

echo "=== Starting RQ1 Code-Only Experiments - $BATCH_START_TIME ===" | tee -a "$LOG_FILE"
echo "Host: $HOSTNAME | Python: $PYTHON_VERSION | Git: $GIT_BRANCH ($GIT_COMMIT)" | tee -a "$LOG_FILE"
echo "Total runs: $((${#TASKS[@]} * ${#SEEDS[@]}))" | tee -a "$LOG_FILE"
echo "" | tee -a "$LOG_FILE"

RUN_COUNT=0
TOTAL_RUNS=$((${#TASKS[@]} * ${#SEEDS[@]}))

for TASK in "${TASKS[@]}"; do
  for SEED in "${SEEDS[@]}"; do
    RUN_COUNT=$((RUN_COUNT + 1))
    RUN_START_TIME=$(date '+%Y-%m-%d %H:%M:%S')
    RUN_START_TIMESTAMP=$(date +%s)
    
    echo "[$RUN_COUNT/$TOTAL_RUNS] Launching: Task='${TASK}' Variant='${VARIANT}' Seed=${SEED} - Started: $RUN_START_TIME"
    
    bash run_rq1_code_only_dynamic.sh task="$TASK" variant="$VARIANT" seed="$SEED" epochs="$EPOCHS"
    
    RUN_END_TIME=$(date '+%Y-%m-%d %H:%M:%S')
    RUN_DURATION=$(($(date +%s) - RUN_START_TIMESTAMP))
    RUN_DURATION_FORMATTED=$(printf "%02d:%02d:%02d" $((RUN_DURATION/3600)) $((RUN_DURATION%3600/60)) $((RUN_DURATION%60)))
    
    # Log the result
    if [[ $? -eq 0 ]]; then
      echo "✅ SUCCESS: $TASK, $VARIANT, seed=$SEED | Duration: $RUN_DURATION_FORMATTED | Started: $RUN_START_TIME | Ended: $RUN_END_TIME | Branch: $GIT_BRANCH | Python: $PYTHON_VERSION | Host: $HOSTNAME" | tee -a "$LOG_FILE"
    else
      echo "❌ FAILED: $TASK, $VARIANT, seed=$SEED | Duration: $RUN_DURATION_FORMATTED | Started: $RUN_START_TIME | Ended: $RUN_END_TIME | Branch: $GIT_BRANCH | Python: $PYTHON_VERSION | Host: $HOSTNAME" | tee -a "$LOG_FILE"
    fi
    echo ""
  done
done

echo "=== Completed all RQ1 Code-Only Experiments - $(date) ===" | tee -a "$LOG_FILE" 