OpenMP, OpenMP/MPI, and CUDA/MPI C programs for solving the time-dependent dipolar Gross-Pitaevskii equation
Vladimir Loncar, Luis E. Young-S., Srdjan Skrbic, Paulsamy, Muruganandam, Sadhan K. Adhikari, Antun Balaz

TL;DR
This paper introduces improved, parallelized C and CUDA programs for solving the dipolar Gross-Pitaevskii equation across multiple dimensions, demonstrating significant speedups on various hardware configurations.
Contribution
The paper develops and compares new OpenMP, MPI, and CUDA/MPI parallelized programs for the dipolar Gross-Pitaevskii equation, enhancing computational efficiency over previous versions.
Findings
Sequential program speedup of 1.1 to 1.9
OpenMP parallelization speedup of 2 to 12
MPI/MPI and CUDA/MPI versions achieve 9 to 16.5 speedup on clusters
Abstract
We present new versions of the previously published C and CUDA programs for solving the dipolar Gross-Pitaevskii equation in one, two, and three spatial dimensions, which calculate stationary and non-stationary solutions by propagation in imaginary or real time. Presented programs are improved and parallelized versions of previous programs, divided into three packages according to the type of parallelization. First package contains improved and threaded version of sequential C programs using OpenMP. Second package additionally parallelizes three-dimensional variants of the OpenMP programs using MPI, allowing them to be run on distributed-memory systems. Finally, previous three-dimensional CUDA-parallelized programs are further parallelized using MPI, similarly as the OpenMP programs. We also present speedup test results obtained using new versions of programs in comparison with the…
Peer Reviews
No public reviews on file for this paper yet. If you reviewed it on a platform where reviews are public (OpenReview, ICLR, NeurIPS, ICML), you can paste yours below so the community can read it here.
Videos
No videos yet. Explain this paper in a talk, walkthrough, or lecture? Add one.
