Skip to content

Machine Learning enhanced CFD solver for incompressible isothermal fluid flow

License

Notifications You must be signed in to change notification settings

pauloacs/DLpisoFoam

Repository files navigation

DLpisoFoam

Contents

Articles

1 - Application of machine learning to model the pressure poisson equation for fluid flow on generic geometries: https://link.springer.com/article/10.1007/s00521-024-09935-0

  • This paper contains a deep description of the ML Surrogate Model developed to solve the Pressure Poisson Equation.

2- Enhancing CFD solver with Machine Learning techniques: https://www.sciencedirect.com/science/article/pii/S004578252400389X

  • This paper contains the CFD solver benchmark

Introduction

This repository contains the solvers and test cases for the DLpisoFoam solver. This solver is based on the OpenFOAM v8 version and is developed to solve the incompressible Navier-Stokes equations using the PISO algorithm. The main goal of this solver is to enhance the pressure-velocity coupling with a Deep Learning surrogate model. The solver is currently being developed in two versions:

1 - DLpisoFoam-alg1 and DLpisoFoam-alg2: the solvers developed in https://github.com/pauloacs/Solving-Poisson-s-Equation-through-DL-for-CFD-apllications. These solvers use the U_to_p surrogate model in surrogate_models/u_to_p/.

2 - DLpisoFoam-deltas: this solver is currently implemented. It makes use of the deltau_to_delta surrogate models in https://github.com/pauloacs/Solving-Poisson-s-Equation-through-DL-for-CFD-apllications. This solver use the deltau_to_delta surrogate model in surrogate_models/deltau_to_delta/.

Here you can find the DLpisoFoam solvers as well as test cases where those can be used. A DockerFile and everything that is needed to build the docker image is also provided here to ease the installation of the solver.

How to start

Setup the enviroment and install the CFD solvers

There are two ways to use DLpisoFoam:

1. Running with Docker:

This is the easiest option as the setup of the environment is automated. To ensure reproducibility, a Docker container with the solver is provided. If you already have Docker installed, you can build your own docker image locally by running:

$ docker build dlpisofoam .

or pull the container with the following command:

$ docker pull pauloacs/dlpisofoam:latest

Using

$ docker run -it -v $(pwd):/home/repo --rm <image_name> bash

This will create a Docker container and launch a shell.

2. Local Setup: This method requires manual setup and installation.

To set up the environment locally, follow these steps:

  1. Create a Python conda virtual environment by running the following command:
$ conda env create -f env_311.yml
  1. Install the surrogate model Python packages:
$ python -m pip install .
  1. Make sure the required environment variables for the CFD solver are properly set by running:
$ ./prep_env311.sh

Note: You may need to create your own prep_env311.sh file with the correct path to your conda environment.

  1. Finally, install the CFD solvers. For example, to install DLpisoFoam_deltas, navigate to the source/DLpisoFoam_deltas directory and run the following commands:
$ wclean
$ wmake

Run your first tutorial

To run your first tutorial, navigate to the directory of the solver you want to test. For example, if you want to run DLpisoFoam_deltas, follow these steps:

  1. Change to the test_case_deltaU_deltaP/ directory:
$ cd test_case_deltaU_deltaP/
  1. Run the DLpisoFoam_deltas solver:
$ DLpisoFoam_deltas

About

Machine Learning enhanced CFD solver for incompressible isothermal fluid flow

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published