TASKS=(
    # tinyBenchmarks
    tinyHellaswag
    tinyArc
    tinyMMLU
    tinyTruthfulQA
    tinyWinogrande
    tinyGSM8k
)

# Define models with their corresponding ports
declare -A MODEL_PORTS=(
    ["Qwen/Qwen2.5-3B-Instruct"]=9901
    ["Qwen/Qwen2.5-7B-Instruct"]=9902
    ["Qwen/Qwen2.5-14B-Instruct"]=9903
    ["meta-llama/Llama-3.2-3B-Instruct"]=9904
    ["meta-llama/Llama-3.1-8B-Instruct"]=9905
    ["google/gemma-2-9b-it"]=9906
    ["Qwen/Qwen2.5-32B-Instruct"]=9907
    ["google/gemma-2-27b-it"]=9908
    ["Unispac/Gemma-2-9B-IT-With-Deeper-Safety-Alignment"]=9909

)

MODELS=(
    # Qwen/Qwen2.5-3B-Instruct
    # Qwen/Qwen2.5-7B-Instruct
    # Qwen/Qwen2.5-14B-Instruct
    # Qwen/Qwen2.5-32B-Instruct
    meta-llama/Llama-3.2-3B-Instruct
    # meta-llama/Llama-3.1-8B-Instruct
    # google/gemma-2-9b-it
    # google/gemma-2-27b-it
    # Unispac/Gemma-2-9B-IT-With-Deeper-Safety-Alignment
)


declare -A angle_lists
# Naive Static 0.99
# angle_lists["Qwen/Qwen2.5-3B-Instruct"]="280 260"
# angle_lists["Qwen/Qwen2.5-7B-Instruct"]="250 260"
# angle_lists["Qwen/Qwen2.5-14B-Instruct"]="120"
# angle_lists["Qwen/Qwen2.5-32B-Instruct"]="100"
# angle_lists["meta-llama/Llama-3.1-8B-Instruct"]="130 110"
# angle_lists["meta-llama/Llama-3.2-3B-Instruct"]="230 240"
# angle_lists["google/gemma-2-9b-it"]="190"
# angle_lists["google/gemma-2-27b-it"]="110"
# angle_lists["Unispac/Gemma-2-9B-IT-With-Deeper-Safety-Alignment"]="200"


# # Causal ActAdd1p0
# angle_lists["Qwen/Qwen2.5-3B-Instruct"]="210 140"
# angle_lists["Qwen/Qwen2.5-7B-Instruct"]="210 220"
# angle_lists["Qwen/Qwen2.5-14B-Instruct"]="160"
# angle_lists["Qwen/Qwen2.5-32B-Instruct"]="110 120"
# angle_lists["meta-llama/Llama-3.1-8B-Instruct"]="180"
# angle_lists["meta-llama/Llama-3.2-3B-Instruct"]="180 170"
# angle_lists["google/gemma-2-9b-it"]="220"
# angle_lists["google/gemma-2-27b-it"]="260 160"
# angle_lists["Unispac/Gemma-2-9B-IT-With-Deeper-Safety-Alignment"]="230 220"


# Causal DirAblate
# angle_lists["Qwen/Qwen2.5-3B-Instruct"]="310 270"
# angle_lists["Qwen/Qwen2.5-7B-Instruct"]="280 270"
# angle_lists["Qwen/Qwen2.5-14B-Instruct"]="250"
# angle_lists["Qwen/Qwen2.5-32B-Instruct"]="100 110"
# angle_lists["meta-llama/Llama-3.1-8B-Instruct"]="220 250"
# angle_lists["meta-llama/Llama-3.2-3B-Instruct"]="240 210"
# angle_lists["google/gemma-2-9b-it"]="210"
# angle_lists["google/gemma-2-27b-it"]="290 280"
# angle_lists["Unispac/Gemma-2-9B-IT-With-Deeper-Safety-Alignment"]="220 210"

# Baseline
# angle_lists["Qwen/Qwen2.5-3B-Instruct"]="140"
# angle_lists["Qwen/Qwen2.5-7B-Instruct"]="190"
# angle_lists["Qwen/Qwen2.5-14B-Instruct"]="200"
# angle_lists["Qwen/Qwen2.5-32B-Instruct"]="170"
# angle_lists["meta-llama/Llama-3.1-8B-Instruct"]="180"
# angle_lists["meta-llama/Llama-3.2-3B-Instruct"]="180"
# angle_lists["google/gemma-2-9b-it"]="140"
# angle_lists["google/gemma-2-27b-it"]="150"
# angle_lists["Unispac/Gemma-2-9B-IT-With-Deeper-Safety-Alignment"]="110"

