Tools to automatically perform and converge exciting calculations.
Project description
excitingworkflow
exctingworkflow is a repository to collect scripts for automatically setting up exciting calculations and performing convergence series.
All workflows are written in the workflow language of jobflow. excitingworklow can be used
to execute dependent exciting calculations (WORKFLOWS) or simply many independent calculations (HIGH-THROUGHPUT).
Workflows
Currently supported workflows are:
- groundstate convergence of the parameters
rgkmax,nemptyandngridkwith respect to the total energy - GW convergence of the parameters
nemptyandngridq, and the HELO's (high energy local orbitals) in the species file(s) with respect to the Quasiparticle energies CBm and VBM, and the bandgap - BSE convergence of the parameters
gqmaxandngridk/ngridqwith respect to the exciton energy, and/or the spectral similarity (measured by spearman coefficient, or the tanimoto coefficient) - species workflow to find a maximal local orbital basis and local orbital hierarchy
- GW workflow: automated workflow to execute a GW calculation using the task-based GW implementation
Installation
For innstructions on how to install excitingworkflow, please refer to the INSTALL file.
Remote execution
If you want to execute your workflows on a remote machine, for instance on a supercomputer using slurm as a queue
manager, you can achieve this using jobflow-remote. You should read the remote_execution.md file
to get started.
Command line interface
excitingworkflow provides a command line interface (CLI) written with typer. It contains mainly helper commands
that should simplify your daily work. After the installation of excitingworkflow, you can invoke the CLI with:
ew
This is similar to calling ew -h or ew --help. You will see a list of all available commands. You can learn more
about each command by calling ew <command> -h. Either you see the description of the command or you get a list of
all available subcommands.
For a complete overview of all commands, you can call:
ew --tree
Note that all commands using jobflow-remote will use the default project.
Tests
Tests are written and executed with pytest. Overall code coverage is
also measured in the git pipeline and displayed on the webpage. You can run the test suite from the root directory via
pip install pytest
pytest tests/
This package is developed to execute exciting calculations. It's not possible to run exciting in the regular unit
test suite.
There are still tests covering the whole workflow, and actually running exciting. Those integration tests can be
additionally triggered via:
pytest --run-exciting tests/
Note, in order for the test cases to find the exciting binary, the value for exciting_binary from the config file
will be used, so it needs to be set.
Tutorials
We provide basic and advanced tutorials, as well as various example files for setting up and running this package. Refer to this README to get started.
Are you a SOL member?
Make sure to also read the SOL-specific information: SOL_info.md.
License
excitingworkflow is distributed under the GNU General Public License
Version 3 (GPLv3) or any later version.
See the LICENSE file for details.
Contributing
We welcome contributions to this repository. Please refer to the CONTRIBUTING file for more information.
Compatibility
This package has been extensively tested and used on both Linux and macOS. Some of the standard paths given in the tutorials might need to be adjusted if you are using a different operating system. The plain usage of Windows is not recommended. Instead, you want to use a virtual machine or a docker-like environment.
Authors and acknowledgment
Fabian Peschel: main developer and maintainer
Hannah Kleine: contributed idea and parts of the implementation of the species workflow
Alexander Buccheri: thanks for supervision and guideline in writing the workflows
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 Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file excitingworkflow-0.1.0.tar.gz.
File metadata
- Download URL: excitingworkflow-0.1.0.tar.gz
- Upload date:
- Size: 197.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
40428bea73c74bfe0a35bef1ec671ffdb1e1d4d47445c432bb920a0ba14a144d
|
|
| MD5 |
335853b51cd5fc4949b71c3867532639
|
|
| BLAKE2b-256 |
3aa99fb85bb09884308f316b43b1687edca418c7812ee200e32de32622d9548d
|
File details
Details for the file excitingworkflow-0.1.0-py3-none-any.whl.
File metadata
- Download URL: excitingworkflow-0.1.0-py3-none-any.whl
- Upload date:
- Size: 232.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2cf591af137e392944f45d559f2f5816100458fcd09f0acf3dd9d177178f127b
|
|
| MD5 |
6a2fb535c2b896ed25f57af5791d5165
|
|
| BLAKE2b-256 |
7e204902b99b2a096054881e2f4d6c33bf1291e45e345817e3f87ea9ca004766
|