#!/usr/bin/env bash

set -e

# Define seed values
seed_values=(127 )

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

  # =========================
  # REPLAY EXPERIMENTS
  # =========================
  # cco-eval-continual \
  #   --variant_name "zeroshot-replay-${el}-5" \
  #   --lora_adapters  apibench-zero-shot-replay-${el}-5/checkpoint-310 mllm-zero-shot-replay-${el}-5/checkpoint-195 hugging-bench-1-zero-shot-replay-${el}-5/checkpoint-260 hugging-bench-2-zero-shot-replay-${el}-5/checkpoint-270 \
  #   --eval_batch_size 38

  # cco-eval-continual \
  #   --variant_name "zeroshot-replay-${el}-10" \
  #   --lora_adapters  apibench-zero-shot-replay-${el}-10/checkpoint-310 mllm-zero-shot-replay-${el}-10/checkpoint-210 hugging-bench-1-zero-shot-replay-${el}-10/checkpoint-280 hugging-bench-2-zero-shot-replay-${el}-10/checkpoint-305 \
  #   --eval_batch_size 38

  # cco-eval-continual \
  #   --variant_name "zeroshot-replay-${el}-20" \
  #   --lora_adapters  apibench-zero-shot-replay-${el}-20/checkpoint-310 mllm-zero-shot-replay-${el}-20/checkpoint-245 hugging-bench-1-zero-shot-replay-${el}-20/checkpoint-330 hugging-bench-2-zero-shot-replay-${el}-20/checkpoint-375 \
  #   --eval_batch_size 38

  # cco-eval-continual \
  #   --variant_name "cumulative-${el}" \
  #   --lora_adapters  apibench-cumulative-${el}/checkpoint-310 mllm-cumulative-${el}/checkpoint-485 hugging-bench-1-cumulative-${el}/checkpoint-835 hugging-bench-2-cumulative-${el}/checkpoint-1195 \
  #   --eval_batch_size 38

  # =========================
  # SEQUENTIAL FINETUNING
  # =========================
  # cco-eval-continual \
  #   --variant_name "sequential-finetuning-${el}" \
  #   --lora_adapters apibench-sequential-finetuning-${el}/checkpoint-310 mllm-sequential-finetuning-${el}/checkpoint-180 hugging-bench-1-sequential-finetuning-${el}/checkpoint-235 hugging-bench-2-sequential-finetuning-${el}/checkpoint-235 \
  #   --eval_batch_size 38

  # =========================
  # MERGING
  # =========================
  # cco-eval-continual \
  #   --variant_name "merging-${el}" \
  #   --lora_adapters apibench-merging-${el}/checkpoint-310 mllm-merging-${el}/checkpoint-180 hugging-bench-1-merging-${el}/checkpoint-235 hugging-bench-2-merging-${el}/checkpoint-235 \
  #   --eval_batch_size 38 \
  #   --lora_merging_strategy dare_linear \
  #   --weights 1.0 1.0 1.0 1.0 \
  #   --density 0.8  

  # =========================
  # JOINT TRAINING
  # =========================
  # cco-eval-continual \
  #   --variant_name "joint-training-${el}" \
  #   --lora_adapters hugging-bench-2-joint-training-${el}/checkpoint-805 hugging-bench-2-joint-training-${el}/checkpoint-805 hugging-bench-2-joint-training-${el}/checkpoint-805 hugging-bench-2-joint-training-${el}/checkpoint-805 \
  #   --eval_batch_size 38
  
  cco-eval-continual \
    --variant_name "from-scratch-${el}" \
    --lora_adapters apibench-e1_from_scratch-${el}/checkpoint-260 mllm-e1_e2_from_scratch-${el}/checkpoint-415 hugging-bench-1-e1_e2_e3_from_scratch-${el}/checkpoint-710 hugging-bench-2-e1_e2_e3_e4_from_scratch-${el}/checkpoint-1015 \
    --eval_batch_size 38

  # cco-eval-continual \
  #   --variant_name "joint-training-rat-${el}" \
  #   --lora_adapters hugging-bench-2-joint-training-rat-${el}-flagembedding/checkpoint-1610 hugging-bench-2-joint-training-rat-${el}-flagembedding/checkpoint-1610 hugging-bench-2-joint-training-rat-${el}-flagembedding/checkpoint-1610 hugging-bench-2-joint-training-rat-${el}-flagembedding/checkpoint-1610 \
  #   --eval_batch_size 8 \
  #   --retrievers flagembedding \
  #   --model_indices e1 e1_e2 e1_e2_e3 e1_e2_e3_e4

  # =========================
  # RAT FROZEN
  # =========================
  # cco-eval-continual \
  #   --variant_name "rat-frozen${el}" \
  #   --lora_adapters hugging-bench-2-joint-training-rat-${el}-flagembedding/checkpoint-1610 hugging-bench-2-joint-training-rat-${el}-flagembedding/checkpoint-1610 hugging-bench-2-joint-training-rat-${el}-flagembedding/checkpoint-1610 hugging-bench-2-joint-training-rat-${el}-flagembedding/checkpoint-1610 \
  #   --eval_batch_size 8 \
  #   --retrievers flagembedding \
  #   --model_indices e1 e1_e2 e1_e2_e3 e1_e2_e3_e4

  # =========================
  # RETRIEVERS ONLY
  # =========================
  # cco-eval-continual \
  #   --variant_name "retrievers-only" \
  #   --eval_batch_size 8 \
  #   --retrievers flagembedding \
  #   --model_indices e1 e1_e2 e1_e2_e3 e1_e2_e3_e4

done
