Tools for symbolically analyzing quantum feedback networks.
The QNET package is a set of tools created and compiled to aid in the design and analysis of photonic circuit models. Our proposed Quantum Hardware Description Language (cf. QHDL) serves to describe a circuit topology and specification of a larger entity in terms of parametrizable subcomponents. This is strongly analogous to the specification of electric circuitry using the structural description elements of VHDL or Verilog. The physical systems that can be modeled within the framework include quantum optical experiments that can be described as nodes with internal degrees of freedom such as interacting quantum harmonic oscillators and/or N-level quantum systems that, in turn are coupled to a finite number of external bosonic quantum fields.
To get help installing and using QNET, please read this README, visit our homepage which includes the official documentation, sign up to our mailing list, or consult and perhaps contribute to our wiki.
The package consists of the following components:
- A symbolic computer algebra package qnet.algebra for Hilbert Space quantum mechanical operators, the Gough-James circuit algebra and also an algebra for Hilbert space Ket-states and Super-operators which themselves act on operators.
- The QHDL language definition and parser qnet.qhdl including a front-end located at bin/parse_qhdl.py that can convert a QHDL-file into a circuit component library file.
- A library of existing primitive or composite circuit components qnet.circuit_components that can be embedded into a new circuit definition.
In addition to these core components, the software uses the following existing software packages:
- Python version 2.6 or higher. QNET is still officially a Python 2 package, but migration to Python 3 should not be too hard to achieve.
- The gEDA toolsuite for its visual tool gschem for the creation of circuits end exporting these to QHDL gnetlist. We have created device symbols for our primitive circuit components to be used with gschem and we have included our own gnetlist plugin for exporting to QHDL.
- The SymPy symbolic algebra Python package to implement symbolic ‘scalar’ algebra, i.e. the coefficients of state, operator or super-operator expressions can be symbolic SymPy expressions as well as pure python numbers.
- The QuTiP python package as an extremely useful, efficient and full featured numerical backend. Operator expressions where all symbolic scalar parameters have been replaced by numeric ones, can be converted to (sparse) numeric matrix representations, which are then used to solve for the system dynamics using the tools provided by QuTiP.
- The PyX python package for visualizing circuit expressions as box/flow diagrams.
- The SciPy and NumPy packages (needed for QuTiP but also by the qnet.algebra package)
- The PLY python package as a dependency of our Python Lex/Yacc based QHDL parser.
A convenient way of obtaining Python as well as some of the packages listed here (SymPy, SciPy, NumPy, PLY) is to download the Anaconda Python Distribution which is free for academic use. A highly recommended way of working with QNET and QuTiP and just scientific python codes in action is to use the excellent IPython shell which comes both with a command-line interface as well as a very polished browser-based notebook interface.
Copy the QNET folder to any location you’d like. We will tell python how to find it by setting the $PYTHONPATH environment variable to include the QNET directory’s path. Append the following to your local bash configuration $HOME/.bashrc or something equivalent:
export QNET=/path/to/cloned/repository export PYTHONPATH=$QNET:$PYTHONPATH
Note that you should replace “/path/to/cloned/repository” with the full path to the cloned QNET directory! On my personal laptop that path is given by /Users/nikolas/Projects/QNET, but you can place QNET anywhere you’d like.
On Windows a similar procedure should exist. Environment variable can generally be set via the windows control panels. It should be sufficient to set just the $PYTHONPATH environment variable.
To configure gEDA to include our special quantum circuit component symbols you will need to copy the following configuration files from the $QNET/gEDA_support/config directory to the $HOME/.gEDA directory:
Then install the QHDL netlister plugin within gEDA by creating a symbolic link
ln -s $QNET/gEDA_support/gnet-qhdl.scm /path/to/gEDA_resources_folder/scheme/gnet-qhdl.scm
Note that you should replace “/path/to/gEDA_resources_folder” with the full path to the gEDA resources directory!
in my case that path is given by /opt/local/share/gEDA, but in general simply look for the gEDA-directory that contains the file named system-gafrc.
Using QNET in practice
A possible full workflow using QNET is thus:
- Use gschem (of gEDA) to graphically design a circuit model.
- Export the schematic to QHDL using gnetlist (also part of gEDA)
- Parse the QHDL-circuit definition file into a Python circuit library component using the parser front-end bin/parse_qhdl.py.
- Analyze the model analytically using our symbolic algebra and/or numerically using QuTiP.
This package is still work in progress and as it is developed by a single developer, documentation and comprehensive testing code is still somewhat lacking. Any contributions, bug reports and general feedback from end-users would be highly appreciated. If you have found a bug, it would be extremely helpful if you could try to write a minimal code example that reproduces the bug. Feature requests will definitely be considered. Higher priority will be given to things that many people ask for and that can be implemented efficiently.
To learn of how to carry out each of these steps, we recommend looking at the provided examples and reading the relevant sections in the QNET manual. Also, if you want to implement and add your own primitive device models, please consult the QNET manual.
Hideo Mabuchi had the initial idea for a software package that could exploit the Gough-James SLH formalism to generate an overall open quantum system model for a quantum feedback network based solely on its topology and the component models in analytic form. The actual QNET package was then planned and implemented by Nikolas Tezak. In its current form, QNET comprises functionality  that goes well beyond what would be necessary to achieve the original goal, but which has proven to be immensely useful. In addition to the authors of the software packages listed under Dependencies that QNET relies on, we would like to acknowledge the following people’s direct support to QNET which included their vision, ideas, examples, bug reports and feedback.
- Michael Armen
- Armand Niederberger
- Joe Kerckhoff
- Dmitri Pavlichin
- Gopal Sarma
- Ryan Hamerly
- Michael Hush
Work on QNET was directly supported by DARPA-MTO under Award No. N66001-11-1-4106. Nikolas Tezak is also supported by a Simons Foundation Math+X fellowship as well as a Stanford Graduate Fellowship.
|||E.g., all algebras except the operator algebra are not strictly necessary to achieve just the original objective.|
QNET is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
QNET is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along with QNET. If not, see this page.
Copyright (C) 2012, Nikolas Tezak