Skip to content

Latest commit

 

History

History
258 lines (195 loc) · 10.3 KB

README.md

File metadata and controls

258 lines (195 loc) · 10.3 KB

license stars contributors pr-welcome g++-10 gfortran-10

Qsyn: An End-to-End Quantum Circuit Synthesis Framework

Introduction

Qsyn is a C++ based growing software system for synthesis, optimization and verification of quantum circuits appearing in quantum computers. Qsyn implements scalable quantum circuits optimization by combining ZX-Calculus and technology mapping.

Qsyn provides an experimental implementation of optimization algorithms and a programming environment for simulation or building similar applications. Future development will focus on enhancing the algorithms, and visualization of ZX-graphs.

Third party dependencies

  • xtensor, xtensor-blas for tensor calculation
  • tqdm for progress bar pretty-printing
  • pdflatex for outputting pdf files

Getting Started

Installation

git clone https://github.com/ric2k1/qsyn.git
cd qsyn

Visualization (optional for ZXGDraw)

sudo apt-get install texlive-latex-base

System Requirements

  • Linux (recommended): Qsyn requires g++-10 and gfortran-10 to compile. The two compilers should also be on the same version.
  • MacOS: Qsyn can also be compiled with Apple Clang (which, by default, is what gets called when invoking g++) with version 13.1.7 and up. However, note the following caveats:
    • You may need to install OpenMP via HomeBrew or MacPort, and link/add the headers and libraries into compiler search path.
    • Due to differences in c++ standard implementation, there might be some deviations in the output of Apple Clang-compiled program from their g++-compiled counterparts.

Compilation

CMake

qsyn uses CMake manage the dependencies:

  1. create a build directory to store CMake files

    mkdir build
    cd build
    
  2. run CMake to generate Makefiles, if this step fails, you might have to install blas and lapack libraries

    cmake ..
    
  3. run make to build up the executable, you would want to crank up the number of threads to speed up the compilation process

     make -j16
    

Makefile (to be deprecated)

qsyn can also be built with the old-school "configure-then-make" way. However, note that this way of managing the build is planned to be deprecated in the future.

  1. Qsyn depends on xtensor and xtensor-blas. To install these dependencies, run configure.sh, which checks for lacking dependencies and install them automatically.
    sudo ./configure.sh
    
  2. Then, run make to build up the executable.
    make -j16
    
    or
    gmake -j16
    
    if you are on MacOS.
  3. If the compilation process ends successfully, you will see
    > building qsyn...
    ~/qsyn$ _
    
  4. To delete all intermediate files created in the compilation process, please type
    make clean
    

Run

  • After successful compilation, you can call the command-line interface of Qsyn where you can execute commands implemented into Qsyn.

     ❯ ./qsyn
     DV Lab, NTUEE, Qsyn 0.4.0
     qsyn>
    
  • To run the demo program, you can provide a file containing commands. For example:

    ❯ ./qsyn -f tests/demo/demo/dof/tof_3.dof
    DV Lab, NTUEE, Qsyn 0.4.0
    qsyn> verb 0
    Note: verbose level is set to 0
    
    qsyn> zxgread benchmark/zx/tof3.zx
    
    qsyn> zxgs -freduce
    
    qsyn> zxgp
    Graph 0( 3 inputs, 3 outputs, 17 vertices, 19 edges )
    
    qsyn> qq -f
    
  • The same result can be produced by running in the command-line mode:

    ❯ ./qsyn
    DV Lab, NTUEE, Qsyn 0.4.0
    qsyn> dofile tests/demo/demo/dof/tof_3.dof
    
    qsyn> verb 0
    Note: verbose level is set to 0
    
    qsyn> zxgread benchmark/zx/tof3.zx
    
    qsyn> zxgs -freduce
    
    qsyn> zxgp
    Graph 0( 3 inputs, 3 outputs, 17 vertices, 19 edges )
    
    qsyn> qq -f
    

Testing

We have provided some DOFILEs, i.e., a sequence of commands, to serve as functionality checks as well as demonstration of use. DOFILEs are Located under tests/<section>/<subsection>/dof/.

  • To run a DOFILE and compare the result to the reference, type
    ./DOFILE.sh <path/to/test> -d
    
  • To update the reference to a dofile, type
    ./DOFILE.sh <path/to/test> -up
    
  • You may also run all DOFILEs by running bash! ./RUN_ALL_TEST.sh Notice that if you use Apple Clang to compile Qsyn, some of the DOFILEs may produce different results, which is to be expected.

License

Apache License 2.0

Commands List

Info

Command Description Options
COLOR toggle colored printing (1: on, 0: off)
DOfile execute the commands in the dofile
HELp print this help message
HIStory print command history
QQuit quit Qsyn
SEED fix the seed
USAGE report the runtime and/or memory usage
VERbose set verbose level to 0-9 (default: 3)

QCir

Command Description Options
QC2TS convert QCir to tensor
QC2ZX convert QCir to ZX-graph
QCBAdd add qubit(s)
QCBDelete delete an empty qubit
QCCHeckout checkout to QCir in QCirMgr
QCCOMpose compose a QCir
QCCOPy copy a QCir
QCCPrint print info of QCir
QCCRead read a circuit and construct the corresponding netlist
QCCWrite write QCir to a QASM file
QCDelete remove a QCir from QCirMgr
QCGAdd add quantum gate
QCGDelete delete quantum gate
QCGPrint print gate info in QCir
QCNew create a new QCir to QCirMgr
QCPrint print info of QCirMgr
QCReset reset QCirMgr
QCTensor tensor a QCir

Graph

Command Description Options
ZX2QC extract QCir from ZX-graph
ZX2TS convert ZX-graph to tensor
ZXCHeckout checkout to Graph in ZXGraphMgr
ZXCOMpose compose a ZX-graph
ZXCOPy copy a ZX-graph
ZXDelete remove a ZX-graph from ZXGraphMgr
ZXGADJoint adjoint ZX-graph
ZXGASsign assign quantum states to input/output vertex
ZXGDraw draw ZX-graph
ZXGEdit edit ZX-graph
ZXGGFlow calculate the generalized flow of current ZX-graph
ZXGPrint print info of ZX-graph
ZXGRead read a file and construct the corresponding ZX-graph
ZXGSimp perform simplification strategies for ZX-graph
ZXGTest test ZX-graph structures and functions
ZXGTRaverse traverse ZX-graph and update topological order of vertices
ZXGWrite write a ZX-graph to a file
ZXNew create a new ZX-graph to ZXGraphMgr
ZXPrint print info of ZXGraphMgr
ZXReset reset ZXGraphMgr
ZXTensor tensor a ZX-graph

Tensor

Command Description Options
TSADJoint adjoint the specified tensor
TSEQuiv check the equivalency of two stored tensors
TSPrint print info of stored tensors
TSReset reset the tensor manager

Extraction

Command Description Options
EXTPrint print info of extracting ZX-graph
EXTRact perform step(s) in extraction

Lattice

Command Description Options
LTS (experimental) perform mapping from ZX-graph to corresponding lattice surgery