@inproceedings{bfd6b9c81b4d47ce8fa5e97992f49c44,
title = "Lattice Boltzmann for Large-Scale GPU Systems",
abstract = "We describe the enablement of the Ludwig lattice Boltzmann parallel fluid dynamics application, designed specifically for complex problems, for massively parallel GPU-accelerated architectures. NVIDIA CUDA is introduced into the existing C/MPI framework, and we have given careful consideration to maintainability in addition to performance. Significant performance gains are realised on each GPU through restructuring of the data layout to allow memory coalescing and the adaptation of key loops to reduce off-chip memory accesses. The halo-swap communication phase has been designed to efficiently utilise many GPUs in parallel: included is the overlapping of several stages using CUDA stream functionality. The new GPU adaptation is seen to retain the good scaling behaviour of the original CPU code, and scales well up to 256 NVIDIA Fermi GPUs (the largest resource tested). The performance on the NVIDIA Fermi GPU is observed to be up to a factor of 4 greater than the (12-core) AMD Magny-Cours CPU (with all cores utilised) for a binary fluid benchmark.",
keywords = "GPU, Lattice Boltzmann, CUDA, MPI, Optimisation, FLUIDS",
author = "Alan Gray and Alistair Hart and Alan Richardson and Kevin Stratford",
year = "2012",
doi = "10.3233/978-1-61499-041-3-167",
language = "English",
isbn = "978-1-61499-040-6",
series = "Advances in Parallel Computing",
publisher = "IOS Press",
pages = "167--174",
editor = "K DeBosschere and EH DHollander and GR Joubert and D Padua and F Peters",
booktitle = "APPLICATIONS, TOOLS AND TECHNIQUES ON THE ROAD TO EXASCALE COMPUTING",
note = "14th Biennial ParCo Conference (ParCo) ; Conference date: 31-08-2011 Through 03-09-2011",
}