#!/bin/bash
set -e

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

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

show_help() {
  echo "Usage: $0 [options]"
  echo
  echo "Options:"
  echo "  --task_tag TAG         Task identifier (default: task_1)"
  echo "  --batch_size SIZE      Batch size for task creation (default: 40)"
  echo "  --worker_num NUM       Number of worker nodes (default: 10)"
  echo "  --iterations NUM       Equivalent iterations (default: 1)"
  echo "  --max_tasks NUM        Maximum number of tasks (default: worker_num * batch_size * iterations)"
  echo "  --check_interval SEC   Check interval in seconds (default: 60)"
  echo "  --poly NUM             Polynomial degree for initial DAGs (default: 2)"
  echo "  --type_string TYPE     Data type (default: float)"
  echo "  --archive_threshold N  Archive threshold (default: 1000)"
  echo "  --stats_frequency N    Stats output frequency (default: 10000)"
  echo "  --init_multiplier N    Initial DAG count multiplier (default: 1)"
  echo "  --force_init           Force re-initialization even if task setup exists"
  echo "  --min_dag_count N      Minimum DAG file count for existing setup (default: 10)"
  echo "  --help                 Show this help message"
  echo
  echo "Examples:"
  echo "  $0 --task_tag test --worker_num 20"
  echo "  $0 --worker_num 100 --batch_size 20 --iterations 5"
  echo "  $0 --force_init"
  exit 0
}

# Default parameters
TASK_TAG="task_1"
BATCH_SIZE=40
WORKER_NUM=10
ITERATIONS=1
MAX_TASKS=""
CHECK_INTERVAL=60
POLY=2
TYPE_STRING="float"
ARCHIVE_THRESHOLD=1000
STATS_FREQUENCY=10000
INIT_MULTIPLIER=1
FORCE_INIT=false
MIN_DAG_COUNT=10

# Parse command-line arguments
while [[ $# -gt 0 ]]; do
  case $1 in
    --help)
      show_help
      ;;
    --task_tag)
      TASK_TAG="$2"
      shift 2
      ;;
    --batch_size)
      BATCH_SIZE="$2"
      shift 2
      ;;
    --worker_num)
      WORKER_NUM="$2"
      shift 2
      ;;
    --iterations)
      ITERATIONS="$2"
      shift 2
      ;;
    --max_tasks)
      MAX_TASKS="$2"
      shift 2
      ;;
    --check_interval)
      CHECK_INTERVAL="$2"
      shift 2
      ;;
    --poly)
      POLY="$2"
      shift 2
      ;;
    --type_string)
      TYPE_STRING="$2"
      shift 2
      ;;
    --archive_threshold)
      ARCHIVE_THRESHOLD="$2"
      shift 2
      ;;
    --stats_frequency)
      STATS_FREQUENCY="$2"
      shift 2
      ;;
    --init_multiplier)
      INIT_MULTIPLIER="$2"
      shift 2
      ;;
    --force_init)
      FORCE_INIT=true
      shift
      ;;
    --min_dag_count)
      MIN_DAG_COUNT="$2"
      shift 2
      ;;
    *)
      echo "Unknown argument: $1"
      echo "Use --help for usage information"
      shift
      ;;
  esac
done

if [[ -z "$MAX_TASKS" ]]; then
  MAX_TASKS=$((WORKER_NUM * BATCH_SIZE * ITERATIONS))
fi

# Resolve op root (override with ANUM_OP_ROOT if set)
OP_ROOT="${ANUM_OP_ROOT:-$SCRIPT_DIR/op}"

# Output startup information
log "Starting Master node..."
log "Task tag: $TASK_TAG"
log "Batch size: $BATCH_SIZE"
log "Worker count: $WORKER_NUM"
log "Iterations: $ITERATIONS"
log "Max tasks: $MAX_TASKS"
log "Archive threshold: $ARCHIVE_THRESHOLD"
log "Stats frequency: every $STATS_FREQUENCY tasks"
log "Init DAG multiplier: $INIT_MULTIPLIER (init count = $WORKER_NUM x $BATCH_SIZE x $INIT_MULTIPLIER = $((WORKER_NUM * BATCH_SIZE * INIT_MULTIPLIER)))"
log "Force re-init: $FORCE_INIT"
log "Min DAG threshold: $MIN_DAG_COUNT"
log "OP root: $OP_ROOT"

# Create required directories
log "Creating directories..."
BASE_OP_DIR="$OP_ROOT/$TASK_TAG"
DAG_DIR="$BASE_OP_DIR/dag"
TASK_DIR="$BASE_OP_DIR/task"

mkdir -p "$DAG_DIR/pool"
mkdir -p "$DAG_DIR/result"
mkdir -p "$DAG_DIR/archive"
mkdir -p "$TASK_DIR/current"
mkdir -p "$BASE_OP_DIR/bestof"

# Check master_node.py exists
if [ ! -f "master/master_node.py" ]; then
  log "Error: master/master_node.py not found"
  exit 1
fi

# Run master_node.py
log "Starting Master node process..."

PYTHON_ARGS=(
  --task_tag "$TASK_TAG"
  --batch_size "$BATCH_SIZE"
  --worker_num "$WORKER_NUM"
  --max_tasks "$MAX_TASKS"
  --check_interval "$CHECK_INTERVAL"
  --poly "$POLY"
  --type_string "$TYPE_STRING"
  --archive_threshold "$ARCHIVE_THRESHOLD"
  --stats_frequency "$STATS_FREQUENCY"
  --init_multiplier "$INIT_MULTIPLIER"
  --min_dag_count "$MIN_DAG_COUNT"
)

if [ "$FORCE_INIT" = true ]; then
  PYTHON_ARGS+=(--force_init)
fi

python3 master/master_node.py "${PYTHON_ARGS[@]}"

log "Master node exited"
