#!/usr/bin/env bash
# rolling_train_equities_s4.sh
# Sliding-window training for the S4 baseline, seeds 1-5 per year.

# ── Move to repo root ───────────────────────────────────────────────────────────
cd "$(dirname "$0")"/..

# Use BASE_PATH from environment or set default if not defined
BASE_PATH=${BASE_PATH:-"./"}
# Remove trailing slash if present
BASE_PATH=${BASE_PATH%/}

# ── Tunables ────────────────────────────────────────────────────────────────────
N_SEEDS=5          # seeds 1…5
MAX_CONCURRENT=5   # max simultaneous Hydra jobs

# ── Outer loop over rolling windows ─────────────────────────────────────────────
for YEAR in {1990..2013}; do
  TRAIN_BEG=$(printf "%04d0101" "${YEAR}")
  TRAIN_END=$(printf "%04d1231" $((YEAR + 7)))
  VAL_BEG=$(printf  "%04d0101" $((YEAR + 8)))
  VAL_END=$(printf  "%04d1231" $((YEAR + 8)))
  TEST_BEG=$(printf "%04d0101" $((YEAR + 9)))
  TEST_END=$(printf "%04d1231" $((YEAR + 9)))
  VAL_YEAR=$(printf "%04d"     $((YEAR + 8)))

  echo "────────────────────────────────────────────────────────────"
  echo "YEAR ${YEAR}: Train ${TRAIN_BEG}–${TRAIN_END},   Val ${VAL_BEG}–${VAL_END},   Test ${TEST_BEG}–${TEST_END}"
  echo "────────────────────────────────────────────────────────────"

  # ── Inner loop over seeds ─────────────────────────────────────────────────────
  for SEED in $(seq 1 "$N_SEEDS"); do
    # Throttle: hold until < $MAX_CONCURRENT jobs are active
    while [ "$(jobs -p | wc -l)" -ge "$MAX_CONCURRENT" ]; do
      sleep 2
    done

    python -m train experiment=equities/equities_s4.yaml \
      dataset.dataset_config.train_beg_date="${TRAIN_BEG}" \
      dataset.dataset_config.train_end_date="${TRAIN_END}" \
      dataset.dataset_config.val_beg_date="${VAL_BEG}" \
      dataset.dataset_config.val_end_date="${VAL_END}" \
      dataset.dataset_config.test_beg_date="${TEST_BEG}" \
      dataset.dataset_config.test_end_date="${TEST_END}" \
      ++dataset.save_data=False \
      ++dataset.load_data=True \
      ++dataset.data_path="${BASE_PATH}/data/equities/equity_dataset_${VAL_YEAR}.npz" \
      ++train.seed="${SEED}" \
      wandb.name="${VAL_BEG}_s4_seed${SEED}" &

    # Small pause to prevent Hydra timestamp collisions
    sleep 5
  done
done

# ── Final rendez-vous ───────────────────────────────────────────────────────────
wait
echo "All sliding-window training jobs have completed."

# chmod +x rolling_train_equities_s4.sh
# ./rolling_train_equities_s4.sh