# QMirage
An implement for paper "Fast Adversarial Attack Targeting Latent Features in Quantum Neural Networks"

The repository is structured as follows:

```angular2html
|-- adversarial/
|-- models/
|-- robustness_analysis/
|-- tools/
|-- adv_baseline.py 
|-- QMirage.py
|-- config.py
|-- requirements.txt
|-- train.py
```


## Preparation

### Requirement
```angular2html
pip install -r requirements.txt
```

### Related data
We provide trained QNNs (both ideal and realistic ones), partial adversarial examples generated by baselines and QMirage in `\data\models` and `\data\adversarial` respectively.
Adversarial examples include FGSM, BIM, CW, QuanTest and QMirage for QCL and MNIST.

## Quick Start

You can test QMirage by directly using provided models and data for a quick start.

1. on ideal models
```angular2html
python QMirage.py --dataset mnist --structure qcl --resize --class_idx 0 1
```
Options:

`--dataset`: target dataset, choices: mnist (default), fashion_mnist

`--structure`: target model, choices: qcl (default), qcnn, drnn, hqnn

`--class_idx`: target classes for binary or ternary classification. choices: 0 1 for binary classification, 0 1 2 for ternary classification on QCL and 4 5 7 for ternary classification on QCNN.

`--resize`: downsample to 16*16 (8*8 for drnn)


2. on finite-shot and noisy models
```angular2html
python QMirage.py --dataset mnist --structure qcl --resize --class_idx 0 1 --finite 1000 --noise
```
Options:

`--finite`: number of shots to obtain QNN outputs

`--noise`: add random noise before measurement layer in QNN


## Train QNN models

```angular2html
# train ideal models
python train.py --dataset mnist --structure qcl --class_idx 0 1 --resize --data_scale 0.2
# train finite-shot and noisy models
python train.py --dataset mnist --structure qcl --class_idx 0 1 --resize --data_scale 0.2 --finite 1000 --noise
```

Options:

`--data_scale`: percentage of the whole dataset used for model training. Default: 0.2



## Run Baseline

1. Classical-inspired adversarial attacks
```angular2html
# on ideal models
python adv_baseline.py --dataset mnist --structure qcl --resize --attack FGSM --num_test 100
# on finite-shot and noisy models
python adv_baseline.py --dataset mnist --structure qcl --resize --finite 1000 --noise --attack FGSM --num_test 100
```
Options:

`--attack`: baseline attack, choices: FGSM (default), BIM, CW. After running some attack, the original images will be saved for other attacks to ensure fair comparison.

`--num_test`: number of data sampled from each class, default: 100

2. Quantum-specific adversarial attacks
```angular2html
python QuanTest.py --dataset mnist --structure qcl --resize --num_test 100
```
Note that QuanTest can only be tested on ideal models.

## Run QMirage

```angular2html
# on ideal models
python QMirage.py --dataset mnist --structure qcl --resize
# on finite-shot and noisy models
python QMirage.py --dataset mnist --structure qcl --resize --finite 1000 --noise
```
You can try different attack configurations by modifying `attack_config` in QMirage.py including target layer, initial learning rate, w, and budget.

## RobustnessVerifier
```angular2html
python robustness_verifier.py --dataset mnist --structure qcl --resize
```

Note that RobustnessVerifier cannot work effectively on DRNN.


## Larger-scale models

To test larger-scale QNNs (deeper circuits or more qubits), you can change depth_dict or qubit_dict in models/circuits.py.
We have uploaded noisy QCL with depth of 5, 10, 15 (8 qubits), with 10 qubits (depth 5) respectively.

