YADE - An extensible framework for the interactive simulation of multiscale, multiphase, and multiphysics particulate systems

Vasileios Angelidakis, Katia Boschi, Karol Brzeziński, Robert A. Caulk, Bruno Chareyre, Carlos Andrés del Valle, Jérôme Duriez, Anton Gladky, Dingeman L.H. van der Haven, Janek Kozicki, Gerald Pekmezi, Luc Scholtès, Klaus Thoeni

Research output: Contribution to journalArticlepeer-review

5 Downloads (Pure)

Abstract

This contribution presents the key elements of YADE, an extensible open-source framework for dynamic simulations. During the past 19 years, YADE has evolved from “Yet Another Dynamic Engine” to a versatile multiscale and multiphysics solver, counting a large, active, and growing community of users and developers. The computationally intense parts of the source code are written in C++, using flexible object models that allow for easy implementation of new features. The source code is wrapped in Python, equipping the software with an interactive kernel used for rapid and concise scene construction, simulation control, post-processing, and debugging. The project, including documentation and examples, is hosted on https://yade-dem.org, while the source code is freely available on GitLab. Over the last decade, YADE has expanded in terms of capabilities thanks to the contribution of many developers from different fields of expertise, including soil and rock mechanics, chemical engineering, physics, bulk material handling, and mineral processing. The rapid growth of YADE can be attributed to (1) the careful and robust design of the framework core, (2) a continuous integration pipeline with fully embedded thorough tests which are executed upon each merge request, ensuring stable compilation for various operating systems, and (3) user-friendliness, facilitated by the Python interface, detailed documentation, and rigorous user support. In this paper, we review the main features of YADE, highlighting its versatility in terms of applications, its flexibility in terms of code development, as well as recent improvements in terms of computational efficiency. Program summary Program Title: YADE - Yet Another Dynamic Engine CPC Library link to program files: https://doi.org/10.17632/n4f5fw97rd.1 Developer's repository link: https://gitlab.com/yade-dev/trunk Licensing provisions: GNU General Public License 2 Programming language: C++, Python Nature of problem: Numerical simulation of many-particle systems requires accurate models for particle-to-particle interactions, efficient contact detection between objects of various shapes, and robust time integration. In addition, the flow of fluids, thermal effects, as well as other coupled problems in the presence of particles are found in many fundamental and practical applications and they need dedicated computational tools. YADE provides a computational framework to perform such simulations using the discrete element method and multiple extensions of it. Solution method: YADE simulates particulate systems using the Discrete Element Method (DEM) in a flexible platform combining C++ and Python. It provides a large variety of shape and interaction models, an explicit time-integration scheme, and many post-processing tools. YADE features dedicated solvers for both fluid and heat fluxes at the pore scale, and it supports couplings with third-party software such as Escript (finite element method) and OpenFOAM (finite volumes).
Original languageEnglish
Article number109293
JournalComputer Physics Communications
Volume304
Early online date05 Jul 2024
DOIs
Publication statusEarly online date - 05 Jul 2024

Keywords

  • Discrete element method (DEM)
  • Open-source software
  • Granular materials
  • Non-spherical particles
  • Coupled methods
  • Parallel computing

Fingerprint

Dive into the research topics of 'YADE - An extensible framework for the interactive simulation of multiscale, multiphase, and multiphysics particulate systems'. Together they form a unique fingerprint.

Cite this