# Mitigating Exponential Mixed Frequency Growth through Frequency Selection

This repository contains the code and data for Mitigating Exponential Mixed Frequency Growth through Frequency Selection.  
The code is provided as Jupyter notebooks (`.ipynb`) together with the input data files (`.csv`).  
The model output data that was used for generating the plots in the main section of the paper is also provided, together with the notebooks to generate the plots. 
For readability, the code is split into two folders: one for the 1D Fourier target experiments and one for the 2D Fourier target experiments.
We have also included only one jupyter notebook per model, which can be run to reproduce the results.
The parameters in the notebooks can be adjusted easily to run other experiments with different settings, such as different number of frequencies, different numbers of qubits, serial layers, prefactors, initial weights scalings, etc. 

---

## Requirements

- Python 3.10+ (or whichever version you used)  
- Jupyter Notebook or JupyterLab  

To install dependencies, run:  

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

## File Structure

```
freq_selection/
├── 1d_Fourier_target/           # 1D Fourier target experiments
│   ├── data/                    # Input data files and generator scripts
│   ├── input/                   # Input CSV files
│   ├── existing_results/        # Model outputs + plotting notebooks
│   └── notebooks/               # Jupyter notebooks for 1D experiments
│
├── 2d_Fourier_target/           # 2D Fourier target experiments
│   ├── data/                    # Input data files and generator scripts
│   ├── input/                   # Input CSV files
│   ├── existing_results/        # Model outputs + plotting notebooks
│   └── notebooks/               # Jupyter notebooks for 2D experiments
│
├── requirements.txt             # Python dependencies
└── README.md                    # This file
```


## Data

All input data files are in the data/input folders of the 1d_ or 2d_Fourier_target folders.
Each notebook for the models assumes the .csv files are in this location.
The input data files were generated using the scripts in the data folder.

The existing_results contain csv files with the results from the experiments in the paper, as well as the notebooks to generate the plots in the main section of the paper.

## Usage

1. Start Jupyter:
```
jupyter lab
```
(or jupyter notebook)

2. Open the notebook(s) in the notebooks/ folder.
3. Run the cells sequentially to reproduce the results.


## Notes
The experiment models are based on https://pennylane.ai/qml/demos/tutorial_expressivity_fourier_series/
Please contact us via the conference submission system for any clarification.

## Ethics Statement
Large language models have been used for the production of this paper to polish writing, debug the code for conducting the experiments and generate the code for the plotting of the results.
