A curated list of repositories related to fluid dynamics.
Please send pull requests or raise issues to improve this list.
Contents
Educational
Notebooks
- barbagroup/CFDPython - A sequence of Jupyter notebooks featuring the “12 Steps to Navier-Stokes”.
- gpeyre/numerical-tours - Numerical Tours of Signal Processing and other materials.
- jfavre/Visualization-training - The material used for the Scientific Visualization course, organized online by the Swiss National Supercomputing Centre (CSCS) on May 17-18, 2021.
Lecture Series
Books
- Brunton, S., & Kutz, J. (2019). Data-Driven Science and Engineering: Machine Learning, Dynamical Systems, and Control. Cambridge: Cambridge University Press. DOI :memo: Book :book:
- Castro, I. P., & Vanderwel, C. (2021). Turbulent Flows: An Introduction. IOP Publishing. DOI :memo: Book :book:
- Thuerey, N., Holl, P., Mueller, M., Schnell, P., Trost, F., & Um, K. (2021). Physics-based Deep Learning. Book :book:
Meshing
- nschloe/optimesh - Mesh optimization, mesh smoothing.
- nschloe/pygmsh - Gmsh for Python.
- nschloe/meshio - I/O for exhaustive number of mesh file types.
- PyMesh/PyMesh - Geometry Processing Library for Python.
- cnr-isti-vclab/meshlab - The open source mesh processing system.
- inducer/meshpy - 2D/3D simplicial mesh generator interface for Python (Triangle, TetGen, gmsh).
- gmsh - A three-dimensional finite element mesh generator with built-in pre- and post-processing facilities .
- CGAL/cgal - The Computational Geometry Algorithms Library (CGAL) is a C++ library that aims to provide easy access to efficient and reliable algorithms in computational geometry.
Computational Fluid Dynamics
Finite Difference Methods (FDM)
- p-costa/CaNS - A code for fast, massively-parallel direct numerical simulations (DNS) of canonical flows.
Finite Element Methods (FEM)
- JuliaFEM/JuliaFEM.jl - The JuliaFEM software library is a framework that allows for the distributed processing of large Finite Element Models across clusters of computers using simple programming models.
- FEniCS/dolfinx - Next generation FEniCS problem solving environment.
- deal.II - An open source finite element library.
- firedrakeproject/firedrake - Firedrake is an automated system for the portable solution of partial differential equations using the finite element method (FEM).
- KratosMultiphysics/Kratos - Kratos Multiphysics (A.K.A Kratos) is a framework for building parallel multi-disciplinary simulation software.
- FluidityProject/fluidity - An open-source computational fluid dynamics code with adaptive unstructured mesh capabilities.
- kinnala/scikit-fem - Simple finite element assemblers.
Finite Volume Methods (FVM)
- OpenFOAM/OpenFOAM-dev - OpenFOAM is a free, open source computational fluid dynamics (CFD) software package released by the OpenFOAM Foundation.
- su2code/SU2 - SU2: An Open-Source Suite for Multiphysics Simulation and Design.
- cselab/aphros - Finite volume solver for incompressible multiphase flows with surface tension.
- code-saturne/code_saturne - code_saturne public mirror.
- DelNov/T-Flows - T-Flows (stands for Turbulent Flows) is a Computational Fluid Dynamics (CFD) program, originally developed at Delft University of Technology, the Netherlands.
- ucns3d-team/UCNS3D - Unstructured Compressible Navier Stokes 3D code (UCNS3D).
- weymouth/WaterLily.jl - Fast and simple fluid simulator in Julia.
- MFlowCode/MFC - MFC is a compressible multiphase fluid solver with high-order-accurate shock- and interface-capturing and GPU support via OpenACC.
- nextfoam/Baram - BARAM is developed to mitigate the steep learning curve of Text-based Solvers. BARAM helps you focus on a problem itself with intuitive graphical user interface. For now, OpenFOAM® solvers modified by nextfoam are integrated into BARAM.
Spectral Methods
- DedalusProject/dedalus - A flexible framework for solving PDEs with modern spectral methods.
- FourierFlows/FourierFlows.jl - Tools for building fast, hackable, pseudospectral partial differential equation solvers on periodic domains.
- Nek5000/Nek5000 - NEK5000 is an spectral element CFD code developed at the Mathematics and Computer Science Division of Argonne National Laboratory.
- spectralDNS/shenfun - High performance computational platform in Python for the spectral Galerkin method.
Vortex Methods / Panel Methods / Blade Element Methods
Immersed Boundary Methods (IBM)
- cwrowley/ibpm - Immersed Boundary Projection Method (IBPM).
- barbagroup/PetIBM - PetIBM - toolbox and applications of the immersed-boundary method on distributed-memory architectures.
- barbagroup/cuIBM - cuIBM: a GPU-based immersed boundary method code.
- ChenguangZhang/sdfibm - Immersed boundary method empowered by signed distance field, and OpenFOAM.
- IBAMR/IBAMR - An adaptive and distributed-memory parallel implementation of the immersed boundary (IB) method.
Weather and Climate
- wrf-model/WRF - Weather Research and Forecasting (WRF) model is a numerical weather prediction (NWP) system designed to serve both atmospheric research and operational forecasting needs.
Building Energy and Urban Environments
- NREL/EnergyPlus - EnergyPlus™ is a whole building energy simulation program that engineers, architects, and researchers use to model both energy consumption and water use in buildings.
- uDALES/u-dales - uDALES: large-eddy-simulation software for urban flow, dispersion and microclimate modelling.
- ladybug-tools/butterfly - :butterfly: A light python API for creating and running OpenFoam cases for CFD simulation.
Shallow Water / Ocean Dynamics
- jostbr/shallow-water - Python model solving the shallow water equations (linear momentum, nonlinear continuity).
- team-ocean/veros - The versatile ocean simulator, in pure Python, powered by JAX.
- CliMA/Oceananigans.jl - Julia software for fast, friendly, flexible, data-driven, ocean-flavored fluid dynamics on CPUs and GPUs.
- OceanParcels/parcels - Parcels (Probably A Really Computationally Efficient Lagrangian Simulator) is a set of Python classes and methods to create customisable particle tracking simulations using output from Ocean Circulation models.
Lattice Boltzmann Methods (LBM)
- aromanro/LatticeBoltzmann - A 2D Lattice Boltzmann program.
- lanl/MF-LBM - A Portable, Scalable and High-performance Lattice Boltzmann Code for DNS of Flow in Porous Media.
- unigespc/palabos - Palabos is an open-source CFD solver based on the lattice Boltzmann method.
Design and Optimization
Coupling
- precice/precice - A coupling library for partitioned multi-physics simulations, including, but not restricted to fluid-structure interaction and conjugate heat transfer simulations.
Chemical Kinetics
- Cantera/cantera - Chemical kinetics, thermodynamics, and transport tool suite.
Supersonic / Hypersonic Flow
- matteobernardini/STREAmS - STREAmS performs Direct Numerical Simulations of compressible turbulent flows in Cartesian geometry solving the unsteady, fully compressible Navier-Stokes equations for a perfect gas.
- sergeas67/OpenHyperFLOW2D - 2D (flat/axisymmetrical) transient viscous compressible multicomponent sub/trans/supersonic reacting gas flow with RANS/URANS turbulence models.
Differential programming
Neural Networks for PDE
Graphics
Other Techniques
- PyFR/PyFR - Framework for solving advection-diffusion type problems on streaming architectures using the Flux Reconstruction approach of Huynh.
- pencil-code/pencil-code - A high-order finite-difference code for compressible hydrodynamic flows with magnetic fields and particles.
- NaluCFD/Nalu - Nalu: a generalized unstructured massively parallel low Mach flow code designed to support a variety of open applications of interest built on the Sierra Toolkit and Trilinos solver Tpetra solver stack.
- lesgo-jhu/lesgo - The Large-Eddy Simulation framework from the Turbulence Research Group at Johns Hopkins University.
- cornellius-gp/gpytorch - A highly efficient and modular implementation of Gaussian Processes in PyTorch.
Experimental Fluid Dynamics
PIV / PTV
- JHU-NI-LAB/OpenLPT_Shake-The-Box - Open-source C++ code for Shake-the-box, particle tracking algorithm.
- OpenPTV/openptv - OpenPTV - open source 3D-PTV software.
- OpenPIV/openpiv-python - OpenPIV consists in a Python and Cython modules for scripting and executing the analysis of a set of PIV image pairs.
- OpenPTV/pyptv - Python GUI for OpenPTV - open source three-dimensional particle tracking velocimetry.
- ronshnapp/MyPTV - Python based 3D-PTV - open source pure Python three-dimensional particle tracking velocimetry.
ML / Optical Flow
Post-processing and Data Analysis
- numpy/numpy - The fundamental package for scientific computing with Python.
- mathLab/PyDMD - Python Dynamic Mode Decomposition.
- dynamicslab/pysindy - A sparse regression package with several implementations for the Sparse Identification of Nonlinear Dynamical systems.
- ritchieng/eigenvectors-from-eigenvalues - This repository implements a calculation of eigenvectors from eigenvectors elegantly through PyTorch.
- mengaldo/PySPOD - A Python package for spectral proper orthogonal decomposition (SPOD).
- belson17/modred - An easy-to-use and parallelized library for finding modal decompositions and reduced-order models.
- Astroua/TurbuStat - Statistics of Turbulence Python Package.
- SURGroup/UQpy - UQpy (Uncertainty Quantification with python) is a general purpose Python toolbox for modeling uncertainty in physical and mathematical systems.
- haller-group/LCStool - LCStool: LCS Tool is a computational engine for analyzing fluid flows by extracting their most influential material surfaces, Lagrangian Coherent Structures.
Visualization
2D Visualization
3D Visualization
- K3D-tools/K3D-jupyter - K3D lets you create 3D plots backed by WebGL with high-level API (surfaces, isosurfaces, voxels, mesh, cloud points, vtk objects, volume renderer, colormaps, etc).
- sciapp/gr - GR framework: a graphics library for visualisation applications.
- QuantStack/ipygany - 3-D Scientific Visualization in the Jupyter Notebook.
- InsightSoftwareConsortium/itkwidgets - Interactive Jupyter widgets to visualize images, point sets, and meshes in 2D and 3D.
- NVIDIA/ipyparaview - iPython widget for server-side ParaView rendering in Jupyter.
- Kitware/Vtk - Visualization Toolkit.
- Kitware/paraview - An open-source, multi-platform data analysis and visualization application.
- pyvista/pyvista - 3D plotting and mesh analysis through a streamlined interface for the Visualization Toolkit (VTK).
- blender/blender - A free and open source 3D creation suite, supporting the entirety of the 3D pipeline-modeling, rigging, animation, simulation, rendering, compositing, motion tracking and video editing.
Benchmarks and Datasets
Datasets
Benchmarks
Reproducibility
- iterative/dvc - Data Version Control, Git for Data & Models, ML Experiments Management.
- sphinx-doc/sphinx - Sphinx is a tool that makes it easy to create intelligent and beautiful documentation for Python projects.
- CFD Online Forum - A free community for everyone interested in Computational Fluid Dynamics.