Our Qiskit Advocate Mentorship Project for Spring, 2022 is a Transpiler Hackathon.
Our Github organization is here.
View this document formatted on GitHub Pages
- QAMP Spring 2022 Transpiler Hackathon
- Table of Contents
TOC created by gh-md-toc
- Final year undergrad student in computer science
- Took part in a summer school on compiler analysis
- Trained computer vision edge based products
- Very interested in the transpiler and simulators.
- Part of QAMP Fall 2021
- Résumé
- QAMP Fall 2021 with Aboulkhair Foda under the mentorship of Kevin Krsulich wrote Transpiler Debugger
- 4th year Mathematics Major at Indian Institute of Science
- Silver medal at IMO 2018
- 2nd in the ICPC Quantum Challenge 2021
- 3rd in IBM Quantum Challenge Fall 2020
- Working under Prof. Ashwin Nayak from University of Waterloo (IQC) on research problems in Quantum Learning Theory
- Résumé
- PhD student in mathematical aspects of quantum computing
- MSc in Math
- Two publications in Quantum Journal
- Open-source contributions, e.g. QREM
- Programming 40 years
- Open Source author
- Contributing editor 1991-2011 Dr. Dobb's Journal
- Qiskit Advocate since 2019
- IBM Champion 2021-2022
- Current secretary of of the OpenQASM 3 Technical Steering Committee
In attendance Harshit Gupta, Oskar Słowik, Jack Woehr, Matthew Treinish
- PRs
- 7913 merged
- 7990 ready for review
- 7879 ready for review
- 7875 had review, needs work, less substantial than work on issue 7485
- Issues
- 7485
- 7705
- Harshit
- Regression from PR 7181 (merged)
- Issue 7485
- Oskar
- Graphs to show Matthew
- Work on 7705
- All
- Discuss May 5 overview on Slack
- Matthew
- Team can help on reviews
- Look at open Transpiler PRs
- provide feedback
- familiarize self with code and see where things are going
- team can see bugs as well as anyone
- Harshit
- Exams May 5 - May 15
- Oskar & Jack
- Meet via Slack during Harshit's hiatus for exams.
In attendance Harshit Gupta, Oskar Słowik, Jack Woehr
PR 7193 for 7181 - Harshit submitted substantial improvements PR 7875 for 7296 - Harshit submitted ... work in progress ...add Gate attribute qubit_symmetric 7113 .. if PR 7193 gets accepted would simplify tackling 7113. 7705 .. Oscar benchmarking 7485 .. BasisTranslator taking up to 1G of memory ... attractive and substantial issue because level 1,2,3 all use BasisTranslator
- Examine where should we place the check for the symmetric qargs in the InverseCancellation pass? - Harshit
- With 7181 working pretty good now, one thought is that should we try to make it target aware? Matthew had included it in the list of passes to make target aware and since Harshit got a bit familiar with it during optimization, he will try doing that.
- Continue 7705 Discover some parameters for the tuning of the time for search - Oskar
- 7485 - Oskar
- Jack will keep lines of communication open with IBM team.
Our Checkpoint #1 presentation PDF
In attendance Harshit Gupta, Oskar Słowik, Jack Woehr
- 8-10 slides
- We first try to give brief overview of the transpiler, where it is situated, how it works and what are its major components
- Then move on to the goals of our project and discuss how we are going to contribute to the qiskit transpiler
- After that, bring in our project plan - working on two major issues and being helpful on the side.
- At the end, show the current PRs and our progress on the issues, to show proof of initial work.
- Questions
- Jack -- intro slide, project plan slide
- Oskar, Harshit -- 2 issues slides each
- Jack -- slide for link to blog
- 7296 .. PR 7875 ready for review
- 7386 .. PR 7542 was merged
- 7387 .. stalled
- 7705 .. Oskar to continue on this
- 7181 .. Oskar and Harshit take this one up after presentation
- 7113 .. Deal with this after 7181
In attendance Vishnu Ajith, Harshit Gupta, Oskar Słowik, Jack Woehr
We discussed an apparent anomaly in DAG generation as exemplified by Harshit's example:
from qiskit.converters import circuit_to_dag
from qiskit import QuantumCircuit
from qiskit.circuit import QuantumRegister, ClassicalRegister
from qiskit.visualization import dag_drawer
qr = QuantumRegister(3)
cr = ClassicalRegister(3)
circ_reg = QuantumCircuit(qr, cr)
circ_reg.h(qr[0])
circ_reg.h(qr[1])
circ_reg.measure(qr[0], cr[0])
circ_reg.measure(qr[1], cr[1])
circ_reg.x(qr[0]).c_if(cr, 0x3)
circ_reg.measure(qr[0], cr[0])
circ_reg.measure(qr[1], cr[1])
circ_reg.measure(qr[2], cr[2])
# direct
circ_no_reg = QuantumCircuit(3, 3)
circ_no_reg.h([0, 1])
circ_no_reg.measure([0, 1, 2], [0, 1, 2])
circ_no_reg.x(0).c_if(circ_no_reg.cregs[0], 0x3)
circ_no_reg.measure([0, 1], [0, 1])
# print("Circuit is :", circ_no_reg.draw())
dag_in = circuit_to_dag(circ_no_reg)
dag_in_reg = circuit_to_dag(circ_reg)
dag_drawer(dag_in, scale=0.7, filename="dag_in_no_reg.png")
dag_drawer(dag_in_reg, scale=0.7, filename="dag_in_with_reg.png")
The circuits are semantically equivalent but draw quite different DAGs. Harshit will run this by Matthew Treinish.
-
Previously we had looked at how to write benchmarks for different mappings w/r/t #7705 Add adaptive limits for VF2Layout in preset passmanagers
- Oskar start working on tools for benchmarking for #7705.
- Can have substantial progress (Harshit)
- Harshit has some code to send Oskar as a template for writing the benchmarking code.
-
We were also intending to work on #7113 Add support for BackendV2 and Target to transpiler
- Current IBM backend devices seem to have mostly Heavy Hex mapping.
- Earlier QPUs had Heavy Square
- Vishnu on #7113
-
Harshit still working on #7387
- Possibility of reaching a dead end in an intrinsic difficulty problem.
- Polling Kevin and Matthew
-
Structure with fork and branches is good
-
Metric of our effort is PR's: reviews and acceptance
In attendance Harshit Gupta, Pulkit Sinha, Jack Woehr
Focus on parallelization / depth reduction pass
There are promising heuristic strategies but not all guarantee either a solution nor an optimal solution.
Create transpiler pass DagDependencyReducer which will wrapper 3 algorithms
- GlobalMaxDAGDepthReducer
- InteractiveDAGDepthReducer
- IterativeDAGDepthReducer
The 3 algorithms will be coded (at first) in individual files. The question arose in the discussion whether the team should present 3 separate PRs for the 3 algorithms. We decided that we should submit as one PR and let the IBM engineers decide how to mix and match.
- Create local branch
dagdependencyreducer
- Check in an empty Transpiler pass as
dagdependencyreducer.py
- Push branch to our fork.
- Team clones our
qiskit-terra
fork. - Team does
git fetch
thengit checkout dagdependencyreducer
- From the
dagdependencyreducer
branch, create sub-branches of the branch as follows: git checkout -b GlobalMaxDAGDepthReducer
git push -u origin GlobalMaxDAGDepthReducer
- Repeat from
dagdependencyreducer
branch forInteractiveDAGDepthReducer
andIterativeDAGDepthReducer
As work progresses on individual sub-branches, the team can:
- commit and stash changes
- checkout the parent branch
dagdependencyreducer
and start building out the masterDagDependencyReducer
class indagdependencyreducer.py
- commit and push the
dagdependencyreducer
branch - checkout the sub-branch and merge the parent branch by
git merge dagdependencyreducer
Continue development …
- Incorporate qubit args in the GlobalMaxDAGDepthReducer (Harshit)
- Write basic code for InteractiveDAGDepthReducer and IterativeDAGDepthReducer (Pulkit)
Our team met today with Kevin Krsulich of the IBM Q team to examine promising transpiler issues to address. Two major issues that came up in discussion are:
- Add adaptive limits for VF2Layout in preset passmanagers
- The transpiler VF2Layout component, if successful, is very effective, but if unsuccessful, can take a long time to fail. This can be partly addressed by proving the user with a "knob" to dial back how long or how many tries VF2Layout takes before giving up. Currenty, there are fixed time limits, but such limits to be effective need to be sensitive to device size and input circuit size. We need examples of perfect layouts which are hard to solve within the current mapping. The solution to the problem is driven by different applications, demonstrations, and examples. There does not yet exist a sufficient body of benchmarks. There are a few papers on VF2, but experimentation will be needed to yield substantial improvement.
- Add support for BackendV2 and Target to transpiler
- The previous version, Backend V1, is still in use in most places, and deals with configuration, coupling, and basis gates. Backend V2 extends these notions and provides better support for different hardware architectures, e.g., ion traps, which are not well represented by V1. V2 is more general,and expresses gates independently. Support for V2 within existing transpiler passes very limited. All passes must be updated for V2: this one issue will spawn nultiple PRs. The effort is made difficult in that there exists many hard-coded assumptions in the transpiler code.
Additionally, team member Harshit Gupta is currently finishing up work he previously undertook on the following to issues:
For this coming week, the team is going to all work together on finishing up issue 7387 ("better convergence") with Harshit, in part, to become oriented in the transpiler. Then we will proceed to one of the major issues, either dividing into two groups to address both 7705 and 7113, or working together on one or both of those issues.
Our team may also undertake inter alia to address a few smaller issues that can more easily be closed. Jack Woehr will sift through the transpiler issues for smaller issues.
Our team of Harshit Gupta, Vishnu Ajith, Oskar Słowik, and Jack Woehr met today via Zoom. We discussed the following points
- The 3 aspects of the Qiskit Transpiler
- Coupling map
- Basis gates
- Optimization
-
Circuit optimization may be a paradigmatic example of quantum computation
-
Current devices at our disposal are probably not powerful enough to achieve much in this respect. But see this discussion about performing certain transpiler passes on the quantum device itself.
-
Tackle Qiskit Terra transpiler issues as recommended by the IBM Qiskit Team, particularly
- Matthew Treinish
- Kevin Krsulich
-
We have no specific goal other than to be useful to Qiskit Transpiler development. We may find ourselves performing any mixture of the following:
- PR many small issues
- Work as a team on one or more major issues
- Invent a new feature ourselves
-
We will meet weekly starting 2022-03-14
Matthew Treinish requests that the team help out with #7113 Add support for BackendV2 and Target to transpiler