Scalability of 3D-DFT by block tensor-matrix multiplication on the JUWELS Cluster
Nitin Malapally, Viacheslav Bolnykh, Estela Suarez, Paolo Carloni, Thomas Lippert, Davide Mandelli
TL;DR
This work addresses the scalability gap of 3D-DFT on distributed-memory systems by proposing a block tensor-matrix multiplication (BTMM) approach that uses point-to-point communication instead of all-to-all in an adapted Cannon's algorithm. Implemented as the S3DFT C++ library, the method rewrites the 3D-DFT as sequential tensor-matrix multiplications with a volumetric $p^3$-PE decomposition and a permutation-based assembly of results, achieving up to $88\%$ of the single-node peak in shared memory. Benchmark comparisons against FFTW3 and Intel MKL show that iMKL remains the fastest overall, FFTW3 second, and S3DFT lags due to distributed-memory communication patterns; nonetheless, one DM variant scales well while others fail to scale on JUWELS. The results illustrate both the potential of BTMM-based 3D-DFT on modern HPC hardware and the need for improved DM communication strategies, especially on networks with lower latency and different topologies, to become competitive with FFT-based approaches on large-scale systems.
Abstract
The 3D Discrete Fourier Transform (DFT) is a technique used to solve problems in disparate fields. Nowadays, the commonly adopted implementation of the 3D-DFT is derived from the Fast Fourier Transform (FFT) algorithm. However, evidence indicates that the distributed memory 3D-FFT algorithm does not scale well due to its use of all-to-all communication. Here, building on the work of Sedukhin \textit{et al}. [Proceedings of the 30th International Conference on Computers and Their Applications, CATA 2015 pp. 193-200 (01 2015)], we revisit the possibility of improving the scaling of the 3D-DFT by using an alternative approach that uses point-to-point communication, albeit at a higher arithmetic complexity. The new algorithm exploits tensor-matrix multiplications on a volumetrically decomposed domain via three specially adapted variants of Cannon's algorithm. It has here been implemented as a C++ library called S3DFT and tested on the JUWELS Cluster at the Jülich Supercomputing Center. Our implementation of the shared memory tensor-matrix multiplication attained 88\% of the theoretical single node peak performance. One variant of the distributed memory tensor-matrix multiplication shows excellent scaling, while the other two show poorer performance, which can be attributed to their intrinsic communication patterns. A comparison of S3DFT with the Intel MKL and FFTW3 libraries indicates that currently iMKL performs best overall, followed in order by FFTW3 and S3DFT. This picture might change with further improvements of the algorithm and/or when running on clusters that use network connections with higher latency, e.g. on cloud platforms.
