export CUDA_VISIBLE_DEVICES=0

model_name=TimeMixer

seq_len=96
e_layers=2
down_sampling_layers=3
down_sampling_window=2
learning_rate=0.01
d_model=16
d_ff=32
train_epochs=10
patience=10
batch_size=16

use_infogeo_loss=$1
infogeo_lambda=0.5
window_size=5

if [ ! -d "./logs/MSE/" ];then
    mkdir -p ./logs/MSE/
fi
if [ ! -d "./logs/InfoGeo/" ];then
    mkdir -p ./logs/InfoGeo/
fi

if [ "$use_infogeo_loss" = "1" ]; then
    log_dir="./logs/InfoGeo/"
    loss_type="InfoGeo"
else
    log_dir="./logs/MSE/"
    loss_type="MSE"
    infogeo_lambda=0.0
fi

for pred_len in 96 192 336 720
do
python -u run.py \
  --task_name long_term_forecast \
  --is_training 1 \
  --root_path ../datasets/ETT-small/ \
  --data_path ETTh1.csv \
  --model_id ETTh1_$seq_len'_'$pred_len \
  --model $model_name \
  --data ETTh1 \
  --features M \
  --seq_len $seq_len \
  --label_len 0 \
  --pred_len $pred_len \
  --e_layers $e_layers \
  --enc_in 7 \
  --c_out 7 \
  --des 'Exp' \
  --d_model $d_model \
  --d_ff $d_ff \
  --learning_rate $learning_rate \
  --train_epochs $train_epochs \
  --patience $patience \
  --batch_size $batch_size \
  --down_sampling_layers $down_sampling_layers \
  --down_sampling_method avg \
  --down_sampling_window $down_sampling_window \
  --use_ps_loss 0 \
  --ps_lambda 0.0 \
  --patch_len_threshold 24 \
  --use_infogeo_loss $use_infogeo_loss \
  --infogeo_lambda $infogeo_lambda \
  --window_size $window_size > ${log_dir}ETTh1_${seq_len}_${pred_len}_${loss_type}.log
done
