Skip to content

LEoPart integrates particle functionality into the open-source finite element library FEniCS. This fork focuses on Lagrangian Particle Tracking (LPT) of 3D trajectories of micro- and nano-sized neutrally buoyant particles (flow tracers) that are freely suspended within a turbulent flow field.

License

LGPL-3.0, GPL-3.0 licenses found

Licenses found

LGPL-3.0
COPYING.LESSER
GPL-3.0
COPYING
Notifications You must be signed in to change notification settings

MattH688/LEoPartFork-LPT

Repository files navigation

LEoPart -- FEniCS functionality for scattered particle advection and projection

CircleCI Documentation Status

NOTE: This is a branch of LEoPart adding Lagrangian particle tracking (LPT), 'do_step' with additiona LPT functionality, in the 'advect_particles' class. This adds the ability to move particles based on particle size and density. The LPT has been tailoured to microfluidic channels with assumption of the wall lift. Additionally this branch adapts the dump2file class in particlefun.py to export particles to ".csv" for ParaView visualisation. See NanoMedic.org for more information (Coming Soon!).

LEoPart integrates particle functionality into the open-source finite element library FEniCS. LEoPart is so much as to say Lagrangian-Eulerian on Particles, and might remind you of the animal with particles imprinted on its skin.

Main purpose of this library is to advect and project scattered particle data onto a mesh in an accurate and -optionally- (locally) conservative manner. By blending a finite element mesh and Lagrangian particles, the library enables to solve hyperbolic conservation laws in an accurate and conservative manner, yet free of numerical diffusion. Alternatively, LEoPart might come in handy if you just need to trace large numbers of particles on a fixed or moving mesh polygonal or polyhedral mesh.

As a bonus, this library shows how static condensation principles can be implemented in a rather efficient way in FEniCS.

For a detailed mathematical/implementation background of LEoPart reference is made to a series of papers. We would be grateful if you cite one of these references when using LEoPart:

@article{maljaars2020,
  title={LEoPart: a particle library for FEniCS},
  author={Maljaars, Jakob M and Richardson, Chris N and Sime, Nathan},
  journal={arXiv preprint arXiv:1912.13375},
  year={2019}
}

@article{Maljaars2019,
  author = {Maljaars, Jakob M. and Labeur, Robert Jan and Trask, Nathaniel and Sulsky, Deborah},
  doi = {10.1016/J.CMA.2019.01.028},
  issn = {0045-7825},
  journal = {Comput. Methods Appl. Mech. Eng.},
  month = {jan},
  pages = {443--465},
  publisher = {North-Holland},
  title = {{Conservative, high-order particle-mesh scheme with applications to advection-dominated flows}},
  volume = {348},
  year = {2019}
}

@article{Maljaars2017,
  author = {Maljaars, Jakob M. and Labeur, Robert Jan and M{\"{o}}ller, Matthias},
  doi = {10.1016/j.jcp.2017.12.036},
  issn = {10902716},
  journal = {J. Comput. Phys.},
  month = {apr},
  pages = {150--172},
  publisher = {Elsevier Inc.},
  title = {{A hybridized discontinuous Galerkin framework for high-order particle--mesh operator splitting of the incompressible Navier--Stokes equations}},
  volume = {358},
  year = {2018}
}

Dependencies

Requires FEniCS 2018.1.0 or FEniCS 2019.1.0 www.fenicsproject.org

Python 3


Package contents

The package source can be found in the directory ./source. The directory ./unit_tests contains unit tests for checking essential parts of the code. Various numerical examples, covering linear scalar advection and incompressible Navier-Stokes equations are included in the ./tests directory.


Documentation

Check out the (beta) documentation at https://leopart.readthedocs.io/en/latest


Old version

This repo serves as a better, cleaner and faster replacement of the purely Python based library, which is now hosted at https://bitbucket.org/jakob_maljaars/leopart_python

Installation and executing the code

  1. Clone the repo via

    git clone git clone https://[email protected]/jakob_maljaars/dolfinparticles.git
    

    Using Docker? See Step 2, otherwise go to Step 3

  2. If you want to use FEniCS in Docker, run

    [sudo] docker run -ti -v $(pwd):/home/fenics/shared quay.io/fenicsproject/stable:[2018.1.0.r1]
    

    from the directory where the clone is located.

  3. Compile the python wrapper:

    cd ./source/cpp
    cmake .
    make
    cd ../..
    

    Note the cmake command may require configuration if multiple Python installations exist. Otherwise Python may not find the complied cpp library as cmake created it for a different Python version and will likely produce the error...

    File "/usr/local/lib/python3.8/dist-packages/leopart/ParticleFun.py", line 29, in <module>
      from leopart.cpp import particle_wrapper as compiled_module
    ImportError: cannot import name 'particle_wrapper' from 'leopart.cpp' (unknown location) 
    

    The additional configuration tells cmake which Python Interpter to use, for example cmake . -DPYTHON_EXECUTABLE:FILEPATH=/usr/bin/python3.8. The /usr/bin/python3.8 should be set to your desired Python path.

  4. Add library to your PYTHONPATH

    python3 setup.py install --prefix=[YOUR PYTHONPATH]
    

The code runs in parallel and test found in unit_tests/tests directory can be executed as

mpirun -np [N] python3 [YOUR_TEST].py

Application examples

Passive and active particle tracer modeling on fixed and moving meshes

Alt text

Mass and momentum conservative density tracking in multi-fluid flows:

Alt text

Users are encouraged to apply the code to suit their particular problem.


Contact

Any questions or suggestions? Feel free to contact the developers: j.m.maljaars at tudelft.nl / jakobmaljaars at gmail.com chris at bpi.cam.ac.uk

License

Copyright (C) 2018 Maljaars et al.

This software can be redistributed and/or modified under the terms of the GNU Lesser General Public License as published by the Free Software Foundation (http://www.gnu.org/licenses/).

The software is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.

About

LEoPart integrates particle functionality into the open-source finite element library FEniCS. This fork focuses on Lagrangian Particle Tracking (LPT) of 3D trajectories of micro- and nano-sized neutrally buoyant particles (flow tracers) that are freely suspended within a turbulent flow field.

Resources

License

LGPL-3.0, GPL-3.0 licenses found

Licenses found

LGPL-3.0
COPYING.LESSER
GPL-3.0
COPYING

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 4

  •  
  •  
  •  
  •