Skip to content

YangletLiu/RL4QC

Repository files navigation

Classical Simulation of Quantum Circuits Using Reinforcement Learning: Parallel Environments and Benchmark

📝 Foreword

Who wins in the classical versus quantum computing competition? 😮
Back in 2019, Google proudly announced the first demonstation [1] of “quantum supremacy” with its 53-qubit Sycomore quantum circuits, which was later challenged by researchers claiming to have pulled ahead of Google on classical computers. We assert that any tech giant, university spinoff, or startup is too hasty to advertise ``quantum supremacy” via quantum circuits on the scale of 50 ~ 100 qubits.
Thus, an improved benchmark curve 📈 for classical simulations for quantum circuits is really important. This is also the reason why we start this project.

[1] Arute, Frank, Kunal Arya, Ryan Babbush, Dave Bacon, Joseph C. Bardin, Rami Barends, Rupak Biswas et al. "Quantum supremacy using a programmable superconducting processor." Nature 574, no. 7779 (2019): 505-510.

🎯 Our goal

By representing the quantum gates as the tensor diagrams, the quantum circuits can be represented by a tensor network. The simulation of the quantum circuit involves contracting the tensor network in a specific order. To improve the efficiency of classical simulations of quantum circuits, we need to find a better contraction order with fewer multiplications.

One potential solution is to use reinforcement learning (RL) algorithms, which have shown promise in solving similar combination problems like graph cut and TSP. Some researchers have proposed using RL to find the optimal tensor network contraction order, but this alone may not be enough to accurately measure "quantum supremacy" and improve the benchmark curve.

We hope this project can bridge the gap between the quantum circuit and the deep learning, especially the RL community, to work together to find the real “quantum supremacy” . Come and join us in our mission to unlock the full potential of quantum circuits and revolutionize the world of computing! 🙌

🚩 Roadmap

In our project, we will mainly focus on three aspects, namely the dataset, simulation envrionment, and benchmark,

Dataset: We will release various datasets for the tensor representations of quantum circuits, for other researchers to verify their ideas.
✅ Tensor-Train/MPS tensor network
✅ Tensor-Ring tensor network
✅ Tree tensor network
⬜ PEPS tensor network
⬜ MERA tensor network
⬜ Google's Sycamore circuit

Simulation environment: We will develop efficient simulation environments for reserchers to debug their algirithms. For each tensor network, we will develop the single and the parallel version of the simulation environment, respectively. The parallel enviroment will be much more efficient in the data sampling, thus to significantly improve the efficiency of training RL agents.

Tensor network Single 🚲 Parallel 🚀
TT/MPS
TR
Tree
PEPS
MERA
Sycamore

Benchmark: We will merge and supply widely used algorithms, which has been applied for the classical simulations of quantum circuits, for other researchers to compare their methods' performance.
✅ greey strategy of optimized einsum (OE greedy)
✅ dinamic programming of optimized einsum (OE dynamic)
✅ cotengra kahypar (CTG kahypar)
✅ cotengra greedy (CTG greedy)
✅ RL-Hamiltonian

👋 We are always welcome other researchers to contribute the benchmark algorithms, including the suggestions of methods, better hyper-parameters, etc., and the datasets, especially the pratical quantum circuits.

📋 Experimental Results

File Structure

RL4QuantumCircuits
├── baseline
|    ├──mps
|    |──tr
|    |──tree
|    |──peps
|    |──mera
|    |──sycamore
├── datasets_generator
|    ├──mps
|    |──sycamore
|    |──tr
|    |──tree
|    |──peps
├── simulation_data
|    ├──mps
|    |──sycamore
|    |──tr
|    |──tree
|    |──peps
├── rl
|    ├──mps
|    ├──sycamore
├── verification
|    ├──code
|    ├──orders

We provide the classical simulation data of quantum circuits in the simulation_data dictionary, which covers the Sycamore circuits, matrix product state (mps), tensor ring (tr), tensor tree (tree), and peps with a range of nodes.
In each file, we use the string to represent the quantum circuits, where each character stands for an edge, and the adjacent character indicates the connections between nodes.

How to run

🔸 To run the baseline methods, just execute "python cotengra.py" or "python opt_einsum.py", where the variable n is the number of the tensor nodes.
🔸 To generate the dataset, please execute "python *generate.py", where the variable V in the main part is the number of tensor nodes.

Tensor-Train/MPS tensor network

We present the Number of multiplications versus the Number of tensor nodes in the tensor-train/mps tensor network in the following table,

number of nodes 10 50 100 200 400 600 800 1000 1500 2000
OE greedy 3.848 15.875 30.927 61.030 121.236 181.442 241.648 301.854 X X
CTG greedy 3.693 15.656 30.705 60.808 121.014 181.220 241.426 301.632 X X
CTG kahypar 3.690 15.650 30.710 60.810 121.010 181.220 241.430 301.630 451.150 602.660
RL-Ising 3.392 15.232 30.404 60.507 120.713 180.919 241.125 301.331

⚠️ Note:
(1) OE dynamic can not give a solution in a limited time for the number of nodes from 50 to 2000.
(2) OE greedy and CTG greedy can not scale up to the number of nodes 1500 and 2000.

Sycamore circuit

We present the Number of multiplications versus the Number of cycles in the sycamore circuit in the following table,

number of cycles 12 14 16 18 20
OE greedy 17.795 19.679 25.889 26.793 26.491
CTG greedy 17.065 19.282 23.151 23.570 25.623
CTG kahypar 13.408 14.152 17.012 17.684 18.826
RL-Ising

Benchmark results

We open-source the benchmark results of the classical simulation of quantum circuits on Sycamore circuits at https://drive.google.com/drive/folders/16D3yaUrBIH_5bFZQJoXpGnKDDXAIZHmk?usp=sharing .

Related blogs

About tensor networks https://zhuanlan.zhihu.com/p/623285707
About tensor-train/mps tensor network https://zhuanlan.zhihu.com/p/623582170
About quantum circuits simulations using tensor networks https://zhuanlan.zhihu.com/p/624353259
About the design of environments https://zhuanlan.zhihu.com/p/627658313
About the tensor network dataset generation https://zhuanlan.zhihu.com/p/628239428?

Reference:

[1] Meirom, E., Maron, H., Mannor, S., & Chechik, G. Optimizing tensor network contraction using reinforcement learning. In International Conference on Machine Learning (pp. 15278-15292). ICML 2022.
[2] Daniel, G., Gray, J., et al. (2018). Opt_einsum-a python package for optimizing contraction order for einsum-like expressions. Journal of Open Source Software, 3(26):753 https://github.com/dgasmith/opt_einsum
[3] Gray, J. and Kourtis, S. (2021). Hyper-optimized tensor network contraction. Quantum, 5:410. https://github.com/jcmgray/cotengra

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •  

Languages