#!/bin/bash
# Evolutionary Algorithm for Model Selection Experiments
# Search space: MLP, ResNet with evolutionary algorithm

export PYTHONPATH="${PYTHONPATH}:$(pwd)"

SCRIPT="./scripts/ptnas.py"

# Configuration
TIMESTAMP=$(date +"%Y%m%d_%H%M%S")

# Base data directory
BASE_DATA_DIR="/home/user/embedding_fusion/data/fit-medium-table"

# Output directory
OUTPUT_DIR="./logs/"
LOG_FILE="${OUTPUT_DIR}/log_ptnas.txt"
CSV_FILE="${OUTPUT_DIR}/ptnas_results.csv"

# Create output directory
mkdir -p "${OUTPUT_DIR}"

# Redirect all output to log file AND console
exec > >(tee -a "${LOG_FILE}") 2>&1

echo "=========================================="
echo "pTNAS: Evolutionary Algorithm for Model Selection"
echo "=========================================="
echo "Script: ${SCRIPT}"
echo "Output: ${OUTPUT_DIR}"
echo "Log: ${LOG_FILE}"
echo "CSV: ${CSV_FILE}"
echo "Started: $(date)"
echo ""
echo "📊 Experiment Configuration:"
echo "   Datasets: ${#DATASETS[@]}"
echo "   Models: 2 (MLP, ResNet)"
echo "   Total experiments: $((${#DATASETS[@]} * 2))"
echo ""

START_TIME=$(date +%s)

DATASETS=(
  event-user-repeat          # event user-repeat ✅
  ratebeer-user-active       # ratebeer user-active ✅
  ratebeer-beer-positive     # ratebeer beer-positive ✅
  trial-study-outcome        # trial study-outcome ✅
  trial-site-success         # trial site-success ✅
  avito-user-clicks          # avito user-clicks ✅
  event-user-attendance      # event user-attendance ✅
  hm-item-sales              # hm item-sales ✅
)

#==============================================================================
# [1/2] MLP Search Space
#==============================================================================

echo "=========================================="
echo "[1/2] MLP Search Space"
echo "=========================================="

for DATASET in "${DATASETS[@]}"; do
    echo ""
    echo "Processing: MLP on ${DATASET}"
    python3 -u ${SCRIPT} \
        --data_dir "${BASE_DATA_DIR}/${DATASET}" \
        --space_name "mlp" \
        --output_csv "${CSV_FILE}" \
        --device "cuda:0" \
        --seed 42

    if [ $? -eq 0 ]; then
        echo "✅ MLP on ${DATASET} completed"
    else
        echo "❌ MLP on ${DATASET} failed"
    fi
done

echo ""
echo "MLP Search Space Completed!"
echo ""

#==============================================================================
# [2/2] ResNet Search Space
#==============================================================================

echo "=========================================="
echo "[2/2] ResNet Search Space"
echo "=========================================="

for DATASET in "${DATASETS[@]}"; do
    echo ""
    echo "Processing: ResNet on ${DATASET}"
    python3 -u ${SCRIPT} \
        --data_dir "${BASE_DATA_DIR}/${DATASET}" \
        --space_name "resnet" \
        --output_csv "${CSV_FILE}" \
        --device "cuda:0" \
        --seed 42

    if [ $? -eq 0 ]; then
        echo "✅ ResNet on ${DATASET} completed"
    else
        echo "❌ ResNet on ${DATASET} failed"
    fi
done

echo ""
echo "ResNet Search Space Completed!"
echo ""

#==============================================================================
# Summary
#==============================================================================

END_TIME=$(date +%s)
ELAPSED=$((END_TIME - START_TIME))

echo ""
echo "=========================================="
echo "✅ pTNAS Experiments Completed!"
echo "=========================================="
echo "Total time: $((ELAPSED / 3600))h $(((ELAPSED % 3600) / 60))m $((ELAPSED % 60))s"
echo "Results: ${OUTPUT_DIR}"
echo "CSV: ${CSV_FILE}"
echo "Completed: $(date)"
echo "=========================================="


