MASTER_PORT=$((RANDOM % 50001 + 10000))

forget_losses=(
    GA+GD
    NPO+GD
    IDK+GD
    DPO+GD
    # GA+KL
    # NPO+KL
    # IDK+KL
    # DPO+KL
)

forget_sets=(
    # forget01
    forget05
    forget10
)
# You can specify any forget task from 1 to 10, tofu benchmark defaults to 1
task_list=(1 2 3 4 5 6 7 8 9 10) #  foret01/forget05
# task_list=(1 2 3 4 5 6 7 8 9)    #  forget10

# pass to python script
export TASK_LIST=$(IFS=,; echo "${task_list[*]}")


learning_rates=(
    1e-5
)


mask=true
use_LoRA=false # if use LoRA for fine-tuning

save_root=results/continual_tofu

forget_coeff=1.0 
regularization_coeff=1.0
attention_temp=2.3

save_checkpoint=false
save_steps=last
eval_steps=(last)
fix_ref_model=false

num_epochs=5

# split=forget01 # forget01/forget05/forget10

for split in ${forget_sets[@]}; do
    for forget_loss in ${forget_losses[@]}; do
        for lr in ${learning_rates[@]}; do
            for task_id in ${task_list[@]}; do
                COMMON="use_LoRA=$use_LoRA forget_coeff=$forget_coeff regularization_coeff=$regularization_coeff lr=$lr split=$split forget_loss=$forget_loss num_epochs=$num_epochs \
                    mask=$mask fix_ref_model=$fix_ref_model save_root=$save_root save_checkpoint=$save_checkpoint"
                CUDA_VISIBLE_DEVICES=0,1 torchrun --nproc_per_node=2 --master_port=$MASTER_PORT \
                        forget.py \
                        --config-name=tofu.yaml \
                        task_id=$task_id \
                        save_steps=$save_steps \
                        $COMMON
                for step in ${eval_steps[@]}; do
                    CUDA_VISIBLE_DEVICES=0 torchrun --nproc_per_node=1 --master_port=$MASTER_PORT \
                            eval.py \
                            --config-name=tofu.yaml \
                            task_id=$task_id \
                            eval_unlearn_step=$step \
                            $COMMON
                done
            done
        done
    done
done




MASTER_PORT=$((RANDOM % 50001 + 10000))

forget_losses=(
    attn+GD
    # attn+KL
)

# You can specify any forget task from 1 to 10, tofu benchmark defaults to 1
task_list=(1 2 3 4 5 6 7 8 9 10) #  foret01/forget05
# task_list=(1 2 3 4 5 6 7 8 9)    #  forget10

# pass to python script
export TASK_LIST=$(IFS=,; echo "${task_list[*]}")


learning_rates=(
    1e-5
)


mask=true
use_LoRA=false # if use LoRA for fine-tuning

save_root=results/continual_tofu

forget_coeff=0.1
regularization_coeff=1.0
attention_temp=2.3

save_checkpoint=false
save_steps=last
eval_steps=(last)
fix_ref_model=false

num_epochs=5

# split=forget01 # forget01/forget05/forget10
for split in ${forget_sets[@]}; do
    for forget_loss in ${forget_losses[@]}; do
        for lr in ${learning_rates[@]}; do
            for task_id in ${task_list[@]}; do
                COMMON="use_LoRA=$use_LoRA forget_coeff=$forget_coeff regularization_coeff=$regularization_coeff lr=$lr split=$split forget_loss=$forget_loss num_epochs=$num_epochs \
                    mask=$mask fix_ref_model=$fix_ref_model save_root=$save_root save_checkpoint=$save_checkpoint attention_temp=$attention_temp"
                CUDA_VISIBLE_DEVICES=0,1 torchrun --nproc_per_node=2 --master_port=$MASTER_PORT \
                        forget.py \
                        --config-name=tofu.yaml \
                        task_id=$task_id \
                        save_steps=$save_steps \
                        $COMMON
                for step in ${eval_steps[@]}; do
                    CUDA_VISIBLE_DEVICES=0 torchrun --nproc_per_node=1 --master_port=$MASTER_PORT \
                            eval.py \
                            --config-name=tofu.yaml \
                            task_id=$task_id \
                            eval_unlearn_step=$step \
                            $COMMON
                done
            done
        done
    done
