Skip to main content

Heavy weight plotting tools for ab initio solid-state calculations

Project description

Build Status JOSS Paper Pypi Repository Zenodo Repository

Sumo is a Python toolkit for plotting and analysis of ab initio solid-state calculation data, built on existing Python packages from the solid-state chemistry/physics community. It is hoped that these command-line tools will bring some of the benefits of these libraries to a wider user-base while providing publication-ready plotting (powered by Matplotlib.)

The main features include:

  1. An extensive framework for generating high-symmetry k-point paths.

    • Crystallographic spacegroups are determined using Spglib.

    • Conventional crystallographic paths are built in as well as interfaces to the SeeK-path and Pymatgen implementations.

  2. Plotting scripts for electronic and phonon band structures, density of states, and optical absorption diagrams.

    • VASP calculations are imported using Pymatgen.

    • The Phonopy framework is supported for phonon band structures.

  3. Analysis scripts to calculate parabolic and non-parabolic band effective masses.

    • Curve fitting is performed using Scipy.

The code currently primarily supports VASP calculations, and has partial support for CASTEP and for LMTO calculations with Questaal. We would like to add support for additional solid-state codes in future releases. Code contributions to interface with these packages are welcome.

Sumo is free to use, however, we ask that you cite the code if you use it in your research. See the “contributing” section for information about reporting bugs and getting involved.

Usage

Sumo is intended to be used via the command-line, however, a fully-documented python API is also provided. A manual, including tutorials and API documentation, is available online. Additionally, the built-in help (-h) option for each command provides a summary of the available options.

A guide to using each command can be found on the Tutorial page.

For a preview of the functionality of sumo, see the Gallery.

Currently, the scripts provided are:

  • sumo-kgen: For generating VASP KPOINTS files along high-symmetry k-point paths.

  • sumo-bandplot: For plotting publication-ready electronic band structure diagrams.

  • sumo-dosplot: For plotting publication-ready electronic density of states diagrams.

  • sumo-optplot: For plotting publication-ready optical absorption diagrams.

  • sumo-phonon-bandplot: For plotting publication-ready phonon band structure diagrams.

  • sumo-bandstats: For calculating electron and hole effective masses from a band structure.

Information on how to tweak the style of sumo plots is provided on the Customising Sumo Plots page.

Feature support for different codes

Features

VASP

CASTEP

Questaal

k-point path generation

Y

Y (1)

Y

band plotting

Y

Y

Y

band projections

Y

N

N

band analysis

Y

N

N

total DOS plot

Y

Y

Y

projected DOS

Y

Y

Y

phonon band plot

Y (2)

Y

N

  1. Brillouin-zone path can also be written for CASTEP phonon calculation

  2. VASP phonons are plotted from Phonopy output files

Installation

Sumo is a Python 3 package and requires a typical scientific Python stack; we recommend using your main package manager if possible (e.g. apt, Homebrew), or Anaconda to install Python 3 with setuptools. It is a good idea to also use this package manager to install Numpy and Matplotlib, as building them with setuptools can be troublesome. Sumo can then be installed using the Python package manager “Pip”, which will automatically setup other Python packages as required:

pip install --user sumo

If this is your first entry to the scientific Python ecosystem, be aware that the full stack including Scipy with need several hundred MB of disk space.

Developer installation

Regular users can skip this section!

Sumo can also be installed from a copy of the source repository (https://github.com/smtg-bham/sumo); this will be preferred for development work or if using experimental code branches.

To clone the project from Github and make a local installation:

git clone https://github.com/smtg-bham/sumo.git
cd sumo
pip install --user -e .

The -e and --user options are recommended: Instead of copying files, with -e pip will create links to the source folder so that that tweaks to the code will be immediately reflected on the PATH. The --user flag installs to a directory in your home folder (usually under the hidden directory ~/.local), preventing interference with your root Python installation.

Tests

From a developer installation, the unit tests can be run (from the root directory of the project) using:

pytest

Automatic testing is run on the master branch of Sumo and proposed features using GitHub Actions.

Documentation

To build the documentation from the project files, install sumo with extra Sphinx dependencies before compiling with sphinx-build.

pip install --user .[docs]
sphinx-build docs/src docs_build

The user guide can then be explored from docs/build/html/index.html.

How to cite sumo

If you use sumo in your research, please consider citing the following work:

Alex M. Ganose, Adam J. Jackson, David O. Scanlon. sumo: Command-line tools for plotting and analysis of periodic ab initio calculations. Journal of Open Source Software, 2018 3 (28), 717, doi:10.21105/joss.00717.

License

Sumo is made available under the MIT License.

Detailed requirements

Sumo is currently compatible with Python 3.10+ and relies on a number of open-source python packages, specifically:

Contributing

Bugs reports and feature requests

There are probably still some bugs. If you think you’ve found one, please report it on the Issue Tracker. This is also the place to propose ideas for new features or ask questions about the design of Sumo. Poor documentation is considered a bug, but please be as specific as possible when asking for improvements.

Code contributions

We welcome your help in improving and extending the package with your own contributions. This is managed through Github pull requests; for external contributions we prefer the “fork and pull” workflow while core developers use branches in the main repository:

  1. First open an Issue to discuss the proposed contribution. This discussion might include how the changes fit Sumo’s scope and a general technical approach.

  2. Make your own project fork and implement the changes there. Please keep your code style compliant with PEP8.

  3. Open a pull request to merge the changes into the main project. A more detailed discussion can take place there before the changes are accepted.

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

sumo-2.4.0.post1.tar.gz (115.6 kB view details)

Uploaded Source

Built Distribution

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

sumo-2.4.0.post1-py3-none-any.whl (139.5 kB view details)

Uploaded Python 3

File details

Details for the file sumo-2.4.0.post1.tar.gz.

File metadata

  • Download URL: sumo-2.4.0.post1.tar.gz
  • Upload date:
  • Size: 115.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for sumo-2.4.0.post1.tar.gz
Algorithm Hash digest
SHA256 bb7e58aac2c4c1f38d15229253d17af9caa1219589f99aa82404be3702664473
MD5 1045369cf2562eef7c5454625dc4b32e
BLAKE2b-256 3d9f42285072b861aa98457d62bc66ed576e5f1073bba04742d23402bc5f615f

See more details on using hashes here.

Provenance

The following attestation bundles were made for sumo-2.4.0.post1.tar.gz:

Publisher: release.yml on SMTG-Bham/sumo

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file sumo-2.4.0.post1-py3-none-any.whl.

File metadata

  • Download URL: sumo-2.4.0.post1-py3-none-any.whl
  • Upload date:
  • Size: 139.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for sumo-2.4.0.post1-py3-none-any.whl
Algorithm Hash digest
SHA256 b7a025c9776a1fa0a73b61b3ffaf74eeda570735f1a50f6d61a5a78ab8ad37ce
MD5 54e264f0cf92345fbfaec8dc04ea4b2e
BLAKE2b-256 1fb8734c2d4ff8a2bebff0b2f3a51beab4850651591c3f7d77f1cc2ca72ffdd9

See more details on using hashes here.

Provenance

The following attestation bundles were made for sumo-2.4.0.post1-py3-none-any.whl:

Publisher: release.yml on SMTG-Bham/sumo

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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