#!/bin/bash

source scripts/setup_env.sh

model="Llama-3.1-8B-Instruct"
trainer="T3"

FORGET_PCT="05"
forget_split="forget${FORGET_PCT}"
model="Llama-3.1-8B-Instruct"

# Classifier training params
seeds=(1 2 3 4 5)
num_epochs=100
warmup_epochs=25
lr=5e-4
weight_decay=1e-3
hidden_size=25
num_hidden_layers=1
activation_str="id"
bias=false
batch_size=2048

# Preprocessing params
extraction_layer=-1
pooling="mean"

# Model construction commands
base_temp=2.5
guidance_scale=1

# Performance mode
performance_mode=true

for seed in "${seeds[@]}"; do

    load_dir="saves/preprocess/tofu_${model}_${forget_split}/seed${seed}"
    precomputed_path="${load_dir}/precomputed_states.pt"
    output_dir="saves/unlearn/preprocessed/tofu_${model}_forget${FORGET_PCT}_T3/seed${seed}"

    model_path=open-unlearning/tofu_${model}_full
    echo $"Unlearning ${model_path} using ${trainer}"

    python src/unlearn_t3_preprocessed.py \
    --config-name=unlearn_t3_preprocessed.yaml \
    data.precomputed_path=${precomputed_path} \
    training.epochs=${num_epochs} \
    training.warmup_epochs=${warmup_epochs} \
    training.learning_rate=${lr} \
    training.weight_decay=${weight_decay} \
    training.batch_size=${batch_size} \
    training.seed=${seed} \
    training.performance_mode=$performance_mode \
    classifier.hidden_size=${hidden_size} \
    classifier.num_hidden_layers=${num_hidden_layers} \
    classifier.activation_str=${activation_str} \
    classifier.bias=${bias} \
    save.output_dir=${output_dir}
done
