# Semantically Guided Target Selection via Language Models for Adversarial Testing of Vision Models

Code that can be used to perform adversarial attacks based on similarity via language models. 

The overview of our approach:

![Alt text](./overview_img.png)


## Requirements 

Run on Python 3.9.16 and requirements.txt


## Reproducing the experiments 

We provide a sample compatible dataset in folder *DEV* and its label file in *dev_dataset.csv*. To reproduce our results, replace them with real DEV data folder and its corresponding file with annotations from https://github.com/cleverhans-lab/cleverhans/tree/master/cleverhans_v3.1.0/examples/nips17_adversarial_competition/dataset.

### Configurations to run to reproduce the results from the paper:

#### CLIP

```bash
adversarial_testing.py --model MobileNetV2 --similarity_source CLIP --variant MS --dataset DEV

adversarial_testing.py --model MobileNetV2 --similarity_source CLIP --variant LS --dataset DEV

adversarial_testing.py --model EfficientNetV2B0 --similarity_source CLIP --variant MS --dataset DEV

adversarial_testing.py --model EfficientNetV2B0 --similarity_source CLIP --variant LS --dataset DEV

adversarial_testing.py --model ResNet50V2 --similarity_source CLIP --variant MS --dataset DEV

adversarial_testing.py --model ResNet50V2 --similarity_source CLIP --variant LS --dataset DEV
```

#### BERT

```bash
adversarial_testing.py --model MobileNetV2 --similarity_source BERT --variant MS --dataset DEV

adversarial_testing.py --model MobileNetV2 --similarity_source BERT --variant LS --dataset DEV

adversarial_testing.py --model EfficientNetV2B0 --similarity_source BERT --variant MS --dataset DEV

adversarial_testing.py --model EfficientNetV2B0 --similarity_source BERT --variant LS --dataset DEV

adversarial_testing.py --model ResNet50V2 --similarity_source BERT --variant MS --dataset DEV

adversarial_testing.py --model ResNet50V2 --similarity_source BERT --variant LS --dataset DEV
```

#### tinyLLAMA

```bash
adversarial_testing.py --model MobileNetV2 --similarity_source LLAMA --variant MS --dataset DEV

adversarial_testing.py --model MobileNetV2 --similarity_source LLAMA --variant LS --dataset DEV

adversarial_testing.py --model EfficientNetV2B0 --similarity_source LLAMA --variant MS --dataset DEV

adversarial_testing.py --model EfficientNetV2B0 --similarity_source LLAMA --variant LS --dataset DEV

adversarial_testing.py --model ResNet50V2 --similarity_source LLAMA --variant MS --dataset DEV

adversarial_testing.py --model ResNet50V2 --similarity_source LLAMA --variant LS --dataset DEV
```

#### WUP - our reference

```bash
adversarial_testing.py --model MobileNetV2 --similarity_source WUP --variant MS --dataset DEV

adversarial_testing.py --model MobileNetV2 --similarity_source WUP --variant LS --dataset DEV

adversarial_testing.py --model EfficientNetV2B0 --similarity_source WUP --variant MS --dataset DEV

adversarial_testing.py --model EfficientNetV2B0 --similarity_source WUP --variant LS --dataset DEV

adversarial_testing.py --model ResNet50V2 --similarity_source WUP --variant MS --dataset DEV

adversarial_testing.py --model ResNet50V2 --similarity_source WUP --variant LS --dataset DE
```
