#!/bin/bash
set -e

SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
cd "$SCRIPT_DIR"

# ==============================================================================
# Quick Start Examples
# ==============================================================================
#
# 1. Run with all default settings (Worker ID will be randomly generated):
#    ./start_worker.sh
#
# 2. Run with a specific task tag (Worker ID will be randomly generated):
#    ./start_worker.sh --task_tag my_experiment
#
# 3. Run for a limited time (e.g., 1 hour = 3600 seconds):
#    ./start_worker.sh --run_time 3600
#
# 4. Run a spec-driven worker for one interval:
#    ./start_worker.sh --spec_path op/my_experiment/spec.json --piece_id p0
#
# For more options, use: ./start_worker.sh --help
# ==============================================================================

# Default parameter values
TASK_TAG_DEFAULT="task_1"
CHECK_INTERVAL_DEFAULT=5
RUN_TIME_DEFAULT=0
NUM_MANTAIN_DEFAULT=40
WORKER_TYPE_DEFAULT="default"
FUN_DEFAULT="exp"
FUN_IDX_DEFAULT=0
EPS_DEFAULT=1e-6
SPEC_PATH_DEFAULT=""
PIECE_ID_DEFAULT=""


log() {
  echo "[$(date '+%Y-%m-%d %H:%M:%S')] $1"
}

show_help() {
  echo "Usage: $0 [options]"
  echo
  echo "Start a Worker node that fetches tasks from the queue, runs DAG evolution,"
  echo "and writes evolved DAGs to the pool folder. Worker ID is auto-generated."
  echo
  echo "Options:"
  echo "  --task_tag TAG         Task identifier (default: ${TASK_TAG_DEFAULT})"
  echo "  --check_interval SEC   Task poll interval in seconds (default: ${CHECK_INTERVAL_DEFAULT})"
  echo "  --run_time SEC         Run time in seconds; 0 = unlimited (default: ${RUN_TIME_DEFAULT})"
  echo "  --num_mantain NUM      Population size maintained during evolution (default: ${NUM_MANTAIN_DEFAULT})"
  echo "  --num_maintain NUM     Alias for --num_mantain"
  echo "  --worker_type TYPE     Legacy log label only; target is controlled by --fun or --spec_path"
  echo "  --fun TYPE             Target function, e.g. exp/log/sin/cos/tanh/sinh/sigmoid/besselj (default: ${FUN_DEFAULT})"
  echo "  --fun_idx ID           Function index/parameter (default: ${FUN_IDX_DEFAULT})"
  echo "  --eps EPS              Optimization tolerance (default: ${EPS_DEFAULT})"
  echo "  --spec_path PATH       Spec JSON path (default: none)"
  echo "  --piece_id ID          Piece ID within the spec (default: none)"
  echo "  --help                 Show this help message"
  echo
  echo "Examples:"
  echo "  $0 --task_tag prod_run --check_interval 10"
  echo "  $0 --run_time 3600"
  echo "  $0 --num_mantain 100"
  exit 0
}

# Initialize variables with default values
TASK_TAG="$TASK_TAG_DEFAULT"
CHECK_INTERVAL="$CHECK_INTERVAL_DEFAULT"
RUN_TIME="$RUN_TIME_DEFAULT"
NUM_MANTAIN="$NUM_MANTAIN_DEFAULT"
WORKER_TYPE="$WORKER_TYPE_DEFAULT"
FUN="$FUN_DEFAULT"
FUN_IDX="$FUN_IDX_DEFAULT"
EPS="$EPS_DEFAULT"
SPEC_PATH="$SPEC_PATH_DEFAULT"
PIECE_ID="$PIECE_ID_DEFAULT"

# Parse command-line arguments
while [[ $# -gt 0 ]]; do
  case $1 in
    --help)
      show_help
      ;;
    --task_tag)
      TASK_TAG="$2"
      shift 2
      ;;
    --check_interval)
      CHECK_INTERVAL="$2"
      shift 2
      ;;
    --run_time)
      RUN_TIME="$2"
      shift 2
      ;;
    --num_mantain|--num_maintain)
      NUM_MANTAIN="$2"
      shift 2
      ;;
    --worker_type)
      WORKER_TYPE="$2"
      shift 2
      ;;
    --fun)
      FUN="$2"
      shift 2
      ;;
    --fun_idx)
      FUN_IDX="$2"
      shift 2
      ;;
    --eps)
      EPS="$2"
      shift 2
      ;;
    --spec_path)
      SPEC_PATH="$2"
      shift 2
      ;;
    --piece_id)
      PIECE_ID="$2"
      shift 2
      ;;
    *)
      echo "Error: unknown argument: $1" >&2
      echo "Use '$0 --help' for usage information." >&2
      exit 1
      ;;
  esac
done

WORKER_SCRIPT_PATH="worker/worker_node_log.py"

# Output current settings
log "Starting Worker node (type: $WORKER_TYPE)"
log "- Task tag: $TASK_TAG"
log "- Check interval: $CHECK_INTERVAL s"
log "- Run time: $RUN_TIME s (0=unlimited)"
log "- Population size: $NUM_MANTAIN"
log "- Worker script: $WORKER_SCRIPT_PATH"

# Optional spec arguments
SPEC_ARGS=()
if [ -n "$SPEC_PATH" ]; then
  SPEC_ARGS+=(--spec_path "$SPEC_PATH")
fi
if [ -n "$PIECE_ID" ]; then
  SPEC_ARGS+=(--piece_id "$PIECE_ID")
fi

# Check if worker script exists
if [ ! -f "$WORKER_SCRIPT_PATH" ]; then
  log "Error: Worker script not found: $WORKER_SCRIPT_PATH" >&2
  exit 1
fi

# Run worker script
python3 "$WORKER_SCRIPT_PATH" \
  --task_tag "$TASK_TAG" \
  --check_interval "$CHECK_INTERVAL" \
  --run_time "$RUN_TIME" \
  --num_mantain "$NUM_MANTAIN" \
  --fun "$FUN" \
  --fun_idx "$FUN_IDX" \
  --eps "$EPS" \
  "${SPEC_ARGS[@]}"
