Skip to main content

A timeline debugger for the qiskit transpiler

Reason this release was yanked:

An import issue in qiskit-ibm-provider and fixed some bugs

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.0.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.0-py3-none-any.whl (62.9 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: qiskit_trebugger-1.1.0.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.0.tar.gz
Algorithm Hash digest
SHA256 34636fd6a4cb9e5041acaeb52f8b232e6687b1171bafd7192590b9eb0db86f05
MD5 85666a6fe3a6f1bd0ea21d836b1f3185
BLAKE2b-256 54ce7544f738dd884919fca0256ddd0ad931bc05fa6f3e625c2e20ec7a707947

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for qiskit_trebugger-1.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 6a56f52ac46468350bc1e269cb93226858987c470820df92e157a21b5e8a43dc
MD5 e39a2a67087da3bdb123e15eecc430e4
BLAKE2b-256 2f581f164162b21a4dc086b8947d94de850b0176f5421956e993dc6012246756

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