GPU-based fluid simulation and rendering using OpenGL 4.6 compute shaders, DSA and bindless textures. Fluid behaviour is simulated using smoothed-particle hydrodynamics (SPH) as described by Müller et al. [1]. The GPU simulation pipeline roughly follows the work of Harada et al. [2]. After particle simulation, a screen-space rendering technique is performed to suggest a fluid-like continuous surface [3].
[1] Particle-Based Fluid Simulation for Interactive Applications, Müller et al. 2003
[2] Smoothed Particle Hydrodynamics on GPUs, Harada et al. 2007
[3] Screen Space Fluid Rendering with Curvature Flow, van der Laan et al. 2009
Showcase.mp4
flut first builds a uniform grid to speed up SPH neighbor search. In an earlier version, bitonic mergesort was used for this purpose. It got later replaced by counting sort, as outlined below. After grid construction, per-particle densities are computed. From these values, forces are derived which contribute to velocity and position changes. Lastly, the particles are splatted as screen space spheres, smoothed to evoke the look of a surface and shaded using Phong.
To speed up uniform grid construction, counting sort (Hoetzlein 2014) is used. The implementation follows closely what Sebastian Aaltonen described to me about Claybook's implementation. Particles are first splatted to a 3D grid to obtain the cell particle count. Next, a reduction is performed to obtain per-cell particle offsets. Finally, the particles are copied to a new buffer in cell-local order for optimal memory locality.
- The neighborhood search uses an unrolled single loop with interleaved particle fetching as described here
- Curvature flow fragment shader is only executed on oriented bounding box
- Very small but nice: negative grid bounds checks are avoided using
uvec3
cast (from this talk)
Make sure you git clone
with the --recursive
flag or execute git submodule update --init --recursive
after a non-recursive clone.
Then, invoke CMake for your buildsystem of choice and build the flut
target.
Example:
mkdir -p BUILD && cd BUILD
cmake .. -G "Visual Studio 16 2019 Win64" -DCMAKE_BUILD_TYPE=Release
cmake --build . -j 8 --target flut --config Release
- Improved rendering
- Boundary density contribution
- Surface tension forces
- BDF-2 integration
Special thanks to Sebastian Aaltonen for his detailed description of Claybook's SPH implementation.
Copyright (C) 2020 Pablo Delgado Krämer
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <https://www.gnu.org/licenses/>.