Skip to main content

An OpenQASM visualisation tool

Project description

The qasm2image repository provides functions to represent quantum circuits written following the OpenQASM specification.

Installation

Dependencies

The tool and all the dependencies are available via the PIP tool. See the installation instructions below.

Installation procedure

pip3 install cffi
pip3 install qasm2image

Usage

In a Python environnement

# Import the functions
from qasm2image import qasm2svg
from qasm2image import qasm2png
# Generate your QASM string (either read from a file or generate a circuit and ask for its QASM).
qasm_str = "..."
# Define the basis used to represent the circuit
basis = 'u1,u2,u3,U,cx'
# Compute the SVG representation
svg_str = qasm2svg(qasm_str, basis=basis, show_clbits=True)
# Compute the PNG representation
png_bytes = qasm2png(qasm_str, basis=basis, show_clbits=True)
# Types of the outputs
assert type(svg_str) is str
assert type(png_bytes) is bytes
# Write the result into files
with open('circuit.svg', 'w') as svg_file:
    svg_file.write(svg_str)
# Don't forget to write in *binary* mode for PNG
with open('circuit.png', 'wb') as png_file:
    png_file.write(png_bytes)

In a shell environnement

A script is provided to change QASM code directly from the command line.

$ qasm2image -h
usage: qasm2image [-h] [-b BASIS] [--hide-clbits] [-s SCALE]
                  input_file output_file

Transform a quantum circuit in QASM format to an image format.

positional arguments:
  input_file            the QASM file implementing the circuit to transform
  output_file           the image file that will be generated by the tool

optional arguments:
  -h, --help            show this help message and exit
  -b BASIS, --basis BASIS
                        a comma-separated list of gate names which represent
                        the gate basis in which the circuit will be decomposed
  --hide-clbits         if present, classical bits will not be represented
  -s SCALE, --scale SCALE
                        scale of the PNG image. SVG output is not affected by
                        this parameter

License

This project is distributed under the CeCILL-B license. A copy of the whole license is included in the repository.

In order to use the work in this repository you have a strong obligation to cite (as stated in the license):

  1. The author of the work: Adrien Suau (see on my GitHub page or mail me if any doubt).

  2. The CERFACS (Centre Européen de Recherche et de Formation Avancée en Calcul Scientifique).

Output

adder.qasm

adder.png

qft.qasm

qft.png

inverseqft1.qasm

inverseqft1.png

inverseqft2.qasm

inverseqft2.png

qec.qasm

qec.png

The same QASM code, but with the hide-clbits option set: qasm2image --hide-clbits qec.{qasm,png}.

qec\_no\_clbits.png

teleportv2.qasm

teleportv2.png

Project details


Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

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

qasm2image-0.4.2-py3-none-any.whl (25.5 kB view details)

Uploaded Python 3

File details

Details for the file qasm2image-0.4.2-py3-none-any.whl.

File metadata

File hashes

Hashes for qasm2image-0.4.2-py3-none-any.whl
Algorithm Hash digest
SHA256 b18f319d504ed035d67afb805b9bd43d15534542c6e15133dc810fe13c907d53
MD5 717f493252e56f7ffdda6902b279ff45
BLAKE2b-256 dd77d55fff44e86e36710976b82149d5b43476f5a423dc4b375a6498a0a8f935

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