#!/bin/bash

# set -euo pipefail

./scripts/setup.sh

function run {
    for suffix_trained_xgboost_model_folder_path in "${trained_xgboost_model_folder_paths[@]}"; do
        trained_xgboost_model_folder_path="${xgboost_models_dir}/${suffix_trained_xgboost_model_folder_path}"
        for F in "${Fs[@]}"; do
            F_str=$(echo $F | sed 's/\.//g')
            for mu in "${mus[@]}"; do
                mu_str=$(echo $mu | sed 's/\.//g')
                for lambda in "${lambdas[@]}"; do
                    lambda_str=$(echo $lambda | sed 's/\.//g')
                    clbf_folder_path="${clbf_dir_root}/${suffix_trained_xgboost_model_folder_path}/F_${F_str}_mu_${mu_str}_lambda_${lambda_str}"
                    for pos_query_ratio in "${pos_query_ratios[@]}"; do
                        pos_query_ratio_str=$(echo $pos_query_ratio | sed 's/\.//g')
                        for query_num in "${query_nums[@]}"; do
                            result_folder_path="${result_dir_root}/${suffix_trained_xgboost_model_folder_path}/F_${F_str}_mu_${mu_str}_lambda_${lambda_str}/pr_${pos_query_ratio_str}_qn_${query_num}"
                            ./experiment/build/test_clbf \
                                -k "$X_test_key_path" \
                                -x "$X_test_path" \
                                -y "$y_test_path" \
                                -m "$clbf_folder_path" \
                                -o "$result_folder_path" \
                                -p $pos_query_ratio \
                                -q $query_num
                            exit_code=$?
                            if [ $exit_code -ne 0 ]; then
                                echo "Failed to test CLBF for directory: $clbf_folder_path"
                            fi
                        done
                    done
                done
            done
        done
    done
}

datasets=("url" "ember")
for dataset in "${datasets[@]}"; do
    xgboost_models_dir="models/${dataset}/xgboost"
    clbf_dir_root="models/${dataset}/clbf"
    result_dir_root="results/${dataset}/clbf"
    X_test_key_path="data/${dataset}/preprocessed/X_test_key.bin"
    X_test_path="data/${dataset}/preprocessed/X_test.bin"
    y_test_path="data/${dataset}/preprocessed/y_test.bin"
    trained_xgboost_model_folder_paths=("max_depth_4_num_boost_round_100_eta_03")

    # memory <-> fpr trade-off
    trained_xgboost_model_folder_paths=(
        "max_depth_1_num_boost_round_10_eta_03"
        "max_depth_1_num_boost_round_100_eta_03"
        "max_depth_2_num_boost_round_10_eta_03"
        "max_depth_2_num_boost_round_100_eta_03"
        "max_depth_4_num_boost_round_10_eta_03"
        "max_depth_4_num_boost_round_100_eta_03"
        "max_depth_6_num_boost_round_10_eta_03"
        "max_depth_6_num_boost_round_100_eta_03"
    )
    Fs=(0.1 0.05 0.02 0.01 0.005 0.002 0.001)
    lambdas=(1.0)
    mus=(0.0)
    pos_query_ratios=(0.0)
    query_nums=(40000)
    run

    # memory <-> reject time trade-off
    trained_xgboost_model_folder_paths=(
        "max_depth_1_num_boost_round_10_eta_03"
        "max_depth_1_num_boost_round_100_eta_03"
        "max_depth_2_num_boost_round_10_eta_03"
        "max_depth_2_num_boost_round_100_eta_03"
        "max_depth_4_num_boost_round_10_eta_03"
        "max_depth_4_num_boost_round_100_eta_03"
        "max_depth_6_num_boost_round_10_eta_03"
        "max_depth_6_num_boost_round_100_eta_03"
    )
    Fs=(0.1 0.01 0.001)
    lambdas=(0.0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 \
    0.9 0.95 0.98 0.99 0.995 0.998 0.999 1.0)
    mus=(0.0)
    pos_query_ratios=(0.0)
    query_nums=(40000)
    run

    # ablation study for \bar{D}
    trained_xgboost_model_folder_paths=(
        "max_depth_4_num_boost_round_2_eta_03"
        "max_depth_4_num_boost_round_3_eta_03"
        "max_depth_4_num_boost_round_4_eta_03"
        "max_depth_4_num_boost_round_5_eta_03"
        "max_depth_4_num_boost_round_6_eta_03"
        "max_depth_4_num_boost_round_7_eta_03"
        "max_depth_4_num_boost_round_8_eta_03"
        "max_depth_4_num_boost_round_9_eta_03"
        "max_depth_4_num_boost_round_10_eta_03"
        "max_depth_4_num_boost_round_20_eta_03"
        "max_depth_4_num_boost_round_30_eta_03"
        "max_depth_4_num_boost_round_40_eta_03"
        "max_depth_4_num_boost_round_50_eta_03"
        "max_depth_4_num_boost_round_60_eta_03"
        "max_depth_4_num_boost_round_70_eta_03"
        "max_depth_4_num_boost_round_80_eta_03"
        "max_depth_4_num_boost_round_90_eta_03"
        "max_depth_4_num_boost_round_100_eta_03"
    )
    Fs=(0.1 0.01 0.001)
    lambdas=(1.0)
    mus=(0.0)
    pos_query_ratios=(0.0)
    query_nums=(40000)
    run
done
