#!/bin/bash
export CUDA_VISIBLE_DEVICES=${1:-0}
mode="${2:-forecast}"  # ['forecast', 'perturb', 'both']
exp_name="${3:-cycle}"

cycle=144
model_name="RESAM"
model_types=("mlp")

perturb_name="${4:-pertrub_test}"
perturb_path="./results_perturb"
perturb_types=("last" "random")
perturb_ratios=(3 1)


if [ "$mode" == "forecast" ] || [ "$mode" == "both" ]; then
    echo "[INFO] Running training and forecasting..."
    for model_type in "${model_types[@]}"; do
        # seq_len=96
        python ./scripts/run_benchmark.py --config-path "rolling_forecast_config.json" --data-name-list "Solar.csv" --strategy-args "{\"horizon\": 96}" --model-name "time_series_library.$model_name" --model-hyper-params "{\"batch_size\": 16, \"d_model\": 512, \"lr\": 0.001, \"norm\": true, \"horizon\": 96, \"seq_len\": 96}" --adapter "transformer_adapter" --gpus 0 --num-workers 1 --timeout 60000 --save-path "Solar/$model_name-$model_type" --cycle $cycle --exp_name $exp_name"_sample_0.75_2stage" --sample_ratio 0.75 --stage 2 --model_type $model_type

        python ./scripts/run_benchmark.py --config-path "rolling_forecast_config.json" --data-name-list "Solar.csv" --strategy-args "{\"horizon\": 192}" --model-name "time_series_library.$model_name" --model-hyper-params "{\"batch_size\": 16, \"d_model\": 512, \"lr\": 0.001, \"norm\": true, \"horizon\": 192, \"seq_len\": 96}" --adapter "transformer_adapter" --gpus 0 --num-workers 1 --timeout 60000 --save-path "Solar/$model_name-$model_type" --cycle $cycle --exp_name $exp_name"_sample_0.75_2stage" --sample_ratio 0.75 --stage 2 --model_type $model_type

        python ./scripts/run_benchmark.py --config-path "rolling_forecast_config.json" --data-name-list "Solar.csv" --strategy-args "{\"horizon\": 336}" --model-name "time_series_library.$model_name" --model-hyper-params "{\"batch_size\": 16, \"d_model\": 128, \"lr\": 0.001, \"norm\": true, \"horizon\": 336, \"seq_len\": 96}" --adapter "transformer_adapter" --gpus 0 --num-workers 1 --timeout 60000 --save-path "Solar/$model_name-$model_type" --cycle $cycle --exp_name $exp_name"_sample_0.75_2stage" --sample_ratio 0.75 --stage 2 --model_type $model_type

        python ./scripts/run_benchmark.py --config-path "rolling_forecast_config.json" --data-name-list "Solar.csv" --strategy-args "{\"horizon\": 720}" --model-name "time_series_library.$model_name" --model-hyper-params "{\"batch_size\": 32, \"d_model\": 512, \"lr\": 0.001, \"norm\": true, \"horizon\": 720, \"seq_len\": 96}" --adapter "transformer_adapter" --gpus 0 --num-workers 1 --timeout 60000 --save-path "Solar/$model_name-$model_type" --cycle $cycle --exp_name $exp_name"_sample_0.75_2stage" --sample_ratio 0.75 --stage 2 --model_type $model_type

    done
fi


if [ "$mode" == "perturb" ] || [ "$mode" == "both" ]; then
    echo "[INFO] Running perturbation experiment..."

    for perturb_type in "${perturb_types[@]}"; do
        for perturb_ratio in "${perturb_ratios[@]}"; do
            for model_type in "${model_types[@]}"; do
                # seq_len=96
                python ./scripts/run_perturb.py --config-path "rolling_forecast_config.json" --data-name-list "Solar.csv" --strategy-args "{\"horizon\": 96}" --model-name "time_series_library.$model_name" --model-hyper-params "{\"batch_size\": 16, \"d_model\": 512, \"lr\": 0.001, \"norm\": true, \"horizon\": 96, \"seq_len\": 96}" --adapter "transformer_adapter" --gpus 0 --num-workers 1 --timeout 60000 --save-path ${perturb_path}  --cycle $cycle --exp_name $exp_name"_sample_0.75_2stage" --sample_ratio 0.75 --stage 2 --model_type $model_type --perturb_name $perturb_name --perturb_type $perturb_type --perturb_ratio $perturb_ratio

                python ./scripts/run_perturb.py --config-path "rolling_forecast_config.json" --data-name-list "Solar.csv" --strategy-args "{\"horizon\": 192}" --model-name "time_series_library.$model_name" --model-hyper-params "{\"batch_size\": 16, \"d_model\": 512, \"lr\": 0.001, \"norm\": true, \"horizon\": 192, \"seq_len\": 96}" --adapter "transformer_adapter" --gpus 0 --num-workers 1 --timeout 60000 --save-path ${perturb_path}  --cycle $cycle --exp_name $exp_name"_sample_0.75_2stage" --sample_ratio 0.75 --stage 2 --model_type $model_type --perturb_name $perturb_name --perturb_type $perturb_type --perturb_ratio $perturb_ratio

                python ./scripts/run_perturb.py --config-path "rolling_forecast_config.json" --data-name-list "Solar.csv" --strategy-args "{\"horizon\": 336}" --model-name "time_series_library.$model_name" --model-hyper-params "{\"batch_size\": 16, \"d_model\": 128, \"lr\": 0.001, \"norm\": true, \"horizon\": 336, \"seq_len\": 96}" --adapter "transformer_adapter" --gpus 0 --num-workers 1 --timeout 60000 --save-path ${perturb_path}  --cycle $cycle --exp_name $exp_name"_sample_0.75_2stage" --sample_ratio 0.75 --stage 2 --model_type $model_type --perturb_name $perturb_name --perturb_type $perturb_type --perturb_ratio $perturb_ratio

                python ./scripts/run_perturb.py --config-path "rolling_forecast_config.json" --data-name-list "Solar.csv" --strategy-args "{\"horizon\": 720}" --model-name "time_series_library.$model_name" --model-hyper-params "{\"batch_size\": 32, \"d_model\": 512, \"lr\": 0.001, \"norm\": true, \"horizon\": 720, \"seq_len\": 96}" --adapter "transformer_adapter" --gpus 0 --num-workers 1 --timeout 60000 --save-path ${perturb_path}  --cycle $cycle --exp_name $exp_name"_sample_0.75_2stage" --sample_ratio 0.75 --stage 2 --model_type $model_type --perturb_name $perturb_name --perturb_type $perturb_type --perturb_ratio $perturb_ratio

            done
        done
    done
fi