Using ultraFluidX
Before using ultraFluidX, make sure that enough compatible GPU devices are available on your machine(s) for your desired simulation, especially in terms of available memory on the devices and their compute performance.
ultraFluidX requires at least one NVIDIA GPU device with compute capability 3.5 or higher and NVIDIA drivers version 450.80.02 or higher, and it is strongly recommended to use a minimum of four GPUs based on the NVIDIA Ampere Architecture, for example, NVIDIA A100, to allow for overnight simulations of typical passenger-car setups on a single machine.
ultraFluidX always needs MPI to run a simulation. The main rank, 0 handles the preprocessing and the I/O, whereas each additional secondary rank 1...n handles one GPU device each. Therefore, ultraFluidX must be started with a minimum of 2 MPI ranks to use at least 1 GPU device for the simulation.
mpirun -np 5 ultraFluidX case.xml
case.xml specifies the simulation parameters and needs to reference a tessellated surface mesh in STL format, a small example (cube.xml, cube.stl) is located in the installation folder uFX/examples/cube/.
CUDA_VISIBLE_DEVICES
, that
is, by executing the BASH
command,export CUDA_VISIBLE_DEVICES=0,1,2,3
CUDA_VISIBLE_DEVICES
has not been set
unintentionally.uFX
script in the altair/scripts
folder:ufx -np 5 -inpFile case.xml
The script sets the required environment variables, wraps the mpirun
call, and redirects the output of ultraFluidX into a log
file that is automatically tagged with the current time stamp.