KRATOS Multiphysics ("Kratos") is a framework for building parallel, multi-disciplinary simulation software, aiming at modularity, extensibility, and high performance. Kratos is written in C++, and counts with an extensive Python interface.
Project description
DEM Application
This application focuses on the Discrete Element Method (DEM), a particles method for modeling the bulk behavior of granular materials and many geomaterials such as coal, ores, soil, rocks, aggregates, pellets, tablets and powders.
The DEMpack Team at CIMNE is in charge of all developments related to the DEM.
For the coupling between DEM and Fluids, go to the Swimming DEM Application.
For the coupling between DEM and thermal effects, go to the Thermal DEM Application.
Getting started
This application is part of the Kratos Multiphysics Platform. Instructions on how to get you a copy of the project up and running on your local machine for development and testing purposes are available for both Linux and Windows systems.
Prerequisites
Build Kratos and, before that, make sure that you add
-DDEM_APPLICATION=ON
amongst the compilation options, so the DEM application is compiled.
No auxiliar external libraries are needed.
Theory
The DEM is a numerical method that has been applied to simulate and analyze flow behavior in a wide range of disciplines including mechanical and process engineering, pharmaceutical, materials science, agricultural engineering and more. Coupling with fluid is already available through the Swimming-DEM application, also integrated in the Kratos Multiphysics Platform.
The fundamental theoretical background corresponding to the discontinuous (granular matter) part of the code can be found in the DEM literature easily.
Contact laws
The contact laws are implemented in this folder. Note that the letter 'D' or 'd' in the file name stands for 'discontiuum'. It is related to non cohesive or slightly cohesive contacts.
Linear repulsive force
The most simple representation of a repulsive contact force between a sphere and a wall is given by a linear law, where the force acting on the sphere when contacting the wall is a linear function of the indentation, which in turn would bring a quadratic dependence with the contact radius.
Non-Linear repulsive force
Hertz solved in 1882 the non-cohesive normal contact between a sphere and a plane. In 1971 Johnson, Kendall and Roberts presented the solution (JKR-Theory) for the same problem in this case adding cohesive behaviour. Not much later, Derjaguin, Müller and Toporov published similar results (DMT-Theory). Both theories are very close and correct and, while the JKR theory is adequate to the study of flexible, large spheres, the DMT theory is specially suited to represent the behaviour of rigid, small ones.
Numerical approach
The application includes two types of DEM elements used for different purposes:
- Spheric Particle - Base element used to simulate granular materials (non cohesive or slightly cohesive)
- Spheric Continuum Particle - With specific build-in variables to simulate fracture in cohesive materials. It can also be understood as a discretization method of the continuum by using spheres.
And has the following easy-to-use capabilities:
- Interaction with FEM-based walls - Objects that cannot be crossed by DEM spheres. The user can choose to impose Linear-periodic conditions or rigid body conditions.
- Inlets - Inject new particles while running the simulation linked to some material properties. With user defined granulometry, mass flow and particle type (single particle or clusters). Inlets are based on FEM-based walls and boundary conditions can also be applied to them.
- Initial conditions on particle elements.
- Boundary conditions on particle elements.
It also includes several predefined cluster formations to be used.
DEM strategies
Non-cohesive materials strategy
Once contact between two spheres occurs, the forces at the contact point are computed. The interaction between the two contacting spheres can be represented by two forces with the same module but opposite directions. This force F can be decomposed into its normal and shear components Fn and Fs, respectively. The contact interface for the simplest formulation is characterized by the normal and tangential stiffness Kn and Ks, respectively, a frictional device obeying the Couloumb law with a frictional coefficient, and a dashpot defined by a contact damping coefficient.
In order to represent irregular particles with spheres, a numerical correction is used. The rolling friction imposes a virtual moment opposite to particle rotation and dependent on its size.
Continuum materials strategy
For continuum materials simulations, the contact between particles can resist tractions up to a certain limit, when breakage occurs. Depending on the chosen constitutive law, the computation of the forces changes. In the basic versions, a bond strategy is used, but more advanced laws use a non-local stress-tensor based strategy.
DEM integration schemes
The standard translational and rotational equations for the motion of rigid bodies are used to compute the dynamics of the spheres and clusters. The following schemes can be chosen separately for translation and rotation:
- Symplectic Euler
- Velocity Verlet
- Forward Euler
- Taylor
Also, two rotational specific integration schemes are available:
- Runge-Kutta
- Quaternion based
Contact search
The contact detection basically consists in determining, for every target object, which other objects are in contact with it, and then apply the corresponding interaction. It is usually not needed to perform a search at every time step, which is generally limited by the stability of the explicit integration of the equations of motion. A bins based technique is used for this purpose.
Available interfaces
DEM
This is the package that allows a user to create, run and analyze results of a DEM simulation for discontinuum / granular / little-cohesive materials. Requires GiD - Pre and Post Processing software. It has both 2D and 3D versions. Check the manuals, follow the tutorials or play with the preloaded sample problems in order to learn how this application works.
Cohesive-DEM
This package combines the features of the previous one also with the simulation of continuum/cohesive materials. It also offers the possibility of tackling both 2D and 3D problems. Check also the manuals or tutorials or load the test examples in the GUI in order to learn how this problem type works.
Fluid-DEM
This package allows you to simulate a wide spectrum of problems involving the interaction of granular DEM and fluids. This application has only a 3D version. Check also for existing manuals or tutorials to get a feel of how to work with this application.
Contact
- Miguel Angel Celigueta - Core Development - maceli@cimne.upc.edu
- Salva Latorre - Granular materials - latorre@cimne.upc.edu
- Ferran Arrufat - Cohesive materials - farrufat@cimne.upc.edu
- Guillermo Casas - Fluid coupling - gcasas@cimne.upc.edu
- Joaquín Irazabal - Particle clusters & DEM-Solid interaction - jirazabal@cimne.upc.edu
- Joaquín González-Usúa - Fluid coupling - jgonzalez@cimne.upc.edu
- Chengshun Shang - Bonded partcile models - cshang@cimne.upc.edu
License
The DEM application is OPEN SOURCE. The main code and program structure is available and aimed to grow with the need of any users willing to expand it. The BSD (Berkeley Software Distribution) licence allows to use and distribute the existing code without any restriction, but with the possibility to develop new parts of the code on an open or close basis depending on the developers.
New GIDInterface for Kratos
The new GIDInterface currently under developement can be found here. Based on the customLib, it includes the interfaces for most of the Kratos applications in addition to the new DEM interface.
FAQ
What to do if particles behave strangely
- Check the Young Modulus. Materials with high stiffness may require smaller time steps to ensure stability.
- Check the material density.
- Check the time step. If the time step is too large, the elements can fail to interact with each other. In the worst case scenarios, the simulation may even crash.
- Check the frequency of neighbours' search. If the search is not done frequently enough, new contacts may not be detected.
- Check the restitution coefficient of the material. Explicit integration schemes gain energy noticeably unless an enough small time step is used. If the time step is large (but stable), use the restitution coefficient to compensate for the gain of energy to obtain more realistic results.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distributions
Built Distributions
File details
Details for the file KratosDEMApplication-10.1.0-cp312-cp312-win_amd64.whl
.
File metadata
- Download URL: KratosDEMApplication-10.1.0-cp312-cp312-win_amd64.whl
- Upload date:
- Size: 2.0 MB
- Tags: CPython 3.12, Windows x86-64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/34.0 requests/2.31.0 requests-toolbelt/0.9.1 urllib3/1.26.9 tqdm/4.63.1 importlib-metadata/6.8.0 keyring/23.5.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.9.11
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 85c36577d930e9f3a02d1e934c3cd23defaaeef66e95da55d0bd9baf135f3ca2 |
|
MD5 | 85723fca9140f6f1b11004c9dc769002 |
|
BLAKE2b-256 | 6f584f15db4b2bd1048de26f23d5808ed28ee57bad793f6b71608ee7119416da |
File details
Details for the file KratosDEMApplication-10.1.0-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
.
File metadata
- Download URL: KratosDEMApplication-10.1.0-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
- Upload date:
- Size: 4.6 MB
- Tags: CPython 3.12, manylinux: glibc 2.17+ x86-64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/34.0 requests/2.31.0 requests-toolbelt/0.9.1 urllib3/1.26.9 tqdm/4.63.1 importlib-metadata/6.8.0 keyring/23.5.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.9.11
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 71970bd1ccd140ebd58d2368ba232a68827815b893c3a6827f832bf38fce70fb |
|
MD5 | 609fe79effb9d73a38894ad5198fd3cc |
|
BLAKE2b-256 | bdd09db20733279ac52b66464873a19e03cea11271534f713d0847e110cc593f |
File details
Details for the file KratosDEMApplication-10.1.0-cp311-cp311-win_amd64.whl
.
File metadata
- Download URL: KratosDEMApplication-10.1.0-cp311-cp311-win_amd64.whl
- Upload date:
- Size: 2.0 MB
- Tags: CPython 3.11, Windows x86-64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/34.0 requests/2.31.0 requests-toolbelt/0.9.1 urllib3/1.26.9 tqdm/4.63.1 importlib-metadata/6.8.0 keyring/23.5.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.9.11
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 96c4b66009df05306c989e8094bea15b473be6f613080f4647ba6a43424f43e7 |
|
MD5 | d2148044ea7f348143d52a378c209d0f |
|
BLAKE2b-256 | 30a14916d3b7f387a670a4291132f69acaee1e4024ae0bddb012e42cd8aeb8a2 |
File details
Details for the file KratosDEMApplication-10.1.0-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
.
File metadata
- Download URL: KratosDEMApplication-10.1.0-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
- Upload date:
- Size: 4.6 MB
- Tags: CPython 3.11, manylinux: glibc 2.17+ x86-64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/34.0 requests/2.31.0 requests-toolbelt/0.9.1 urllib3/1.26.9 tqdm/4.63.1 importlib-metadata/6.8.0 keyring/23.5.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.9.11
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | fd61a5fa5b96bc2ee35da7090432086c232c736730da76ee1bc86bd2bb124671 |
|
MD5 | f4abfd34cde495d19a43dfba09289165 |
|
BLAKE2b-256 | e36e0d788a3cfa7f11aab9b48bc6d5a062e109c5025f0519cc37aee6fa972a9a |
File details
Details for the file KratosDEMApplication-10.1.0-cp310-cp310-win_amd64.whl
.
File metadata
- Download URL: KratosDEMApplication-10.1.0-cp310-cp310-win_amd64.whl
- Upload date:
- Size: 2.0 MB
- Tags: CPython 3.10, Windows x86-64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/34.0 requests/2.31.0 requests-toolbelt/0.9.1 urllib3/1.26.9 tqdm/4.63.1 importlib-metadata/6.8.0 keyring/23.5.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.9.11
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | c1c773af771d15a2e74121b0b9f422bf1652d0dfe0baaa4d6806049fd4309250 |
|
MD5 | 4de5ac706b76915dacbe93743580920d |
|
BLAKE2b-256 | b5d7a4714fb49a247a91605d5b1fe7cb89c76f7e5faae409faf2ae3d5d178e5a |
File details
Details for the file KratosDEMApplication-10.1.0-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
.
File metadata
- Download URL: KratosDEMApplication-10.1.0-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
- Upload date:
- Size: 4.6 MB
- Tags: CPython 3.10, manylinux: glibc 2.17+ x86-64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/34.0 requests/2.31.0 requests-toolbelt/0.9.1 urllib3/1.26.9 tqdm/4.63.1 importlib-metadata/6.8.0 keyring/23.5.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.9.11
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | ed32a8eba9ec134d17d2d1d31ea01211c9b3a9af3a3067352984578e11dc55a7 |
|
MD5 | 8c4f943609cd08e373543224487852db |
|
BLAKE2b-256 | cc53898e3407d366912f79bc4e847df4e82bff2d86e05dbd9b87280e8b5369de |
File details
Details for the file KratosDEMApplication-10.1.0-cp39-cp39-win_amd64.whl
.
File metadata
- Download URL: KratosDEMApplication-10.1.0-cp39-cp39-win_amd64.whl
- Upload date:
- Size: 2.0 MB
- Tags: CPython 3.9, Windows x86-64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/34.0 requests/2.31.0 requests-toolbelt/0.9.1 urllib3/1.26.9 tqdm/4.63.1 importlib-metadata/6.8.0 keyring/23.5.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.9.11
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 00ad7d0871ddaa1b9d9e35edc0c8ab47b376a2bef90f0ffb8d17faf11bbd2cca |
|
MD5 | 098e0bb8a472297637d124e892c23d24 |
|
BLAKE2b-256 | e3fa60876525862e972473f0c62206f707818e0888df57c13c795d064962a00a |
File details
Details for the file KratosDEMApplication-10.1.0-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
.
File metadata
- Download URL: KratosDEMApplication-10.1.0-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
- Upload date:
- Size: 4.6 MB
- Tags: CPython 3.9, manylinux: glibc 2.17+ x86-64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/34.0 requests/2.31.0 requests-toolbelt/0.9.1 urllib3/1.26.9 tqdm/4.63.1 importlib-metadata/6.8.0 keyring/23.5.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.9.11
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 3a592b6b8922a7de1afb45d772b45976531b5e1c0c2fc20767e755adf0ebc67e |
|
MD5 | 5ad8559423032e3a7c99c54b5f149fcc |
|
BLAKE2b-256 | aa77b31c5a26266cfcf3337f683d6aef49b32b5fe55651e1bbc0593842a9acf6 |
File details
Details for the file KratosDEMApplication-10.1.0-cp38-cp38-win_amd64.whl
.
File metadata
- Download URL: KratosDEMApplication-10.1.0-cp38-cp38-win_amd64.whl
- Upload date:
- Size: 2.0 MB
- Tags: CPython 3.8, Windows x86-64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/34.0 requests/2.31.0 requests-toolbelt/0.9.1 urllib3/1.26.9 tqdm/4.63.1 importlib-metadata/6.8.0 keyring/23.5.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.9.11
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 7f4c99892dd4c79bfbcb075c09ee502e33acf7c23b15b20370e9b8c17d724ff7 |
|
MD5 | bf042bb12810bccc17764f53ed29721e |
|
BLAKE2b-256 | 24b30bd30bdc359c4e9385e2f2fae03b2d33af3650c9d28604ee36263c6ddecb |
File details
Details for the file KratosDEMApplication-10.1.0-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
.
File metadata
- Download URL: KratosDEMApplication-10.1.0-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
- Upload date:
- Size: 4.6 MB
- Tags: CPython 3.8, manylinux: glibc 2.17+ x86-64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/34.0 requests/2.31.0 requests-toolbelt/0.9.1 urllib3/1.26.9 tqdm/4.63.1 importlib-metadata/6.8.0 keyring/23.5.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.9.11
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | b1f8d54744f17b4fbd9c6183acf0dc4918954672d967370f951b861f653524ab |
|
MD5 | 9423faeac69d0c2bb1e8e3ade216867a |
|
BLAKE2b-256 | 648a7d33725a6ac95ff6a5d169adde900a414ad9916ce88d74bf5c6fbe8018cd |