Skip to main content

A tool to treat noise on graph states.

Project description

Noisy graph states

PyPI Documentation Status Tests DOI

This python package is a tool to track how noisy graph states transform under operations and measurements (for an introduction to graph states see e.g. arXiv:quant-ph/0602096). It uses the Noisy Stabilizer Formalism introduced in

Noisy stabilizer formalism
M. F. Mor-Ruiz, W. Dür
Phys. Rev. A 107, 032424 (2023); DOI: 10.1103/PhysRevA.107.032424
Preprint: arXiv:2212.08677 [quant-ph]

that describes how Pauli-diagonal noise on graph states transforms under various graph operations, such as local complementation, Pauli measurements and merging operations.

Installation

You can install the package into your Python environment from the Python Package Index:

pip install noisy-graph-states

As with all Python packages this can possibly overwrite already installed package versions in your environment with its dependencies, so installing it in a dedicated virtual environment may be preferable.

If you encounter any problems, you can try installing the exact versions of the dependencies of this package, which were used to develop it (specified in Pipfile.lock). This assume Python 3.9 and pipenv are available on your system.

git clone https://github.com/jwallnoefer/noisy_graph_states.git
cd noisy_graph_states
git checkout main
pipenv sync
pipenv install .

Then you can activate the virtual environment with pipenv shell.

Documentation

The documentation can be built from source with Sphinx, but it is also hosted at https://noisy-graph-states.readthedocs.io

Motivation

There are many protocols in quantum information science that are based on graph states and transformations of graph states. In any realistic scenario noise and imperfections have to be taken into account in order to analyse the performance of such protocols.

While there are existing tools for dealing with stabilizer states and Clifford circuits, it can be useful to stay within the graph state interpretation for the whole protocol. Furthermore, our approach allows us to explicitly obtain the density matrix of the output state without the need to sample from it.

Working principle

Instead of updating the density matrix, instead track how the noise on the state transforms along with the graph state transformation.

For some cases of noise (such as local noise acting on the initial state before operations are performed) the Noisy Stabilizer Formalism allows to do this very efficiently (updating O(n) noises instead of exponentially many density matrix entries).

The main insight here is that the noise channels can be tracked individually instead of being combined to one global channel, e.g. local depolarizing noise on every qubit is highly structured, but nonetheless a full rank noise channel viewed in a global picture.

However, note that this efficiency increase is not guaranteed in general, as with the general correlated noise, one inevitably needs to track exponentially many entries again.

Use of the code

The noisy graph state package was used for these publications:

Imperfect quantum networks with tailored resource states
M. F. Mor-Ruiz, J. Wallnöfer, W. Dür
Published version: Quantum 9, 1605 (2025).

Merging-Based Quantum Repeater
M. F. Mor-Ruiz, J. Miguel-Ramiro, J. Wallnöfer, T. Coopmans, and W. Dür
Preprint: arXiv:2502.04450 [quant-ph];

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

noisy_graph_states-0.4.tar.gz (59.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

noisy_graph_states-0.4-py3-none-any.whl (26.1 kB view details)

Uploaded Python 3

File details

Details for the file noisy_graph_states-0.4.tar.gz.

File metadata

  • Download URL: noisy_graph_states-0.4.tar.gz
  • Upload date:
  • Size: 59.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.8

File hashes

Hashes for noisy_graph_states-0.4.tar.gz
Algorithm Hash digest
SHA256 c0e0e081933f143049403eb6eda44af8e77c2f61e8b04d2470b47c69ac361637
MD5 2a740ddc5cee518a95b91273ed085cf3
BLAKE2b-256 7c9327866ed8393fdd3cdfe3aafda464081cc2230b5276e048e2869fce7c146e

See more details on using hashes here.

File details

Details for the file noisy_graph_states-0.4-py3-none-any.whl.

File metadata

File hashes

Hashes for noisy_graph_states-0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 2b3ffc20c48c7ad09425348b738d8727694062924d055800e958d462acb87550
MD5 604d25e15b1e9966baf9af5bcb321a1f
BLAKE2b-256 e281ac33a0070389a66091985305d977306875ed45df3de9709946e74edda114

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page