#!/bin/bash
SEED=42
DATA_ROOT="./data/UEA_multivariate"
# Define Datasets and their respective Channel Counts (enc_in)
# Format: "Dataset_Name:Channel_Count"
DATASETS=(
#    "UWaveGestureLibrary:3"
#    "ERing:4"
#    "RacketSports:6"
  #  "SpokenArabicDigits:13"
#    "NATOPS:24"
  #  "Heartbeat:61"
  #  "PenDigits:2"
  #  "CharacterTrajectories:3"
   "SelfRegulationSCP1:6"
#    "ArticularyWordRecognition:9"
#    "Libras:2"
  #  "BasicMotions:6"
#    "PEMS-SF:263"
  #  "Cricket:6"
  #  "Epilepsy:3"
)
# Heartbeat:61: lambda_fid 0.1

MODEL="DNN"
DNN_TYPE="PatchTST"

for item in "${DATASETS[@]}"; do
    IFS=":" read -r DS ENC <<< "$item"
    
    echo "===================================================="
    echo "STARTING FINETUNE: $DS (Channels: $ENC)"
    echo "===================================================="
    
    CUDA_VISIBLE_DEVICES=0 python train_explainer_v2.py \
        --dataset "$DS" \
        --enc_in "$ENC" \
        --model "$MODEL" \
        --dnn_type "$DNN_TYPE" \
        --train_epochs 500 \
        --batch_size 16 \
        --lr 1e-2 \
        --lambda_fid 1.0 \
        --lambda_rob 1.0
        
    echo "FINISHED: $DS"

    echo "--------------------------------------------------------"
    echo "Evaluation: $DS"
    echo "--------------------------------------------------------"
    
    # Run the evaluation script without enc/dec/c_out arguments
    python evaluate_amortized_v2.py \
      --dataset "$DS" \
      --model "$MODEL" \
      --dnn_type "$DNN_TYPE" \
      --batch_size 1 \
      --seed "$SEED" \
      --data_root "$DATA_ROOT" \
      --task_name "explanation"
    
    # echo "Completed evaluation for $DATASET."
    # echo ""
    # sleep 2
done
