exp_name="${1:-test}"
is_training="${2:-0}"  # [1=training, 0=test]
cuda_device="${3:-0}"

export CUDA_VISIBLE_DEVICES=$cuda_device

model_name=Base
model_types=("timer" "moirai" "timesfm" "timemoe" "chronos" "visionts" "toto")

root_path_name=./dataset/
datasets=("ETTh1" "ETTh2" "ETTm1" "ETTm2" "weather" "Solar" "Wind" "ZafNoo" "Service")
datanames=("ETTh1" "ETTh2" "ETTm1" "ETTm2" "custom" "Solar" "custom" "custom" "custom")
cycles=(24 24 96 96 144 144 96 48 1440)
seq_lens=(720 720 2880 2880 4320 4320 2880 1440 4320)


batch_size=32


for i in ${!datasets[@]}
do
for model_type in ${model_types[@]}
do

  data_path_name=${datasets[$i]}.csv
  if [[ ${datasets[$i]} == "Solar" ]]; then
    data_path_name=solar_AL.txt
  fi

  model_id_name=${datasets[$i]}
  data_name=${datanames[$i]}
  cycle=${cycles[$i]}
  seq_len=${seq_lens[$i]}
  echo "Running for dataset: $data_name with cycle: $cycle and seq_len: $seq_len"

  for pred_len in 96 192 336 720 1440
  do
    for random_seed in 2025
    do
        echo "Processing dataset: $data_name, model_type: $model_type"
        python -u run.py \
          --is_training $is_training \
          --model_type $model_type \
          --root_path $root_path_name \
          --data_path $data_path_name \
          --model_id $model_id_name'_'$seq_len'_'$pred_len \
          --model $model_name \
          --data $data_name \
          --features M \
          --seq_len $seq_len \
          --pred_len $pred_len \
          --enc_in 7 \
          --dec_in 7 \
          --c_out 7 \
          --cycle $cycle \
          --model_type $model_type \
          --train_epochs 3 \
          --patience 5 \
          --exp_name $exp_name \
          --itr 1 --batch_size $batch_size --learning_rate 0.01 --random_seed $random_seed
    done
  done
done
done
