#!/bin/bash

export MASTER_PORT=$(python -c "import socket; s=socket.socket(); s.bind(('', 0)); print(s.getsockname()[1]); s.close()")
echo "Master Port: $MASTER_PORT"


per_device_train_batch_size=4
gradient_accumulation_steps=4


model=Llama-2-7b-hf

data_splits=(
    "News"
    "Books"
)

trainers=(
    # "GradDiff"
    # "NPO"
    # "SimNPO"
    # "RMU"
    "ME"
)

retain_losses=(
    "NLL"
    "KL"
)
# #########################################################
# #################### MUSE Unlearning ####################
# #########################################################


for retain_loss in "${retain_losses[@]}"; do
    for data_split in "${data_splits[@]}"; do
        for trainer in "${trainers[@]}"; do

            task_name=muse_${model}_${data_split}_${trainer}_${retain_loss}

            CUDA_VISIBLE_DEVICES=0,1 accelerate launch --config_file configs/accelerate/default_config.yaml --main_process_port $MASTER_PORT \
            src/train.py --config-name=unlearn.yaml \
            experiment=unlearn/muse/default.yaml \
            model=${model} \
            data_split=${data_split} \
            trainer=${trainer} \
            task_name=${task_name} \
            retain_logs_path=saves/eval/muse_${model}_${data_split}_retrain/MUSE_EVAL.json \
            trainer.args.per_device_train_batch_size=${per_device_train_batch_size} \
            trainer.args.gradient_accumulation_steps=${gradient_accumulation_steps} \
            trainer.args.ddp_find_unused_parameters=true \
            trainer.args.gradient_checkpointing=true\
            trainer.method_args.retain_loss_type=${retain_loss} 

            # task_name=muse_${model}_${data_split}_${trainer}_${retain_loss}/checkpoint-170

            CUDA_VISIBLE_DEVICES=1 python src/eval.py \
            experiment=eval/muse/default.yaml \
            data_split=${data_split} \
            task_name=${task_name} \
            model=${model} \
            model.model_args.pretrained_model_name_or_path=saves/unlearn/${task_name} \
            paths.output_dir=saves/unlearn/${task_name}/evals \
            retain_logs_path=saves/eval/muse_${model}_${data_split}_retrain/MUSE_EVAL.json
        done
    done
done