Skip to main content
SHARE
Publication

MiniApp for Density Matrix Renormalization Group Hamiltonian Application Kernel...

Publication Type
Conference Paper
Journal Name
IEEE International Conference on Cluster Computing (IEEE CLUSTER)
Publication Date
Page Numbers
590 to 597
Volume
20
Issue
0
Conference Name
IEEE International Conference on Cluster Computing (CLUSTER 2018)
Conference Location
Belfast, United Kingdom
Conference Sponsor
IEEE Computer Society
Conference Date
-

We present two miniapps that implement the core computational kernel of the DMRG++ application, a generic C++ code that implements the Density Matrix Renormalization Group (DMRG) algorithm. The DMRG++ core Kronecker multiplication kernel is formulated using a batched BLAS approach, with implementation that targets both multi-core CPUs using OpenMP and GPGPU using the MAGMA library. The kernel evaluates the matrix-vector multiplication of the target Hamiltonian matrix used in Lanczos algorithm for computing the lowest eigenvalue and eigenvector. The Hamiltonian matrix is expressed compactly as sums of Kronecker products of small dense matrices. We demonstrate improved performance of the miniapp on synthetic problem, and show the performance of the DMRG++ application using a plugin based on the miniapp. We also present an OpenMP miniapp that explores the use of nested parallel constructs to implement the Kronecker multiplication kernel, exploring the use of nested OpenMP worksharing and tasking abstractions to implement the multi-level parallel multiplication algorithm. The miniapp has been used as a co-design vehicle for evaluating features in the OpenMP-4.5 and upcoming OpenMP-5.0 standards.