Fast hardware-aware matrix-free algorithms for higher-order finite-element discretized matrix multivector products on distributed systems
Gourab Panigrahi,Nikhil Kodali,Debashis Panda,Phani Motamarri
DOI: https://doi.org/10.1016/j.jpdc.2024.104925
IF: 4.542
2024-05-30
Journal of Parallel and Distributed Computing
Abstract:Recent hardware-aware matrix-free algorithms for higher-order finite-element (FE) discretized matrix-vector multiplications reduce floating point operations and data access costs compared to traditional sparse matrix approaches. This work proposes efficient matrix-free algorithms for evaluating FE discretized matrix-multivector products on both multi-node CPU and GPU architectures. We address a critical gap in existing matrix-free implementations, which are not well suited for the action of FE discretized matrices on very large number of vectors. We employ batched evaluation strategies, with the batchsize tailored to underlying hardware architectures, leading to better data locality and enabling further parallelization. On CPUs, we utilize even-odd decomposition, SIMD vectorization, and overlapping computation and communication strategies. On GPUs, we employ strategies to overlap compute with data movement to achieve efficient pipelining and reduced data accesses through the use of GPU-shared memory, constant memory and kernel fusion. Our implementation outperforms the baselines for Helmholtz operator action, achieving up to 1.4x improvement on one CPU node and up to 2.8x on one GPU node, while reaching up to 4.4x and 1.5x improvement on multiple nodes for CPUs (∼3000 cores) and GPUs (∼25 GPUs), respectively. We further benchmark the performance of the proposed implementation for solving a model eigenvalue problem for 1024 smallest eigenvalue-eigenvector pairs by employing the Chebyshev Filtered Subspace Iteration method, achieving up to 1.5x improvement on one CPU node and up to 2.2x on one GPU node while reaching up to 3.0x and 1.4x improvement on multi-node CPUs (∼3000 cores) and GPUs (∼25 GPUs), respectively.
computer science, theory & methods