DeepFlame is a deep learning empowered computational fluid dynamics package for single or multiphase, laminar or turbulent, reacting flows at all speeds. It aims to provide an open-source platform to combine the individual strengths of OpenFOAM, Cantera, and PyTorch libraries for deep learning assisted reacting flow simulations. It also has the scope to leverage the next-generation heterogenous supercomputing and AI acceleration infrastructures such as GPU and FPGA.
The neural network models used in the tutorial examples can be found at– AIS Square. To run DeepFlame with DNN, download the DNN model DF-ODENet into the case folder you would like to run.
Detailed guide for installation and tutorials is available on our documentation website.
New in v1.5 (2025/1/8):
- Provide a new boundary condition, totalFlowRateAdvectiveDiffusion (adopted from OpenFOAM v7), which accounts for diffusion effects at the boundary
- Develop a new solver,
dfBuoyancyFoam
(adopted from fireFoam), a transient, compressible solver designed to model turbulent reacting flows while incorporating buoyancy effects - Add radiation models, which are integrated into the current
dfBuoyancyFoam
solver, and can be incorporated into other solvers if needed - Add new combustion models (including infinitelyFastChemistry and eddyDissipationModel) to the
dfBuoyancyFoam
solver - Imply DeepFlame on Arm architecture platforms
New in v1.4 (2024/8/22):
- Reorganize the update order of mass, velocity and temperature for Lagrangian particles and introduce the liquidEvaporationSpalding model as new evaporation model.
- Add source terms for liquid phase in the
dfLowMachFoam
solver - Incorporate Euler-Lagrangian source terms into the
dfHighSpeedFoam
solver to facilitate numerical simulations of two-phase supersonic reactive flows - Provide new flux schemes (including HLLC and HLLCP) for
dfHighSpeedFoam
solver (adopted from detonationFoam ) and do some modifications - Add lagrangianExtraFunctionObjects function (adopted from lagrangianExtraFunctionObjects ) in submodules to write to disk in the old positions file format
- Introduce new cases to evaluate the accuracy of
dfHighSpeedFoam
solver and provide two-phase 1D/2D detonation cases - Add AUSMDV scheme as new flux scheme for
dfHighSpeedFoam
- add compatibility of neural network inference for chemical source terms with the Baidu PaddlePaddle framework
- Adjust original examples referring to the modification of solvers
- Add 2D aachenBomb case in test
- Update PaddlePaddle options for DNN model development and inference in document homepage
New in v1.3 (2023/12/30):
- Complete the full-loop GPU implementation of the
dfLowMachFoam
solver, enabling efficient execution of all computations on GPU - Introduce
DF-ODENet
model, which utilizes sampling from canonical combustion simulation configurations to reduce training costs and improve computational efficiency - Support Large Eddy Simulation (LES) and two-phase combustion simulation capabilities
- Expand the
flareFGM
table to six dimensions and add support for neural network replacement of certain physical quantities in the new six-dimensionalflareFGM
table - Support multi-GPU and multi-processor execution through the
DeepFGM
neural network interface - Modify Cantera's approach to transport property calculations to support real fluid thermophysical property calculation of multi-component reactive flows and integrate neural networks for updating real fluid thermophysical properties
- Add new example cases and update the documentation homepage to provide more comprehensive installation and usage instructions
New in v1.2 (2023/06/30):
- Enable GPU acceleration for fast and efficient discrete matrix construction for solving partial differential equations
- Introduce
DeePFGM
model: a neural network-based approach to replace the flamelet database of the FGM model and reduce memory requirement - Support real fluid density calculation with Cantera's PR/RK equation of state and updated the calculation of isentropic compression coefficient (psi)
- Improve dfHighSpeedFoam solver
- Apply flux splitting to the convective term of the species equations for consistency and accuracy
- Adopt Strong Stability Preserving Runge-Kutta (RKSSP) time scheme for enhanced stability and performance
- Incorporate
WENO scheme
andlibROUNDSchemes
as third-party submodules for convective flux reconstruction - Provide interface to access the reaction rates of each component in a given elementary reaction
- Implement mechanism file detection function to verify the validity of the mechanism file input
- Capture and report Cantera errors for better error handling and user experience
New in v1.1 (2023/03/31):
- Add FGM model
- Add GPU-compatible linear solver AmgX (adopted from petsc4Foam and FOAM2CSR)
- Add new load balancing algorithm
- Add support for solving chemical source term simultaneously on GPU (DNN) and CPU (CVODE)
- Add support for compilation using CMake
- Improve DNN solving procedure when using pure CPU
- Reconstruct
dfChemistryModel
- Update chemical and mixing time scale models in PaSR combustion model
New in v1.0 (2022/11/15):
- Add support for the parallel computation of DNN using libtorch on multiple GPUs
- Add TCI model
New in v0.5 (2022/10/15):
- Add support for the parallel computation of DNN via single and multiple GPUs
- Add access for utilising PyTorch
New in v0.4 (2022/09/26):
- Adapt combustion library from OpenFOAM into DeepFlame
laminar
;EDC
;PaSR
combustion models
New in v0.3 (2022/08/29):
- 1/2/3D adaptive mesh refinement (2/3D adopted from SOFTX_2018_143 and multiDimAMR)
- Add Sigma/dynSmag LES turbulence models
- Add functionObjects/field library
- New example reactiveShockTube for
dfHighSpeedFoam
New in v0.2 (2022/07/25):
- Dynamic load balancing for chemistry solver (adopted from DLBFoam)
From v0.1 (2022/06/15):
- Native Cantera reader for chemical mechanisms in
.cti
,.xml
or.yaml
formats - Full compatiblity with Cantera's
UnityLewis
,Mix
andMulti
transport models - Zero-dimensional constant pressure or constant volume reactor solver
df0DFoam
- Pressued-based low-Mach number reacting flow solver
dfLowMachFoam
- Density-based high-speed reacting flow solver
dfHighSpeedFoam
- Two-phase Lagrangian/Euler spray reacting flow solver
dfSprayFoam
- Cantera's native SUNDIALS CVODE solver for chemical reaction rate evaluation
- Torch's tensor operation functionality for neutral network I/O and calculation
- Interface for DNN model to obtain chemical reaction rates
- Multiple example and tutorial cases with
Allrun
andAllclean
scripts- 0D Perfectly Stirred Reactor
- 1D Freely Propagating Premixed Flame
- 2D Lifted Partially Premixed Triple Flame
- 3D Taylor-Green Vortex with Flame
- 1D Detotation Wave in Homogeneous Premixed Mixture
- 3D Aachen Bomb Spray Flame
- First release v0.1.0 introduction talk (in Chinese)
- Formal release of v1.0.0 introduction talk (in English) and (in Chinese)