#!/bin/bash

current_time=$(date "+%Y-%m-%d_%H-%M-%S")
model_name="Qwen/Qwen2.5-3B-Instruct"

params=(
  'discoverybench/real/test/archaeology/metadata_10.json,0',
  'discoverybench/real/test/archaeology/metadata_12.json,0',
  'discoverybench/real/test/archaeology/metadata_13.json,0',
  'discoverybench/real/test/archaeology/metadata_19.json,0',
  'discoverybench/real/test/archaeology/metadata_20.json,0',
  'discoverybench/real/test/archaeology/metadata_21.json,0',
  'discoverybench/real/test/archaeology/metadata_22.json,0',
  'discoverybench/real/test/archaeology/metadata_24.json,0',
  'discoverybench/real/test/archaeology/metadata_25.json,0',
  'discoverybench/real/test/archaeology/metadata_26.json,0',
  'discoverybench/real/test/archaeology/metadata_28.json,0',
  'discoverybench/real/test/archaeology/metadata_3.json,0',
  'discoverybench/real/test/archaeology/metadata_30.json,0',
  'discoverybench/real/test/archaeology/metadata_34.json,0',
  'discoverybench/real/test/archaeology/metadata_4.json,0',
  'discoverybench/real/test/archaeology/metadata_6.json,0',
  'discoverybench/real/test/introduction_pathways_non-native_plants/metadata_0.json,2',
  'discoverybench/real/test/introduction_pathways_non-native_plants/metadata_1.json,0',
  'discoverybench/real/test/introduction_pathways_non-native_plants/metadata_1.json,1',
  'discoverybench/real/test/introduction_pathways_non-native_plants/metadata_2.json,1',
  'discoverybench/real/test/introduction_pathways_non-native_plants/metadata_3.json,0',
  'discoverybench/real/test/introduction_pathways_non-native_plants/metadata_4.json,1',
  'discoverybench/real/test/introduction_pathways_non-native_plants/metadata_4.json,2',
  'discoverybench/real/test/meta_regression/metadata_0.json,0',
  'discoverybench/real/test/meta_regression/metadata_0.json,3',
  'discoverybench/real/test/meta_regression/metadata_1.json,1',
  'discoverybench/real/test/meta_regression/metadata_10.json,0',
  'discoverybench/real/test/meta_regression/metadata_12.json,1',
  'discoverybench/real/test/meta_regression/metadata_13.json,1',
  'discoverybench/real/test/meta_regression/metadata_13.json,2',
  'discoverybench/real/test/meta_regression/metadata_13.json,3',
  'discoverybench/real/test/meta_regression/metadata_15.json,2',
  'discoverybench/real/test/meta_regression/metadata_17.json,1',
  'discoverybench/real/test/meta_regression/metadata_17.json,2',
  'discoverybench/real/test/meta_regression/metadata_19.json,1',
  'discoverybench/real/test/meta_regression/metadata_19.json,4',
  'discoverybench/real/test/meta_regression/metadata_3.json,0',
  'discoverybench/real/test/meta_regression/metadata_3.json,2',
  'discoverybench/real/test/meta_regression/metadata_5.json,0',
  'discoverybench/real/test/meta_regression/metadata_5.json,1',
  'discoverybench/real/test/meta_regression/metadata_6.json,0',
  'discoverybench/real/test/meta_regression/metadata_6.json,1',
  'discoverybench/real/test/meta_regression/metadata_7.json,0',
  'discoverybench/real/test/meta_regression_raw/metadata_0.json,0',
  'discoverybench/real/test/meta_regression_raw/metadata_0.json,2',
  'discoverybench/real/test/meta_regression_raw/metadata_0.json,3',
  'discoverybench/real/test/meta_regression_raw/metadata_1.json,0',
  'discoverybench/real/test/meta_regression_raw/metadata_1.json,1',
  'discoverybench/real/test/meta_regression_raw/metadata_10.json,0',
  'discoverybench/real/test/meta_regression_raw/metadata_10.json,1',
  'discoverybench/real/test/meta_regression_raw/metadata_11.json,0',
  'discoverybench/real/test/meta_regression_raw/metadata_12.json,1',
  'discoverybench/real/test/meta_regression_raw/metadata_14.json,0',
  'discoverybench/real/test/meta_regression_raw/metadata_15.json,0',
  'discoverybench/real/test/meta_regression_raw/metadata_18.json,2',
  'discoverybench/real/test/meta_regression_raw/metadata_19.json,1',
  'discoverybench/real/test/meta_regression_raw/metadata_19.json,3',
  'discoverybench/real/test/meta_regression_raw/metadata_2.json,1',
  'discoverybench/real/test/meta_regression_raw/metadata_3.json,0',
  'discoverybench/real/test/meta_regression_raw/metadata_5.json,1',
  'discoverybench/real/test/meta_regression_raw/metadata_6.json,1',
  'discoverybench/real/test/meta_regression_raw/metadata_6.json,2',
  'discoverybench/real/test/meta_regression_raw/metadata_9.json,0',
  'discoverybench/real/test/nls_incarceration/metadata_0.json,0',
  'discoverybench/real/test/nls_incarceration/metadata_11.json,0',
  'discoverybench/real/test/nls_incarceration/metadata_14.json,0',
  'discoverybench/real/test/nls_incarceration/metadata_14.json,1',
  'discoverybench/real/test/nls_incarceration/metadata_14.json,2',
  'discoverybench/real/test/nls_incarceration/metadata_15.json,0',
  'discoverybench/real/test/nls_incarceration/metadata_2.json,0',
  'discoverybench/real/test/nls_incarceration/metadata_3.json,3',
  'discoverybench/real/test/nls_incarceration/metadata_3.json,4',
  'discoverybench/real/test/nls_incarceration/metadata_5.json,0',
  'discoverybench/real/test/nls_incarceration/metadata_6.json,0',
  'discoverybench/real/test/nls_incarceration/metadata_9.json,0',
  'discoverybench/real/test/nls_raw/metadata_4.json,0',
  'discoverybench/real/test/nls_raw/metadata_5.json,0',
  'discoverybench/real/test/nls_raw/metadata_7.json,0',
  'discoverybench/real/test/nls_ses/metadata_0.json,0',
  'discoverybench/real/test/nls_ses/metadata_0.json,1',
  'discoverybench/real/test/nls_ses/metadata_10.json,2',
  'discoverybench/real/test/nls_ses/metadata_10.json,3',
  'discoverybench/real/test/nls_ses/metadata_3.json,0',
  'discoverybench/real/test/nls_ses/metadata_4.json,0',
  'discoverybench/real/test/nls_ses/metadata_4.json,1',
  'discoverybench/real/test/nls_ses/metadata_5.json,1',
  'discoverybench/real/test/nls_ses/metadata_7.json,1',
  'discoverybench/real/test/nls_ses/metadata_8.json,1',
  'discoverybench/real/test/requirements_engineering_for_ML_enabled_systems/metadata_0.json,0',
  'discoverybench/real/test/requirements_engineering_for_ML_enabled_systems/metadata_1.json,0',
  'discoverybench/real/test/requirements_engineering_for_ML_enabled_systems/metadata_11.json,0',
  'discoverybench/real/test/requirements_engineering_for_ML_enabled_systems/metadata_13.json,0',
  'discoverybench/real/test/requirements_engineering_for_ML_enabled_systems/metadata_14.json,0',
  'discoverybench/real/test/requirements_engineering_for_ML_enabled_systems/metadata_2.json,0',
  'discoverybench/real/test/worldbank_education_gdp/metadata_0.json,0',
  'discoverybench/real/test/worldbank_education_gdp/metadata_1.json,0',
  'discoverybench/real/test/worldbank_education_gdp/metadata_2.json,0',
  'discoverybench/real/test/worldbank_education_gdp_indicators/metadata_0.json,0',
  'discoverybench/real/test/worldbank_education_gdp_indicators/metadata_3.json,0',
  'discoverybench/real/test/worldbank_education_gdp_indicators/metadata_4.json,0'
)

for param in "${params[@]}"; do
  IFS="," read -r filepath qid <<<"$param"
  # MiGrATe
  accelerate launch train.py --task "discoverybench" --date "$current_time" --model "$model_name" --trl_seed 2 --strategy "migrate" --num_train_epochs 1 --wandb_prefix "discoverybench_grpo_vanilla" --wandb_tags "grpo,discoverybench_vanilla" --min_training_size 40 --max_training_size 40 --inf_batch_size 10 --num_guesses 5 --batch_size 5 --num_generations 5 --online_max_completion_length 1024 --inf_num_samples 0 --learning_rate 5e-5 --lora_alpha 16 --lora_rank 64 --num_iterations 2 --greedy_topk 1 --migrate_gamma 0 --migrate_alpha 5 --migrate_beta 0 --target "$filepath" --discoverybench_metadata_type "real" --discoverybench_qid "$qid" --migrate_sampling_strategy "random_topk" --greedy_topk 1 --migrate_gamma 2 --migrate_alpha 2 --migrate_beta 1

done
