QuOp_MPI

A Parallel Framework for Quantum Variational Algorithms

QuOp_MPI is a Python 3 module designed for parallel, distributed-memory simulation of Quantum Variational Algorithms (QVAs) with arbitrary phase-shift and mixing operators.

Current Version: 1.2.1

For an in-depth discussion on design, usage, and performance, please refer to the preprint on arXiv.

Installation

Prerequisites

Before installing QuOp_MPI, ensure that the following system dependencies are met:

  • Compiler: GCC 7+ with Fortran support (e.g., using mpifort).

  • MPI: Open-MPI or MPICH.

  • HDF5: Configured with –enable-fortran –enable-shared –enable-parallel.

  • FFTW3: Configured with –enable-fortran –enable-shared –enable-mpi.

  • Python: 3.11+

You can install these prerequisites using your Linux package manager or Homebrew on macOS. Instructions for building HDF5 and FFTW3 from source are provided later in this README.

Package Installation

First, install the following build dependencies:

python -m pip install --upgrade pip setuptools
python -m pip install scikit-build cmake ninja

Next, choose one of the following build methods:

Standard Build:

To install from source (ensure that all build prerequisites are set), run:

python -m pip install .

Note

If you encounter installation issues on a repeated build, try removing the _skbuild directory:

rm -rf _skbuild

Development Build:

For development or modifying QuOp_MPI, use the following steps:

cmake -B build -S .
cmake --build build --target install
python -m pip install -e .

Optional Dependencies

QuOp_MPI provides optional dependencies for documentation and examples.

  • Install all optional dependencies at once:

    python -m pip install '.[all]'
    
  • Manual installation: If you prefer, install dependencies manually:

    python -m pip install numpydoc==1.5.0 sphinxcontrib-bibtex==2.5.0 sphinx-rtd-theme==1.2.0
    python -m pip install pandas-datareader==0.10.0 yfinance==0.2.12 matplotlib>=3.6.0 seaborn>=0.11.2 jupyter-client>=6.1.2 jupyter-core>=4.6.3
    

Usage Examples

After installation, you can test the package using one of the provided examples. For instance, to run the maxcut example:

cd examples/maxcut
mpiexec -N 2 python3 maxcut.py

Documentation

The documentation is built using Sphinx. After installing the optional documentation dependencies, generate the docs with:

python setup.py build_sphinx

Building FFTW3 and HDF5 From Source

If pre-built parallel versions of FFTW3 and HDF5 are not available on your system, compile them from source as follows:

# HDF5
wget https://support.hdfgroup.org/ftp/HDF5/releases/hdf5-1.10/hdf5-1.10.6/src/hdf5-1.10.6.tar.gz
tar -xvf hdf5-1.10.6.tar.gz
cd hdf5-1.10.6
./configure --enable-fortran --enable-shared --enable-parallel --prefix=/usr/local
make && sudo make install
cd ..

# FFTW3
wget http://www.fftw.org/fftw-3.3.8.tar.gz
tar -xvf fftw-3.3.8.tar.gz
cd fftw-3.3.8
./configure --enable-mpi --enable-fortran --enable-shared --prefix=/usr/local
make && sudo make install
cd ..

Environment Setup

If QuOp_MPI is unable to locate the HDF5 or FFTW shared libraries, update your library path. Add the following line to your ~/.bashrc:

export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/usr/local/lib

Then, reload your environment:

source ~/.bashrc

License

QuOp_MPI is distributed under the GNU General Public License v3.0 (GPLv3). The full license text is available in the LICENSE file.

Contact Information

For bug reports or inquiries, please submit an issue on GitHub or contact:

Edric Matwiejew Email: edric.matwiejew@research.uwa.edu.au