Skip to content

Latest commit

 

History

History
115 lines (70 loc) · 2.7 KB

README.md

File metadata and controls

115 lines (70 loc) · 2.7 KB

leia

The "leia" project is an OpenFOAM module that implements unstructured Lagrangian / Eulerian Interface (LEIA) methods for multiphase flow simulations in complex geometries.

Build Tests

Author

Publications

License

This project is licensed under the GPL3.0 License - see the LICENSE.md file for details.

Installation

These instructions will get your copy of the project up and running on your local machine for development and testing purposes.

leia is a project that builds on OpenFOAM so it compiles and links against OpenFOAM libraries.

Compilation & Installation dependencies

A C++ compiler that supports the C++20 standard, tested with

  • g++ (GCC) 11.2.0
  • g++ (GCC) 10.3.0

Computing dependencies

Meshing

  • cfmesh, available as OpenFOAM sub-module, used for automatic generation of unstructured volume meshes

OpenFOAM-v2206

To install OpenFOAM follow the instructions on installing OpenFOAM from sources.

  1. Check out openfoam using git.
  2. Check out the git tag and build
    ?> git checkout OpenFOAM-v2206
    ?> ./Allwmake

Post-processing dependencies

We use Jupyter notebooks for visualization and processing of test results, and following packages (may be differently named on your Operating System)

  • python, python-pandas, python-numpy, python-jupyter

Compilation

Once OpenFOAM is installed, run

leia> ./Allwmake  

How to setup and run example cases

The template cases used for advection verification are located in cases/.

Serial execution

 case> ./Allrun.serial

Parallel execution

Create the mesh and initialize the fields with

case> ./Allrun.parallel

Level Set Advection

The velocity field for an alternative advection case can be set in testAdvection/system/fvSolution

velocityModel
{
    type deformation3D; 
    oscillation on;
}

Enter test ater type to get a list of available velocity models. Initial interface shape is also set in testAdvection/system/fvSolution

levelSet
{
    implicitSurface 
    {
        type implicitSphere; 
        center (0.35 0.35 0.35); 
        radius 0.15;
    }

    ...

Enter test after type to get a list of available types and their parameters.

Contributing

Fork the project and submit a merge request.