Skip to main content

A timeline debugger for the qiskit transpiler

Project description

Qiskit Trebugger

Unitary Fund

A new take on debuggers for quantum transpilers. This repository presents a debugger for the qiskit transpiler in the form of a light weight jupyter widget. Built as a project for the Qiskit Advocate Mentorship Program, Fall 2021.

Installation

  1. To install the debugger using pip (a python package manager), use -
pip install qiskit-trebugger

PIP will handle the dependencies required for the package automatically and would install the latest version.

  1. To directly install via github follow the steps below after using git clone:
git clone https://github.com/TheGupta2012/qiskit-timeline-debugger.git
  • Make sure python3 and pip are installed in your system. It is recommended to use a python virtual environment to install and develop the debugger
  • cd into the qiskit-timeline-debugger directory
  • Use pip install -r requirements.txt to install the project dependencies
  • Next, execute pip install . command to install the debugger

Usage Instructions

  • After installing the package, import the Debugger instance from qiskit_trebugger package.
  • To run the debugger, simply replace the call to transpile() method of the qiskit module with debug() method of your debugger instance.
  • The debugger provides two types of views namely jupyter and cli
  • The cli view is the default view and recommender for users who want to use the debugger in a terminal environment
  • The jupyter view is recommended for usage in a jupyter notebook and provides a more interactive and detailed view of the transpilation process.
  • For an example -
from qiskit.providers.fake_provider import FakeCasablanca
from qiskit.circuit.random import random_circuit 
from qiskit_trebugger import Debugger
import warnings

warnings.simplefilter('ignore')
debugger = Debugger(view_type = "jupyter")
backend = FakeCasablanca()
circuit = random_circuit(num_qubits = 4, depth = 5 , seed = 44)
# replace transpile call 
debugger.debug(circuit, optimization_level = 2, backend = backend, initial_layout = list(range(4)))
  • On calling the debug method, a new jupyter widget is displayed providing a complete summary and details of the transpilation process for circuits of < 2000 depth
  • With an easy to use and responsive interface, users can quickly see which transpiler passes ran when, how they changed the quantum circuit and what exactly changed.

Feature Highlights

jupyter view

1. Circuit Evolution

  • See your circuit changing while going through the transpilation process for a target quantum processor.
  • A new custom feature enabling visual diffs for quantum circuits, allows you to see what exactly changed in your circuit using the matplotlib drawer of the qiskit module.

Example

  • Circuit 1
  • Circuit 2

2. Circuit statistics

  • Allows users to quickly scan through how the major properties of a circuit transform during each transpilation pass.
  • Helps to quickly isolate the passes which were responsible for the major changes in the resultant circuit.

3. Transpiler Logs and Property sets

  • Easily parse actions of the transpiler with logs emitted by each of its constituent passes and changes to the property set during transpilation
  • Every log record is color coded according to the level of severity i.e. DEBUG, INFO, WARNING and CRITICAL.

cli view

1. Transpilation Summary and Statistics

  • A quick summary of the transpilation process for a given circuit.
  • Faster access to information in the CLI view.

2. Keyboard Shortcuts

  • The CLI view provides keyboard shortcuts for easy navigation and access to transpiler information.
  • An interactive status bar at the bottom of the screen provides information about the current state of the debugger.

3. Transpiler Logs and Property sets

  • Emits transpiler logs associated with each of the transpiler passes.
  • Highlights addition to property set and its changes during the transpilation process.

Demonstration and Blog

Contributors

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

qiskit_trebugger-1.1.1.tar.gz (17.8 MB view details)

Uploaded Source

Built Distribution

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

qiskit_trebugger-1.1.1-py3-none-any.whl (63.0 kB view details)

Uploaded Python 3

File details

Details for the file qiskit_trebugger-1.1.1.tar.gz.

File metadata

  • Download URL: qiskit_trebugger-1.1.1.tar.gz
  • Upload date:
  • Size: 17.8 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.6

File hashes

Hashes for qiskit_trebugger-1.1.1.tar.gz
Algorithm Hash digest
SHA256 a833317bcfc9511a6234e881698780231ad946bafd535b6213eaff106143fee9
MD5 dc6189706aa1510536a2d34015781ed8
BLAKE2b-256 c1384ec8442b1ac2c49706646bad88e8181e827578140b6937de950d20ca8ee9

See more details on using hashes here.

File details

Details for the file qiskit_trebugger-1.1.1-py3-none-any.whl.

File metadata

File hashes

Hashes for qiskit_trebugger-1.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 b5d4d10901aa125612df39b2672f4b6218a9df837ea24890ebc628579e761509
MD5 28d0ac161970cc6d086e8c2050ed1dc9
BLAKE2b-256 0a8126109ed9c2a27aafe58c48a04fff6701e4f21f89ac4ec24cb09f0087130f

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