Skip to content

salehisaeed/TensorforceFoam

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

24 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

TensorforceFoam

General information

TensorforceFoam is a TensorFlow-based intrusive Deep Reinforcement Learning (DRL) framework for OpenFOAM. The Tensorforce package is utilized for the DRL computations. The term intrusive refers to the direct integration of the DRL agent within the CFD environment. Such integration eliminates the need for any external information exchange during DRL episodes. The framework is parallelized using the message passing interface (MPI) for Python (mpi4py) to manage parallel environments for computationally intensive CFD cases through distributed computing.

The schematic diagram of the framework's workflow is illustrated below. It shows how the training program operates across multiple processors, the role of the master processor in aggregating and updating data, and the communication between processors via MPI. More information about the theory, the developed codes, and the test cases are presented in the published article (An efficient intrusive deep reinforcement learning framework for OpenFOAM ).

Framework

The source code for the OpenFOAM implementation of the DRL agent is found in the OpenFOAM folder, while the training folder contains the Python programs and the verification test cases. The library is tested and verified with the recent versions of OpenFOAM, such as v2312 and 2406.

How to install

To install the TensorforceFoam library, one needs to download the latest source code using git:

git clone https://github.com/salehisaeed/TensorforceFoam

The installation has to be done on both OpenFOAM and Python sides.

Installation of the OpenFOAM side

The OpenFOAM library of TensorforceFoam uses Tensorflow C API and CppFlow to load TensorFlow models within OpenFOAM and run neural network computations. Therefore, these two package needs to be installed before compiling thew OpenFOAM library.

Tensorflow C API

To install Tensorflow C API, download and extract the Linux CPU only version of TensorFlow for C. The library will be linked to the OpenFOAM compiled library to use the Tensorflow models within C++ codes. The address for the extracted library is required in the option file of OpenFOAM library (OpenFOAM/src/DRLAgent/Make/option). For convenience, an environment variable can be defined for this address in the .bashrc as

export TF_LIBRARIES=/address/to/the/library/libtensorflow-cpu-linux-x86_64-2.8.0

CppFlow

The CppFlow is also used here for loading and running Tensorflow models in C++. Download and install CppFlow from its corresponding GitHub repository. However, CppFlow does not support boolean inputs to the Tensorflow models which is needed in the Tensorforce DRL agents. The boolean specifies whether the model is run in the deterministic (evaluating) or non-deterministic (training) modes. Therefore, Small modifications are implemented to the original CppFlow library to make it compatible with boolean inputs. Only two files are modified which are found in the cppflowfolder. The rest of the CppFlow files are the same as the original library.

Here again, an environment variable can be defined for the address of the cppflow library in the .bashrc for convenience:

export CPPFLOW_LIBRARIES=/address/to/the/library/cppflow

OpenFOAM library

Now, we can compile and use the OpenFOAM library. The library is developed for the OpenCFD branch of OpenFOAM (openfoam.com). Therefore, a complete installation of OpenFOAM, preferably a recent version, such as OpenFOAM-v2312 or OpenFOAM-v2406, is required. Users are referred to OpenFOAM installation guide for more information on installing OpenFOAM.

After installing OpenFOAM, one needs to compile the OpenFOAM side of this framework. In a terminal where OpenFOAM is sourced, run the wmake in the OpenFOAM/src/DRLAgent folder:

cd OpenFOAM/src/DRLAgent
wclean && wmake

The C++ compiler needs to be at least C++14 or preferably C++17. The compiler settings can be set inside the following file

$WM_PROJECT_DIR/wmake/rules/General/Gcc/c++

Inside this file, set -std=c++17. If you do not want to alternate the compiler settings globally, the same setting can be done via the Make/option file.

Installation of the Python side

Create a new virtual environment and install Tensorforce and mpi4py. For more information on, the installation of these two packages, users are referred to the original libraries:

How to use

The vortex shedding behind a 2D cylinder case study, presented in Section 3.1 of the (published article), is found in the tutorials/cylinder2D folder. To run the tutorial case and train a model from scratch, simply enter the tutorials/cylinder2D folder and run

mpirun -np 5 python3 training_mpi.py &> log.training

Here, five parallel CFD environments are run, each of which uses CFD parallel processing. The number of cores for each parallel CFD is specified inside system/decomposeParDict file.

The vortex shedding behind a 3D confined cylinder case study, presented in Section 3.2 of the (published article), is also found in the tutorials/cylinder3D folder. One can run the tutorial case and train a model from scratch using the same command as above.

How to cite

If you use TensorforceFoam, kindly cite the original article of this framework

@article{Salehi2024Meccanica,
    author = {Saeed Salehi},
    title = "{An efficient intrusive deep reinforcement learning framework for OpenFOAM}",
    journal = {Meccanica},
    year = {2024},
    doi = {10.1007/s11012-024-01830-1}
    }   

About

Intrusive Tensorflow-based DRL in OpenFOAM

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published