This project uses an SSD1306 OLED module, an MPU6050 accelerometer, and a Raspberry Pi 4 to realize a fluid simulation toy that lets you toss around an ocean of water in your hand. (That is, it simulates fluid dynamics at a scale larger than the actual screen.) You can see it in action on Youtube. This can be thought of as a "free-surface flow" problem, and it's solved by a "smoothed particle hydrodynamics" (SPH) technique.
The only dependencies are OpenMP and the ssd1306 driver by lexus2k. Thanks to the SDL emulation of the SSD1306 offered by the ssd1306 library, this project offers a choice of two executables: desktop_sph_fluid
and pi_sph_fluid
.
desktop_sph_fluid
generates and renders a circular drop falling on a dry surface, and it can be compiled (on Linux) with the commands
git clone https://github.com/colonelwatch/pi-sph-fluid
cd pi-sph-fluid
git submodule update --init ssd1306
make desktop_sph_fluid
./desktop_sph_fluid
pi_sph_fluid
generates the same but with gravity determined by reading the MPU6050 accelerometer. I2C and the driver for accelerometer need to be enabled by configuring/boot/config.txt
. All the necessary commands are
sudo apt install git
# configure /boot/config.txt (you can also write these lines in manually)
sudo raspi-config nonint do_i2c 0 # call raspi-config non-interactively for turning on i2c correctly
sudo raspi-config nonint set_config_var dtparam=i2c_arm on,1000000 /boot/config.txt # set i2c speed to 1MHz
echo dtoverlay=mpu6050 | sudo tee -a /boot/config.txt # pull up device tree overlay for mpu6050
sudo reboot
git clone https://github.com/colonelwatch/pi-sph-fluid
cd pi-sph-fluid
git submodule update --init ssd1306
make pi_sph_fluid
# limit the rate at which the MPU6050 is being polled
echo 10 | sudo tee /sys/bus/iio/devices/iio:device0/sampling_frequency
./pi_sph_fluid
Besides the ssd1306 driver, this project is just under 750 lines of C! Here's what this project implements in that many lines:
- Linked-list neighbors search, a common technique but outlined well in [1]
- Weakly-compressible smoothed particle hydrodynamics (WCSPH), completely described in [2] and [3]
- Artificial viscosity and momentum-preserving pressure, described in the same
- Ordinary advection (not XSPH)
- Working around negative density error by clamping negative pressure to zero, mentioned in the IISPH, DFSPH, and PBF papers ([4-6] respectively) along with other papers
- Boundary handling offered by [7]
- Fake surface tension effects using artificial pressure, mentioned in [6]
- Rendering using metaballs, following the original implementation in [8]
- OpenMP acceleration
To be exact: expect a writeup on this or even some cleaning up, but the following equations are implemented.
Given two-dimensional coordinates written as
where
Also note:
-
$W(\vec{x}_i - \vec{x}_j, h)$ is typically rewritten as$W_{i j}$ - The typical expression of the gradient can be rewritten in terms of the above as
The pseudo-mass of which is defined in [7]:
where
Found in [7]:
Also note:
- Calculating the density seems to be the one exception where a particle can neighbor itself (see calculation of density in SPlisHSPlasH)
- However, a particle doesn't seem to neighbor itself in the general case (see the comparison against brute-force search in the neighbors search library used in SPlisHSPlasH)
- Here, the self-contribution is written out as an explicit term
- This may or may not be the interpretation taken in [7] as well
Stated first in the context of fluid simulation with SPH in [2], plus the clamping at zero (as employed in incompressible SPH formulations in [4, 5]) used as a hack:
where
Including momentum-preserving pressure gradient from [2], artificial viscosity from [2], and artificial pressure from [6], and rigid correction from [7]:
where
where
where
Also note:
- The mean rho is written as
$\bar\rho_{f_i f_j} = (\rho_{f_i} + \rho_{f_j})/2$ - The position difference is written as
$\vec{x}_{i j} = \vec{x}_i - \vec{x}_j$ - The velocity difference is written as
$\vec{v}_{i j} = \vec{v}_i - \vec{v}_j$
Given
where
This project really sits on the ground floor of SPH, and some next steps include:
- Z-order or some other -order sort of particles for a higher cache hit rate, as described in [1]
- Ideally, this sort should be multithreaded
- Inferring velocity from accelerations taken from the MPU6050 and assigning that velocity to the boundary
- This would add a bit more realism to the fluid simulation
- GPU acceleration or an implementation of one of the incompressible schemes (PCISPH, IISPH, DFSPH, PBF, etc)
- There's a failed attempt at IISPH in the
IISPH
branch - Some of the most interesting fluid phenomena don't arise in the small number of particles that CPU WCSPH can handle without going unstable (currently 431)
- There's a failed attempt at IISPH in the
[1] J. M. Domínguez, A. J. C. Crespo, M. Gómez-Gesteira, and J. C. Marongiu, “Neighbour lists in smoothed particle hydrodynamics,” International Journal for Numerical Methods in Fluids, vol. 67, no. 12, pp. 2026–2042, 2011, doi: 10.1002/fld.2481.
[2] J. J. Monaghan, “Smoothed particle hydrodynamics,” Reports on progress in physics, vol. 68, no. 8, p. 1703, 2005.
[3] J. J. Monaghan, “Simulating Free Surface Flows with SPH,” Journal of Computational Physics, vol. 110, no. 2, pp. 399–406, 1994, doi: 10.1006/jcph.1994.1034.
[4] M. Ihmsen, J. Cornelis, B. Solenthaler, C. Horvath, and M. Teschner, “Implicit Incompressible SPH,” IEEE Transactions on Visualization and Computer Graphics, vol. 20, no. 3, pp. 426–435, Mar. 2014, doi: 10.1109/TVCG.2013.105.
[5] J. Bender and D. Koschier, “Divergence-free smoothed particle hydrodynamics,” in Proceedings of the 14th ACM SIGGRAPH / Eurographics Symposium on Computer Animation, Los Angeles California: ACM, Aug. 2015, pp. 147–155. doi: 10.1145/2786784.2786796.
[6] M. Macklin and M. Müller, “Position based fluids,” ACM Trans. Graph., vol. 32, no. 4, pp. 1–12, Jul. 2013, doi: 10.1145/2461912.2461984.
[7] N. Akinci, M. Ihmsen, G. Akinci, B. Solenthaler, and M. Teschner, “Versatile rigid-fluid coupling for incompressible SPH,” ACM Trans. Graph., vol. 31, no. 4, pp. 1–8, Aug. 2012, doi: 10.1145/2185520.2185558.
[8] J. F. Blinn, “A Generalization of Algebraic Surface Drawing,” ACM Trans. Graph., vol. 1, no. 3, pp. 235–256, Jul. 1982, doi: 10.1145/357306.357310.
[9] D. Violeau, Fluid mechanics and the SPH method: theory and applications. Oxford University Press, 2012.
[10] J. J. Monaghan, “SPH without a tensile instability,” Journal of computational physics, vol. 159, no. 2, pp. 290–311, 2000.