Skip to main content

Python Laboratory for Dislocation Dynamics

Project description

Anaconda-Server Badge Anaconda-Server Badge Binder License: GPL v3 License: CC BY-NC-SA 4.0 Anaconda-Server Badge

pyLabDD

Python Laboratory for Dislocation Dynamics

Dislocation Dynamics (DD) is a numerical method for studying the evolution of a population of discrete dislocations in an elastic medium under mechanical loads. The pyLabDD package introduces a simple version of Dislocation Dynamics in 2-dimensional space to study fundamental aspects of plastic deformation associated with the motion and mutual interaction of dislocations. Dislocations are considered as pure edge dislocations where the line direction is normal to the considered plane.

Installation

The preferred method to use pyLabDD is within Anaconda or Miniconda, into which it can be easily installed from conda-forge by

$ conda install conda-forge::pylabdd

or

$ conda install pylabdd -c conda-forge

Generally, it can be installed within any Python environment supporting the package installer for python pip from its latest PyPi image via pip

$ pip install pylabdd

Alternatively, the complete repository can be cloned and installed locally. It is recommended to create a conda environment before installation. This can be done by the following the command line instructions

$ git clone https://github.com/AHartmaier/pyLabDD.git ./pyLabDD
$ cd pyLabDD
$ conda env create -f environment.yml  
$ conda activate pylabdd
$ python -m pip install .

For this installation method, the correct implementation of the package can be tested with

$ pytest tests

After this, the package can be used within Python, e.g. be importing the entire package with

import pylabdd as dd

Speedup with Fortran subroutines

The subroutines to calculate the Peach-Koehler (PK) force on dislocations are rather time consuming. The Fortran implementation of these subroutines brings a considerable seepdup of the simulations compared with the pure Python version. After installation from conda-forge, these faster Fortran subroutines are automatically availble. Installations with pip or from source require a Fortran compiler, typically gfortran, within your active environment, i.e. you might need to install gfortran from conda or pip first.
The embedding of Fortran subroutines into Python is accomplished with the leightweight Fortran wrapper fmodpy. If the compliation of the Fortran subroutines should fail, you will receive a warning and the slower Python subroutines will be used as fallback option. In that case, please check if the gfortran compiler is available in your active environment. If problems still persist, please report them directly to the author of this packges or create an issue in the GitHub repo.

Jupyter notebooks

pyLabDD is conveniently used with Jupyter notebooks. Available notebooks with tutorials on the dislocation dynamics method and the Taylor hardening model are contained in the subfolder notebooks.

The Jupyter notebooks of the pyLabDD tutorials are also available on Binder Binder

Contributions

Contributions to the pyLabDD package are highly welcome, either in form of new notebooks with application examples or tutorials, or in form of new functionalities to the Python code. Furthermore, bug reports or any comments on possible improvements of the code or its documentation are greatly appreciated.

Dependencies

pyLabDD requires the following packages as imports:

  • NumPy for array handling
  • MatPlotLib for graphical output
  • fmodpy for embedding of faster Fortran subroutines for PK force calculation (optional)

Version history

  • v 1.0: Initial version (with F90 subroutine)
  • v 1.1: Pure Python version (with optional F90 subroutines)
  • v 1.2: Automatic compilation of F90 subroutines with fallback to Python version

License

The pyLabDD package comes with ABSOLUTELY NO WARRANTY. This is free software, and you are welcome to redistribute it under the conditions of the GNU General Public License (GPLv3)

The contents of examples, notebooks and documentation are published under the Creative Commons Attribution-NonCommercial-ShareAlike 4.0 International License (CC BY-NC-SA 4.0)

© 2025 Alexander Hartmaier, ICAMS/Ruhr University Bochum, Germany

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pylabdd-1.2.12.tar.gz (44.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pylabdd-1.2.12-py3-none-any.whl (79.4 kB view details)

Uploaded Python 3

File details

Details for the file pylabdd-1.2.12.tar.gz.

File metadata

  • Download URL: pylabdd-1.2.12.tar.gz
  • Upload date:
  • Size: 44.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.20

File hashes

Hashes for pylabdd-1.2.12.tar.gz
Algorithm Hash digest
SHA256 59260a9422a21d8ed8eaf1e3167880d966176587a617b2b3eb29d7511c3d89bd
MD5 42148b52c400c34525770a12ff140f31
BLAKE2b-256 dfec3674c1c1975deb4ab85a1e5fe1f657bfb6cf33231495dc01c3e8f6228bc5

See more details on using hashes here.

File details

Details for the file pylabdd-1.2.12-py3-none-any.whl.

File metadata

  • Download URL: pylabdd-1.2.12-py3-none-any.whl
  • Upload date:
  • Size: 79.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.20

File hashes

Hashes for pylabdd-1.2.12-py3-none-any.whl
Algorithm Hash digest
SHA256 a49abf97f25ab756cdc653965ee2d73b3a2e1e1c2746e2bfc004f73656410740
MD5 a7ce21695dfcd274d660669ab28f47d7
BLAKE2b-256 83918043037ac64f7da00a7905c967379ad27a52bb8f9f9399fcc801b565dcb0

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page