# Adam
# angle_lists["Qwen/Qwen2.5-3B-Instruct"]="290"
# angle_lists["Qwen/Qwen2.5-7B-Instruct"]="250"
# angle_lists["Qwen/Qwen2.5-14B-Instruct"]="210"
# angle_lists["Qwen/Qwen2.5-32B-Instruct"]="260"
# angle_lists["meta-llama/Llama-3.1-8B-Instruct"]="230"
# angle_lists["meta-llama/Llama-3.2-3B-Instruct"]="160"
# angle_lists["google/gemma-2-9b-it"]="190"
# angle_lists["google/gemma-2-27b-it"]="170"
# angle_lists["Unispac/Gemma-2-9B-IT-With-Deeper-Safety-Alignment"]="210"

# Adam Causal (Dir Ablate)
# angle_lists["Qwen/Qwen2.5-3B-Instruct"]="300"
# angle_lists["Qwen/Qwen2.5-7B-Instruct"]="260"
# angle_lists["Qwen/Qwen2.5-14B-Instruct"]="210"
# angle_lists["Qwen/Qwen2.5-32B-Instruct"]="250"
# angle_lists["meta-llama/Llama-3.1-8B-Instruct"]="210"
# angle_lists["meta-llama/Llama-3.2-3B-Instruct"]="200"
# angle_lists["google/gemma-2-9b-it"]="190"
# angle_lists["google/gemma-2-27b-it"]="110"
# angle_lists["Unispac/Gemma-2-9B-IT-With-Deeper-Safety-Alignment"]="200"

# Adam Causal (ActAdd)
angle_lists["Qwen/Qwen2.5-3B-Instruct"]="240"
angle_lists["Qwen/Qwen2.5-7B-Instruct"]="130"
angle_lists["Qwen/Qwen2.5-14B-Instruct"]="190"
angle_lists["Qwen/Qwen2.5-32B-Instruct"]="200"
angle_lists["meta-llama/Llama-3.1-8B-Instruct"]="240"
angle_lists["meta-llama/Llama-3.2-3B-Instruct"]="260"
angle_lists["google/gemma-2-9b-it"]="160"
angle_lists["google/gemma-2-27b-it"]="200"
angle_lists["Unispac/Gemma-2-9B-IT-With-Deeper-Safety-Alignment"]="220"


dir_id=max_sim
opt_mode=adam
mode=causal_actadd1p0
#baseline
beta_str=0p9_0p999

for model_id in "${MODELS[@]}"; do
    port=${MODEL_PORTS[$model_id]}
    for task in "${TASKS[@]}"; do
        # baseline
        model_name=$(echo "$model_id" | cut -d'/' -f2)
        echo "Evaluating model: $model_id with angle none on port $port"
        lm_eval \
            --model local-completions \
            --tasks ${task} \
            --batch_size 1 \
            --model_args model=${model_id},base_url=http://0.0.0.0:${port}/angular_steering/none,num_concurrent=1,max_retries=3,tokenized_requests=False,max_gen_toks=4096 \
            --output_path ./benchmarks/momentum_${mode}/beta_${beta_str}/${dir_id}/${task}/${model_name}/adaptive_none \
            --log_samples
            --wandb_args project=lm-eval-angular-steering,entity=lone17,id=${model_name}+${task}+adaptive_none+${dir_id} \
        # steer
        angles="${angle_lists[$model_id]}"
        for angle in $angles; do
            echo "Evaluating model: $model_id with angle: $angle on port $port"
            lm_eval \
                --model local-completions \
                --tasks ${task} \
                --batch_size 1 \
                --model_args model=${model_id},base_url=http://0.0.0.0:${port}/angular_steering/${angle},num_concurrent=1,max_retries=3,tokenized_requests=False,max_gen_toks=4096 \
                --output_path ./benchmarks/${opt_mode}_${mode}/beta_${beta_str}/${dir_id}/${task}/${model_name}/adaptive_${angle} \
                --log_samples
                # --wandb_args project=lm-eval-angular-steering,entity=lone17,id=${model_name}+${task}+adaptive_${angle}+${dir_id} \
                # --output_path ./benchmarks/momentum_${mode}/beta_${beta_str}/${dir_id}/${task}/${model_name}/adaptive_${angle} \
                # --output_path ./benchmarks/momentum_${mode}/${dir_id}/${task}/${model_name}/adaptive_${angle} \
        done
    done
done
