Skip to main content

Construct and simulate partitioned quantum cellular automata

Project description

PQCA (Partitioned Quantum Cellular Automata)

A quantum cellular automaton iteratively applies some update circuit to some initial state. A partitioned quantum cellular automaton (PQCA) derives its update circuit by partitioning a lattice of qubits into cells, and then applying the same circuit to each cell. The full update circuit is created by composing several such partitioned updates. There is a review of Quantum Cellular Automata by Terry Farrelly, published in Quantum, and available at doi:10.22331/q-2020-11-30-368.

This python module allows for the easy creation and execution of partitioned quantum cellular automata. To create an automaton you will need:

  • A starting state (list of 0s and 1s)
  • Update Frames (see pqca.update_frame)
  • A simulator / quantum computer (see pqca.backend)

An Update Frame combines a tessellation with a circuit to be applied to each cell in that tessellation. A tessellation just partitions a list of qubits into cells. For example pqca.tessellation.one_dimensional(10,2) partitions 10 qubits into 5 cells, each of size 2. The Update Frame would then need to be a circuit on 2 qubits. For more complicated tessellations you can use, e.g. pqca.tessellation.n_dimensional([4,2,4],[2,2,2]) which partitions 32 qubits as though they were arranged in a lattice of shape 4 x 2 x 4, with each cell of size 2 x 2 x 2. The Update Frame would then need to be a circuit on 8 qubits.

One can then call next(automaton) which will advance the internal state of the automaton and return the new state.

Installation

Install via pip from the command line with the command:

pip install pqca

Example

Here is an example that creates two update frames, both applying a simple CX gate, but with offset tessellations.

# Create circuit
cx_circuit = qiskit.QuantumCircuit(2)
cx_circuit.cx(0, 1)

# Create tessellation
tes = pqca.tessellation.one_dimensional(10, 2)

# Create update frames
update_1 = pqca.UpdateFrame(tes, cx_circuit)
update_2 = pqca.UpdateFrame(tes.shifted_by(1), cx_circuit)


# Create initial state
initial_state = [1]*10

# Specify a backend; `pqca.backend.qiskit()` returns IBM's Aer simulator by default
# See backend.py for more details and instructions on coding your own backend
backend = pqca.backend.qiskit()

# Create the automaton
automaton = pqca.Automaton(initial_state, [update_1, update_2], backend)

# The automaton can be called like any other iterator
# The following line advances the internal state, and returns the new state
next(automaton)

Documentation

Detailed documentation can be found at readthedocs.io as well as in the docstrings of the python files themselves.

Licensing

The source code is available under the MIT licence and can be found on Hector Miller-Bakewell's github.

Acknowledgements

This package was created as part of the QuTune Project.

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

pqca-1.0.3.tar.gz (11.8 kB view details)

Uploaded Source

Built Distribution

pqca-1.0.3-py3-none-any.whl (14.3 kB view details)

Uploaded Python 3

File details

Details for the file pqca-1.0.3.tar.gz.

File metadata

  • Download URL: pqca-1.0.3.tar.gz
  • Upload date:
  • Size: 11.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.6

File hashes

Hashes for pqca-1.0.3.tar.gz
Algorithm Hash digest
SHA256 3045ca6fec95d071fb4d438c3f46001ca1e7b6d18e1756043d7044b96da6bc4d
MD5 0f8451b153e764e8b0dd9bf5caddf5dd
BLAKE2b-256 3e73937282cd0aa868359e9dcffcf3b51b9473caf846594c31404c0b6018a701

See more details on using hashes here.

File details

Details for the file pqca-1.0.3-py3-none-any.whl.

File metadata

  • Download URL: pqca-1.0.3-py3-none-any.whl
  • Upload date:
  • Size: 14.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.6

File hashes

Hashes for pqca-1.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 a117c3f1ce4d239a58023aec5337ecf353cf60fd331a0be1b195c31205b9a2b9
MD5 8464f7255b9ffe17584ba832361e7bef
BLAKE2b-256 04225bf7727daf6fd396501c8a7b860f1d0ce4438a2118c376bee4c2a22c4c71

See more details on using hashes here.

Supported by

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