Abstract
Lattice-Boltzmannmethods are versatile numericalmodeling techniques capable of reproducing a wide variety of fluid-mechanical behavior. These methods are well suited to parallel implementation, particularly on the single-instruction multiple data (SIMD) parallel processing environments found in computer graphics processing units (GPUs). Although recent programming tools dramatically improve the ease with which GPUbased applications can be written, the programming environment still lacks the flexibility available to more traditional CPU programs. In particular, it may be difficult to develop modular and extensible programs that require variable on-device functionality with current GPU architectures. This paper describes a process of automatic code generation that overcomes these difficulties for lattice-Boltzmann simulations. It details the development of GPU-based modules for an extensible lattice-Boltzmann simulation package - LBHydra. The performance of the automatically generated code is compared to equivalent purposewritten codes for both single-phase,multiphase, andmulticomponent flows. The flexibility of the new method is demonstrated by simulating a rising, dissolving droplet moving through a porous medium with user generated lattice-Boltzmann models and subroutines.
Original language | English |
---|---|
Title of host publication | Communications in Computational Physics |
Publisher | Global Science Press |
Pages | 867-879 |
Number of pages | 13 |
Volume | 13 |
Edition | 3 |
DOIs | |
Publication status | Published - 1 Mar 2013 |
Externally published | Yes |
Event | International Conference on Discrete Simulation of Fluid Dynamics (DSFD 2011) - Fargo, United States of America Duration: 8 Aug 2011 → 12 Aug 2011 Conference number: 20th |
Conference
Conference | International Conference on Discrete Simulation of Fluid Dynamics (DSFD 2011) |
---|---|
Abbreviated title | DSFD 2011 |
Country | United States of America |
City | Fargo |
Period | 8/08/11 → 12/08/11 |
Keywords
- Computational fluid dynamics
- Graphics processing units
- Lattice-Boltzmann methods