done




MASTER_PORT=$((RANDOM % 50001 + 10000))

forget_losses=(
    ME+GD
    # ME+KL
)

# You can specify any forget task from 1 to 10, tofu benchmark defaults to 1
task_list=(1 2 3 4 5 6 7 8 9 10) #  foret01/forget05
# task_list=(1 2 3 4 5 6 7 8 9)    #  forget10

# pass to python script
export TASK_LIST=$(IFS=,; echo "${task_list[*]}")


learning_rates=(
    1e-5
)



mask=false
use_LoRA=false # if use LoRA for fine-tuning

save_root=results/continual_tofu
forget_coeff=1.0 
regularization_coeff=1.0

save_checkpoint=false
save_steps=last
eval_steps=(last)
fix_ref_model=false

num_epochs=5

split=forget01 # forget01/forget05/forget10
for split in ${forget_sets[@]}; do
    for forget_loss in ${forget_losses[@]}; do
        for lr in ${learning_rates[@]}; do
            for task_id in ${task_list[@]}; do
                COMMON="use_LoRA=$use_LoRA forget_coeff=$forget_coeff regularization_coeff=$regularization_coeff lr=$lr split=$split forget_loss=$forget_loss num_epochs=$num_epochs \
                    mask=$mask fix_ref_model=$fix_ref_model save_root=$save_root save_checkpoint=$save_checkpoint"
                CUDA_VISIBLE_DEVICES=0,1 torchrun --nproc_per_node=2 --master_port=$MASTER_PORT \
                        forget.py \
                        --config-name=tofu.yaml \
                        task_id=$task_id \
                        save_steps=$save_steps \
                        $COMMON
                for step in ${eval_steps[@]}; do
                    CUDA_VISIBLE_DEVICES=0 torchrun --nproc_per_node=1 --master_port=$MASTER_PORT \
                            eval.py \
                            --config-name=tofu.yaml \
                            task_id=$task_id \
                            eval_unlearn_step=$step \
                            $COMMON
                done
            done
        done
    done
done


MASTER_PORT=$((RANDOM % 50001 + 10000))

forget_losses=(
    IDK+AP
)

# You can specify any forget task from 1 to 10, tofu benchmark defaults to 1
task_list=(1 2 3 4 5 6 7 8 9 10) #  foret01/forget05
# task_list=(1 2 3 4 5 6 7 8 9)    #  forget10

# pass to python script
export TASK_LIST=$(IFS=,; echo "${task_list[*]}")


learning_rates=(
    1e-5
)



mask=true
use_LoRA=false # if use LoRA for fine-tuning

save_root=results/continual_tofu
forget_coeff=1.0 
regularization_coeff=1.0

save_checkpoint=false
save_steps=last
eval_steps=(last)
fix_ref_model=false

num_epochs=5

# split=forget01 # forget01/forget05/forget10
for split in ${forget_sets[@]}; do
    for forget_loss in ${forget_losses[@]}; do
        for lr in ${learning_rates[@]}; do
            for task_id in ${task_list[@]}; do
                COMMON="use_LoRA=$use_LoRA forget_coeff=$forget_coeff regularization_coeff=$regularization_coeff lr=$lr split=$split forget_loss=$forget_loss num_epochs=$num_epochs \
                    mask=$mask fix_ref_model=$fix_ref_model save_root=$save_root save_checkpoint=$save_checkpoint"
                CUDA_VISIBLE_DEVICES=0,1 torchrun --nproc_per_node=2 --master_port=$MASTER_PORT \
                        forget.py \
                        --config-name=tofu.yaml \
                        task_id=$task_id \
                        save_steps=$save_steps \
                        $COMMON
                for step in ${eval_steps[@]}; do
                    CUDA_VISIBLE_DEVICES=0 torchrun --nproc_per_node=1 --master_port=$MASTER_PORT \
                            eval.py \
                            --config-name=tofu.yaml \
                            task_id=$task_id \
                            eval_unlearn_step=$step \
                            $COMMON
                done
            done
        done
    done
done