# Supplementary Code for ICML 2026 Submission 1105

This repository contains the supplementary code for the ICML 2026 submission 1105.

The code is intended for demonstration and reproducibility purposes only.

## Requirements
Python=3.11

You can install dependencies via:

```bash
pip install -r requirements.txt
```

# Run experiments
Here are some simple Python commands to run the unlearning method.

```python
# finetuning model
CUDA_VISIBLE_DEVICES=1 torchrun --nproc_per_node=2 --master_port=23114 finetune.py --config-name=finetune.yaml split=full batch_size=4 gradient_accumulation_steps=8 model_family=llama3.2-1b lr=2e-5


# unlearning process
CUDA_VISIBLE_DEVICES=1 torchrun --nproc_per_node=1 --master_port=27393 forget.py --config-name=forget_base.yaml split=forget05 model_family=llama3.2-1b batch_size=4 gradient_accumulation_steps=8 forget_loss=grad_diff weight_decay=0.01 beta=1.0 npo_coeff=1.0
CUDA_VISIBLE_DEVICES=1 torchrun --nproc_per_node=1 --master_port=27393 forget.py --config-name=forget_base.yaml split=forget05 model_family=llama3.2-1b batch_size=4 gradient_accumulation_steps=8 forget_loss=npo_grad_diff weight_decay=0.01 beta=0.1 npo_coeff=0.5
CUDA_VISIBLE_DEVICES=1 torchrun --nproc_per_node=1 --master_port=27393 forget.py --config-name=forget_base.yaml split=forget05 model_family=llama3.2-1b batch_size=4 gradient_accumulation_steps=8 forget_loss=dpo_grad_diff weight_decay=0.01 beta=0.1 npo_coeff=0.5
CUDA_VISIBLE_DEVICES=1 torchrun --nproc_per_node=1 --master_port=27393 forget.py --config-name=forget_base.yaml split=forget05 model_family=llama3.2-1b batch_size=4 gradient_accumulation_steps=8 forget_loss=simnpo_grad_diff weight_decay=0.01 beta=2.0 npo_coeff=0.2 gamma=0.0
CUDA_VISIBLE_DEVICES=1 torchrun --nproc_per_node=1 --master_port=27393 forget.py --config-name=forget_base.yaml split=forget05 model_family=llama3.2-1b batch_size=4 gradient_accumulation_steps=8 forget_loss=wgd weight_decay=0.01 beta=1.0 npo_coeff=1.0 gamma=0.0
CUDA_VISIBLE_DEVICES=1 torchrun --nproc_per_node=1 --master_port=27393 forget.py --config-name=forget_base.yaml split=forget05 model_family=llama3.2-1b batch_size=4 gradient_accumulation_steps=8 forget_loss=satimp_gd weight_decay=0.01 beta=5.0 npo_coeff=1.0 gamma=1.0

CUDA_VISIBLE_DEVICES=1 torchrun --nproc_per_node=1 --master_port=27393 forget.py --config-name=forget_base.yaml split=forget05 model_family=llama3.2-1b batch_size=4 gradient_accumulation_steps=8 forget_loss=eua weight_decay=0.01 beta=0.5 npo_coeff=0.01 gamma=1.0

# evaluate
CUDA_VISIBLE_DEVICES=7 torchrun --nproc_per_node=1 --master_port=18149 eval_es.py model_family=llama3.2-1b split=forget05 model_path=base/llama3.2-1b/eua_1e-05_forget05_5_0.01_0.5and1.0and0.01/checkpoint-62 ps_type=exact
CUDA_VISIBLE_DEVICES=7 torchrun --nproc_per_node=1 --master_port=18149 eval_energy.py model_family=llama3.2-1b split=forget05 model_path=base/llama3.2-1b/eua_1e-05_forget05_5_0.01_0.5and1.0and0.01/checkpoint-62  ps_type=exact topk=5


```