#!/usr/bin/env bash

# Define seed values
seed_values=(8887 )

for el in "${seed_values[@]}"; do
  echo "Running experiments with seed=${el}"

  # =========================
  # REPLAY EXPERIMENTS
  # =========================
  # cco-train \
  #   --seed "${el}" \
  #   --variant_name "zero-shot-replay-${el}-5" \
  #   --mode replay \
  #   --replay_percentage 0.05

  # cco-train \
  #   --seed "${el}" \
  #   --variant_name "zero-shot-replay-${el}-10" \
  #   --mode replay \
  #   --replay_percentage 0.1

  # cco-train \
  #   --seed "${el}" \
  #   --variant_name "zero-shot-replay-${el}-20" \
  #   --mode replay \
  #   --replay_percentage 0.2
  
  cco-train \
    --seed "${el}" \
    --variant_name "cumulative-${el}" \
    --mode replay \
    --replay_percentage 1.0 \
    --max_length 256 \
    --batch_size 64 \
    --grad_accum 2


  # # =========================
  # # SEQUENTIAL FINETUNING
  # # =========================
  # cco-train \
  #   --seed "${el}" \
  #   --variant_name "sequential-finetuning-${el}" \
  #   --mode sequential-finetuning

  # # =========================
  # # MERGING
  # # =========================
  # cco-train \
  #   --seed "${el}" \
  #   --variant_name "merging-${el}" \
  #   --mode merging

  # =========================
  # JOINT TRAINING
  # =========================
  # cco-train \
  #   --seed "${el}" \
  #   --variant_name "joint-training-${el}" \
  #   --mode joint-training

  # cco-train \
  #   --seed "${el}" \
  #   --variant_name "e1_from_scratch-${el}" \
  #   --experience_names apibench \
  #   --mode joint-training \
  #   --max_length 256 \
  #   --batch_size 64 \
  #   --grad_accum 2

  # cco-train \
  #   --seed "${el}" \
  #   --variant_name "e1_e2_from_scratch-${el}" \
  #   --experience_names apibench mllm \
  #   --mode joint-training \
  #   --max_length 256 \
  #   --batch_size 64 \
  #   --grad_accum 2


  # cco-train \
  #   --seed "${el}" \
  #   --variant_name "e1_e2_e3_from_scratch-${el}" \
  #   --experience_names apibench mllm hugging-bench-1 \
  #   --mode joint-training \
  #   --max_length 256 \
  #   --batch_size 64 \
  #   --grad_accum 2
  
  # cco-train \
  #   --seed "${el}" \
  #   --variant_name "e1_e2_e3_e4_from_scratch-${el}" \
  #   --experience_names apibench mllm hugging-bench-1 hugging-bench-2 \
  #   --mode joint-training \
  #   --max_length 256 \
  #   --batch_size 64 \
  #   --grad_accum 2

  # cco-train \
  #   --seed "${el}" \
  #   --variant_name "joint-training-rat-${el}" \
  #   --mode joint-training \
  #   --retriever flagembedding \
  #   --model_indices e1 e1_2 e1_e2_e3 e1_e2_e3_e4 \
  #   --max_length 1200 \
  #   --batch_size 32

  # # =========================
  # # RAT
  # # =========================
  # cco-train \
  #   --seed "${el}" \
  #   --variant_name "rat-${el}" \
  #   --mode replay \
  #   --retriever flagembedding \
  #   --model_indices e1 e1_e2 e1_e2_e3 e1_e2_e3_e4 \
  #   --max_length 1200 \
  #   --batch_size 32

done
