Spatially adaptive FLIP fluid simulations in bifrost

Spatial adaptivity has great promise for fluid simulation in visual effects. Given that a 2× increase in spatial resolution incurs an 8× increase in memory for 3D, using high resolution only where needed can offer a huge savings for many interesting scenarios. For example, figure 1 shows a large-scale simulation of a creature emerging from deep water: the depth is critical for the bulk motion, but the velocity field away from the creature and surface is relatively smooth and does not require as high resolution. Adaptive fluid simulation was proposed for graphics over a decade ago [Losasso et al. 2004], and the combination of FLIP and octrees seven years ago [Hong et al. 2009], yet it has been slow to catch on in the industry. Instead, FLIP with uniform resolution sparse voxel tiles has emerged as the standard approach. Sparse voxel tiles efficiently cover arbitrary domains, give excellent cache usage and low data structure overhead, and allow the use of popular voxel algorithms for level set computations etc. with barely any changes. By comparison, typical adaptive octree and/or tetrahedral mesh approaches incur sizeable overheads and may rule out many standard voxel algorithms. SPGrid [Setaluri et al. 2014] is one recent option for efficiently achieving octree-like adaptivity via multiple levels of sparse voxel tiles; in this talk we discuss a more aggressive approach using a wide-branching tile tree of voxels. We have fully implemented this in Bifrost in Autodesk Maya, demonstrating that even in uniform resolution we achieve the performance of optimized sparse voxel tile code, and that spatial adaptivity gives significant further improvements in both memory and runtime.