# Simulating Mixed State Dynamics to Enable Differentiable Quantum Architecture Search

This source code is provided for peer review purposes only.

## Installation
Our code base makes use of our differentiable quantum simulation library qtorch. You will need to set up a conda environment with Python v3.11 or higher to run the code.

To install the prerequisite packages run the following command:

`pip install torch torchvision wandb wandb[media] tqdm jupyter numba matplotlib seaborn scipy qiskit pylatexenc scikit-learn`

To use the custom GPU kernels you will need to install the CUDA Toolkit in your conda environment, with the following command:

`conda install nvidia/label/cuda-12.8.0::cuda-toolkit -y`


To install the qtorch library, navigate to the directory of this README file and run the following command:

`pip install -e .`


## Running Experiments
For best results, run the Python scripts from this directory.

### Entangled State Initialization Experiments
The module to run this experiment is `examples/qas/entangled_states/macro_search_experiment.py`, use the `--help` option to see the command line arguments.

```bash
python -m examples.qas.entangled_states.macro_search_experiment --project-name "${PROJECT_NAME}" -m -p 12 -r 3 -c 0 -s 0.001 --ghz-layers 3
```

### Image Initialization Experiments
The module to run this experiment is `examples/qas/image_init/macro_search.py`, use the `--help` option to see the command line arguments. For the experiment parameters used in our paper, make sure to pass the path of `img_init.yml` to the `--cfg` option.


```bash
# Create and store the MNIST datasets
python -m examples.qas.image_init.utils -i 16 --data-path "${DATAPATH}" --mnist-path "${DATAPATH}"
python -m examples.qas.image_init.utils -i 8 --data-path "${DATAPATH}" --mnist-path "${DATAPATH}"

# Run the image initalization experiments
python -m examples.qas.image_init.macro_search --project-name "${PROJECT_NAME}" -c 0 -m -p 12 --data-path "${DATAPATH}" --mnist-path "${DATAPATH}" --cfg "${CFGPATH}"
```

### VQE Experiments
The module to run this experiment is `examples/qas/vqe/sweep.py`, use the `--help` option to see the command line arguments. 

```bash
python -m examples.qas.vqe.sweep --project-name "${PROJECT_NAME}" -c 0 -m -p 32
```

### Max Cut Experiments
To run the max-cut experiments, you will have to save the files in `data/graphs` in an artifact on your WANDB project where you intend to run the experiments. These contain the graphs used in our paper. Alternatively, you can generate your own graphs with the module `examples/qas/max_cut/data.py`.

```bash
# Macro search without noise
python -m examples.qas.max_cut.macro_one_shot --project-name "${PROJECT_NAME}" --local-artifact-path $ARTIFACT_PATH

# Macro search with noise
python -m examples.qas.max_cut.macro_one_shot --project-name "${PROJECT_NAME}" --local-artifact-path $ARTIFACT_PATH -m -p 16 -n

# Micro search
python -m examples.qas.max_cut.micro_one_shot --project-name "${PROJECT_NAME}" --local-artifact-path $ARTIFACT_PATH
```

## Experiment Data
The experiment data from the runs that we have presented in the paper are provided in the csv files in the `run_data/` folder.