#!/bin/bash
# Runs a comprehensive experimental suite by iterating through multiple
# configurations for different caching and compression strategies.

set -e

# Get the directory of this script to reliably call the main experiment script.
SCRIPT_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" &> /dev/null && pwd )"

# --- Experiment Matrix Definition ---
declare -a types=("ksvd_merge_batched" "kvcache" "nocache")
declare -a types=("kvcache" "ksvd_merge_batched")
declare -a topk_values=("1" "2" "4" "8" "16" "32" "64" "128" "256")

declare -a sparsities=("32" "48" "64")

declare -a merge_layers_options=("1" "2" "4")
BASE_DICT_PATH="/your_dict_path"

echo "Starting comprehensive experiment suite..."

# Loop over each experiment type
for type in "${types[@]}"; do
    echo ""
    echo "================================================="
    echo "Processing Experiment Type: ${type}"
    echo "================================================="

    case "$type" in
        "ksvd_merge_batched")
            for merge_layers in "${merge_layers_options[@]}"; do
                for sparsity in "${sparsities[@]}"; do
                    # Construct dictionary path and name
                    dict_filename="Qwen2.5-7B-Instruct_1M_wiki30M_concat${merge_layers}_N_8192_s_${sparsity}.pt"
                    dict_path="${BASE_DICT_PATH}/${dict_filename}"
                    dict_name="concat${merge_layers}_s${sparsity}"
                    
                    # Dynamically construct the index directory name to match the merge layers
                    index_dir="doc_emb_ksvd_Qwen2.5-7B-Instruct_7B_inst_reorder_new_drop_merged_${merge_layers}layers_s_${sparsity}"

                    for topk in "${topk_values[@]}"; do
                        echo "--- Running merge_ksvd | merge:${merge_layers} | sparsity:${sparsity} | topk:${topk} ---"
                        bash "$SCRIPT_DIR/run_experiment.sh" "configs/config_${type}.yaml" \
                            --INDEX_PERSIST_DIR "${index_dir}" \
                            --SIMILARITY_TOP_K "${topk}" \
                            --SPARSITY "${sparsity}" \
                            --MERGE_LAYERS "${merge_layers}" \
                            --DICT_FILE_PATH "${dict_path}" \
                            --DICT_NAME "${dict_name}" \
                            --DICT_TYPE "all_${merge_layers}layers_8kd_dl"
                    done
                done
            done
            ;;

        "batched_ksvd" | "ksvd")
            # Test standard/batched k-SVD with all available dictionaries
            for sparsity in "${sparsities[@]}"; do
                # Dynamically construct dictionary path and name
                dict_filename="Qwen2.5-7B-Instruct_1M_wiki30M_concat1_N_8192_s_${sparsity}.pt"
                dict_path="${BASE_DICT_PATH}/${dict_filename}"
                dict_name="dict_concat${merge_layers}_s${sparsity}"
                for topk in "${topk_values[@]}"; do
                    echo "--- Running ${type} | dict: concat${merge_layers}_s${sparsity} | topk:${topk} ---"
                    bash "$SCRIPT_DIR/run_experiment.sh" "configs/config_${type}.yaml" \
                        --CACHE_TYPE "${type}" \
                        --SIMILARITY_TOP_K "${topk}" \
                        --SPARSITY "${sparsity}" \
                        --DICT_FILE_PATH "${dict_path}" \
                        --DICT_NAME "${dict_name}" \
                        --DICT_TYPE "all_1layers_8kd_dl"
                done
            done
            ;;

        "kvcache" | "nocache")
            for topk in "${topk_values[@]}"; do
                echo "--- Running ${type} | topk:${topk} ---"
                bash "$SCRIPT_DIR/run_experiment.sh" "configs/config_${type}.yaml" \
                    --SIMILARITY_TOP_K "${topk}" 
            done
            ;;
    esac
done

echo ""
echo "================================================="
echo "All experiments completed."
echo "=================================================" 