کد مقاله کد نشریه سال انتشار مقاله انگلیسی نسخه تمام متن
502479 863708 2015 12 صفحه PDF دانلود رایگان
عنوان انگلیسی مقاله ISI
pyCTQW: A continuous-time quantum walk simulator on distributed memory computers
موضوعات مرتبط
مهندسی و علوم پایه شیمی شیمی تئوریک و عملی
پیش نمایش صفحه اول مقاله
pyCTQW: A continuous-time quantum walk simulator on distributed memory computers
چکیده انگلیسی

In the general field of quantum information and computation, quantum walks are playing an increasingly important role in constructing physical models and quantum algorithms. We have recently developed a distributed memory software package pyCTQW, with an object-oriented Python interface, that allows efficient simulation of large multi-particle CTQW (continuous-time quantum walk)-based systems. In this paper, we present an introduction to the Python and Fortran interfaces of pyCTQW, discuss various numerical methods of calculating the matrix exponential, and demonstrate the performance behavior of pyCTQW on a distributed memory cluster. In particular, the Chebyshev and Krylov-subspace methods for calculating the quantum walk propagation are provided, as well as methods for visualization and data analysis.Program summaryProgram title: pyCTQWCatalogue identifier: AEUN_v1_0Program summary URL:http://cpc.cs.qub.ac.uk/summaries/AEUN_v1_0.htmlProgram obtainable from: CPC Program Library, Queen’s University, Belfast, N. IrelandLicensing provisions: yesNo. of lines in distributed program, including test data, etc.: 130389No. of bytes in distributed program, including test data, etc.: 4971890Distribution format: tar.gzProgramming language: Fortran and Python.Computer: Workstation or cluster implementing MPI.Operating system: Any operating system with Fortran, python, and MPI installed.RAM: Depends on graph size and number of walkersClassification: 4.15, 14.External routines: PETSc [1–3], SLEPc [4–6], MPI, NumPy and SciPy [7–9], Matplotlib [10], NetworkX [11]Nature of problem:Simulates, visualizes and analyzes continuous-time quantum walks on arbitrary undirected graphs.Solution method:Distributed memory implementations of the matrix exponential, via a choice of Krylov-subspace and Chebyshev expansion techniques, are used to simulate the continuous-time quantum walkers. Visualization ability is provided via the supplied Python module and Matplotlib.Restrictions:The size of the quantum walking system is limited by the amount of available memory. The current package implements up to 3 simultaneous walkers with interactions, but it can be readily extended.Unusual features:In addition to utilizing a parallelized Krylov subspace method and Chebyshev approximation scheme to maximize efficiency, pyCTQW also provides functions for visualization of the quantum walk dynamics and calculation of multi-particle entanglement, and allows for arbitrary diagonal defects to be placed on graph nodes to explore transmission and resonance structures.Running time:Runtime varies depending on the size of the graph, number of processors used, and number of simultaneous walkers.References:[1] S. Balay, W.D. Gropp, L.C. McInnes, B.F. Smith, Efficient management of parallelism in object oriented numerical software libraries, in: E. Arge, A.M. Bruaset, H.P. Langtangen (Eds.), Modern Software Tools in Scientific Computing, Birkhäuser Press, 1997, p. 163–202.[2] S. Balay, J. Brown, K. Buschelman, W.D. Gropp, D. Kaushik, M.G. Knepley, L.C. McInnes, B.F. Smith, H. Zhang, PETSc Web page, 2013. http://www.mcs.anl.gov/petsc.[3] S. Balay, J. Brown, Buschelman, Kris, V. Eijkhout, W.D. Gropp, D. Kaushik, M.G. Knepley, L.C. McInnes, B.F. Smith, H. Zhang, PETSc Users Manual, Technical Report ANL- 95/11- Revision 3.4, Argonne National Laboratory, 2013.[4] V. Hernandez, J.E. Roman, V. Vidal, SLEPc: scalable library for eigenvalue problem computations, Lecture Notes in Computer Science 2565 (2003) 377–391.[5] V. Hernandez, J.E. Roman, V. Vidal, SLEPc: a scalable and flexible toolkit for the solution of eigenvalue problems, ACM Trans. Math. Software 31 (2005) 351–362.[6] C. Campos, J.E. Roman, E. Romero, A. Tomas, SLEPc Users Manual, Technical Report DSIC-II/ 24/02- Revision 3.3, D. Sistemes Informàtics i Computació, Universitat Politècnica de València, 2012.[7] E. Jones, T. Oliphant, P. Peterson, et al., SciPy: Open source scientific tools for Python 2001.[8] P. Peterson, F2PY: a tool for connecting Fortran and python programs, International Journal of Computational Science and Engineering 4 (2009) 296.[9] T.E. Oliphant, Python for scientific computing, Computing in Science and Engineering 9 (2007) 10–20.[10] J.D. Hunter, Matplotlib: A 2D graphics environment, Computing in Science and Engineering 9 (2007) 90–95.[11] A.A. Hagberg, D.A. Schult, P.J. Swart, Exploring network structure, dynamics, and function using NetworkX, in: ps-G. Varoquaux, T. Vaught, J. Millman (Eds.), Proceedings of the 7th Python in Science Conference, Pasadena, CA USA, pp. 11–15.

ناشر
Database: Elsevier - ScienceDirect (ساینس دایرکت)
Journal: Computer Physics Communications - Volume 186, January 2015, Pages 81–92
نویسندگان
, ,