Skip to content

eckhrd/SPH

 
 

Repository files navigation

TinySPH

TinySPH is a parallel 2D Smoothed Particle Hydrodynamics(SPH) code, designed to run in real time on the Oak Ridge Leadership Computing Facility's "Tiny Titan" Raspberry Pi cluster. This application was designed to demonstrate distributed computing concepts and while it works best in a distributed environment it is possible to run on a shared memory system such as a single multicore processor. Although the code is designed for Tiny Titan it should, perhaps with some small build tweaks, compile and run on various flavors of Linux and macOS. The code makes use of MPI for distributed computing and requires at least two MPI processes (1 render, 1 compute).

If you find this code useful, find a bug, or use this code in an interesting way i'd love to hear about it, drop me a line at [email protected] and let me know!

Screenshot

The screenshot below shows TinySPH running on a four core MacBook Pro, running with 7 compute MPI processes and 1 MPI render process. The default rendering mode shows a reconstructed liquid surface.

alt text

With the surface reconstruction removed the underlying physics simulation can be better viewed, showing SPH's particle nature. The color of the particle indicates which processor core is responsable for it. TinySPH includes a simple number of particle based load balancing scheme.

alt text

Install

Several prerequisites are required before compiling the code. In a Linux environment, such as Raspian, these may be obtained using your distros package management system. On Macintosh it is recomended that Homebrew be used.

Macintosh

It is assumed that the XCode toolchain has been installed, this is freely available from Apple. Once Homebrew has been installed, the following commands may be run in Terminal.app to setup the prerequisties.

$ brew install mpich
$ brew install glfw
$ brew install glew
$ brew install freetype

Raspberry Pi

On the Raspberry Pi the following packages must be installed, all of which are availble through apt-get. If you used the TinySetup scripts these should already be installed

$ sudo apt-get install mpich
$ sudo apt-get install libglew-dev

Compile and run

Once the prerequisites have been installed TitanSPH can be compiled and run.

Macintosh

To compile on Intel-based Macs:

$ make -f makefile_macos

To compile on Apple Silicon-based Macs (M-series chips):

$ make -f makefile_apple_silicon

To run on a 4-core single socket computer:

$ mpirun -n 4 ./bin/sph.out

Raspberry Pi

To compile

$ make

To run on TinyTitan

$ make run

Controls

The input controls are set in GLFW_utils.c and EGL_utils.c for GLFW and Raspberry Pi platforms, respectively. The Pi's controls are based upon using an XBox controller to handle input.

Although subject to change generally keys should operate as follows:

  • The esc key exists the simulation under macOS. On other platform esc toggles the exit menu, hover the oak leaf over the terminal image and press a to exit.

  • Arrow keys should change the paramaters in the top left of the screen.

  • The mouse controls the mover sphere.

  • a,b,x,y are fluid parameter presets.

  • On macOS [ ] controls the number of processes while on the Pi it is page up and page down.

  • l toggles between particle and liquid surface rendering methods.

If the keyboard input for the Raspberry Pi doesn't work you may need to correctly set /dev/input/event# in get_key_press() in egl_util.c

Code

If you wish the modify the code here are a few things to keep in mind

  • main() lives in fluid.c ~line 37
  • The main computation loop lives in fluid.c ~lines 236
  • Initial parameters are largely set in fluid.c starting ~line 78
  • The shaders directory contains OpenGL and OpenGL ES 2.0 shaders
  • files with suffix _gl control OpenGL rendering

Algorithm

The SPH algorithm is based upon the work of Clavet et al.. To run in real time on the Raspberry Pi a large timestep was neccessary as communication is extremely expensive. Several modifcations have been made to make the algorithm work on the Raspberry Pi.

  • 2D was used instead of 3D.
  • The algorithm was parallelized, the prediction-relaxation algorithm does not have a trivial parallelization scheme.
  • The algorithm was completely symmetrized to reduce computation/hash cost.
  • Plasticity is not used.

About

Parallel realtime SPH

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C 65.8%
  • C++ 14.4%
  • Makefile 4.2%
  • M4 3.4%
  • GLSL 3.2%
  • Perl 3.2%
  • Other 5.8%