S3D is a direct numerical solver for Navier-Stokes with complex chemistries. It’s used for the simulation of turbulent flows during combustion.
Without a doubt, S3D has some of the best visualizations around:
data:image/s3,"s3://crabby-images/ee9fe/ee9fed0e50b112345a0e0614c185b188e522dfcc" alt=""
data:image/s3,"s3://crabby-images/6f6e8/6f6e8aebc4c2debe255d76e896bb512d017a453b" alt=""
data:image/s3,"s3://crabby-images/49ddd/49ddd2a98270eff4aa02fc0823670d1ac424bba8" alt=""
As one of my first projects at ORNL, I accelerated some of the S3D’s kernels in CUDA. Aside from the usual data parallelization and tuning, this was a great introduction to a large scientific codebase spanning Fortran and Matlab.
As CUDA was much less common in 2009 than it is today, I wrote a summary of the speedups in my first workshop paper: Accelerating S3D: A GPGPU Case Study.