This repository contains a Python 3 reimplementation of the D-Rex model
for the evolution of crystallographic preferred orientation in polycrystals.
The code is available for use under the GNU GPL v3 license.
Documentation is accessible via Python's REPL help()
and also online.
Check requires-python
in pyproject.toml
for the minimum required Python
version. The software is tested on Linux, MacOS and Windows, however large
simulations require substantial computational resources usually afforded by HPC
Linux clusters. Linux shell scripts for setting up a Ray cluster
on distributed memory PBS systems are provided in the tools
folder.
Optional mesh generation using gmsh is available,
however the gmsh
module requires the glu
library
(which may require manual installation on some systems).
Tagged package versions can be installed from PyPi. To install the latest version, execute:
pip install pydrex
Optional dependencies can be installed using package[dependency]
syntax, e.g.
pip install pydrex[mesh,ray]
For an evolving, bleeding edge variant use the latest commit on main
:
pip install git+https://github.com/seismic-anisotropy/PyDRex#egg=pydrex
The package metadata and full list of dependencies are declared in pyproject.toml
.
Some tests can optionally output figures or extended diagnostics when run locally. Check the test suite README for details.
Further examples that demonstrate how PyDRex can be used within geodynamic
simulations are provided in the examples
folder.
They have their own README file as well.
The documentation can be built offline using pdoc, with the command:
pdoc -t docs/template -o html --math pydrex tests
which will output the html documentation into a folder called html
.
The homepage will be html/index.html
.
Note that some submodules depend on optional dependencies,
and should otherwise be excluded:
pdoc -t docs/template -o html --math pydrex !pydrex.mesh !pydrex.distributed tests
See also the provided GitHub actions workflow.
For a development environment, clone the source code
and execute the Bash script tools/venv_install.sh
.
This will set up a local Python virtual environment with an editable install
of PyDRex that can be activated/deactivated by following the displayed prompts.