#!/bin/bash

export WANDB_PROJECT=mem_trex
source ./scripts/account/wandb_config.sh

OUTPUT_DIR="./output/eval/loss_trex"
DATABASE_PATH=./database/trex++2.8k_org_database.json
DATASETS=./data/trex++/trex++2.8k_substitution.json
ANNOTATION_PATH=""
THRESHOLD_lst=(0.6)

# Read checkpoint paths from the configuration file
CHECKPOINTS=()
while IFS= read -r line; do
    if [[ "$line" =~ ^#.*$ ]] || [[ -z "$line" ]]; then
        continue
    fi
    CHECKPOINTS+=("$line")
done < ./output/checkpoint.cfg

DBLOOKUP_OPTIONS=("" "--enable_dblookup")
SUBSTITUTION_OPTIONS=("" "--enable_substitution")

# Loop through all combinations
for ENABLE_DBLOOKUP in "${DBLOOKUP_OPTIONS[@]}"; do
    for ENABlE_SUBSTITION in "${SUBSTITUTION_OPTIONS[@]}"; do
        echo "Running with DBLOOKUP=$ENABLE_DBLOOKUP and SUBSTITUTION=$ENABlE_SUBSTITION"
        if [[ $ENABlE_SUBSTITION == "--enable_substitution" ]]; then
            DATABASE_PATH=./database/trex++2.8k_sub_database.json
        fi


        for THRESHOLD in "${THRESHOLD_lst[@]}"  
        do
        for MODEL_PATH in "${CHECKPOINTS[@]}"
        do
            python ./experiment/eval/eval_loss_trex.py \
                --model_name_or_path "${MODEL_PATH}" \
                --dataset_name "${DATASETS}" \
                --per_device_eval_batch_size 1 \
                --max_seq_length 1024 \
                --output_dir "${OUTPUT_DIR}/loss_trex++_v6" \
                --database_path "${DATABASE_PATH}" \
                --annotation_path "${ANNOTATION_PATH}" \
                --threshold "${THRESHOLD}" \
                ${ENABlE_SUBSTITION} \
                ${ENABLE_DBLOOKUP}
            done
        done
    done
done



