### Acknowledgements

This code is heavily adapted from the following repository [Tangent Task Arithmetic](https://github.com/gortizji/tangent_task_arithmetic/tree/main)


### Install dependencies

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

Add the `src` directory to the `PYTHONPATH`:
```sh
cd analysis
export PYTHONPATH="$PYTHONPATH:$PWD"
```
### Backdooring

```
python3 src/finetune.py --train-dataset=<dataset> --model=<model name> --attack=<type of attack> --poison_rate=<rate posioning> --target=<idx of target label> --save=<path to save dir> --lr=<learning rate> --epochs=<number of epochs> --seed=<seed>
```


### TBAR Poison-Only training

```
python3 src/finetune_from_ckpt.py --train-dataset=<dataset> --model=<model name> --attack=<type of attack> --poison_rate=<rate posioning> --target=<idx of target label> --save=<path to save dir> --load=<path to backdoored .pt model>  --lr=<learning rate> --epochs=<number of epochs> --seed=<seed> --poisonOnly_training
```

### Evaluation


```
python eval_val.py \
  --datasets=<list of datasets to evaluate> \
  --alpha-grid=<scaling coefficient values> \
  --out-csv=<path to store results> \
  --skip-existing \
  --attack <type_of_attack> --model <model_name> --seed=<seed>
```
Keep CA ≥ 95% of baseline and ASR ≤ 5% of baseline
```
python /select_and_eval_test.py \
  --val-csv <path to validation results>\
  --out-csv <path to store results> \
  --ca-min-frac=0.95 \
  --asr-max-frac=0.05 \
  --print-choices \
  --attack=<type_of_attack> --model=<model_name> --seed=<seed>
```
Sensitivity analysis
```
python eval_alpha_sensitivity.py   \
 --val-csv=<path to validation results>   \
 --out-csv=<path to store results>   \
 --ca-min-frac=0.95   --asr-max-frac=0.05   \
 --alpha-perturb-frac 0.10 \
 --print_choices   --attack=<type_of_attack> --model=<model_name>  --seed=<seed> --prefer-min-asr
```


