Skip to content

Python package to analyse electron density & electrostatic potential grids

License

Notifications You must be signed in to change notification settings

nityasagarjena/MacroDensity

Repository files navigation

Welcome to MacroDensity

MacroDensity is a Python package to post-process electrostatic potential and electron density files from electronic structure calculations and plot in a number of ways, including:

  1. Planar average
  2. Spherical average
  3. Atom centred average

Statement of Need

To assess the potential utility of novel semiconducting devices (like p-n junctions, heterostructures, surface terminations), it is key to understand how the electrostatic potential and electron density change across the system. However, extraction and useful presentation of this data from the raw output of the simulation can prove cumbersome and often requires the use of visualisation software followed by manual data extraction. This can result in bottlenecks in high throughput screening projects, where the same data extraction procedure is repeatedly applied to large databases of candidate structures.

To address this, the Macrodensity package has been developed to post-process the output of ab-initio codes like VASP, FHI-AIMS and GULP. The package contains functions that enable the user to format the data from the VASP LOCPOT and CHGCAR files, the FHI-AIMS *.cube file, and GULP *.out file into physically meaningful quantities, which can then be plotted for user interpretation.

Installation

User installation:

MacroDensity can be installed using pip:

.. code:: bash

pip install macrodensity

.. Alternatively if needed, it can also be installed from conda with:

.. .. code:: bash

.. conda install macrodensity

Developer installation

For development of MacroDensity, you can install a copy of the package from the source directory:

.. code:: bash

git clone https://github.com/WMD-group/MacroDensity.git
cd MacroDensity
pip install -e .

Literature

For more information on the theory behind the package, please see the following references:

  • General Approach: Butler, K. T., Hendon, C. H., & Walsh, A. Electronic chemical potentials of porous Metal–Organic frameworks._ Journal of the American Chemical Society, 136(7), 2703–2706, 2014
  • Theoretical Background: Politzer, P., & Murray, J. S. The fundamental nature and role of the electrostatic potential in atoms and molecules._ Theoretical Chemistry Accounts, 108(3), 134–142, 2002

.. _Electronic chemical potentials of porous Metal–Organic frameworks.: https://doi.org/10.1021/ja4110073 .. _The fundamental nature and role of the electrostatic potential in atoms and molecules.: https://doi.org/10.1007/s00214-002-0360-0

Contributing

Bugs reports, feature requests and questions

Please use the Issue Tracker <https://github.com/WMD-group/MacroDensity/issues>_ to report bugs or request new features.

Contributions to extend this package are very welcome! Please use the "Fork and Pull" <https://docs.github.com/en/get-started/quickstart/contributing-to-projects>_ workflow to do so and follow the PEP8 <https://peps.python.org/pep-0008/>_ style guidelines.

Tests

Unit tests are in the tests directory and can be run from the top directory using unittest <https://docs.python.org/3/library/unittest.html>_. Automatic testing is run on the master and develop branches using Github Actions. Please run tests and add new tests for any new features whenever submitting pull requests.

License and citation

MacroDensity is made available under the MIT License.

If you use it in your research, please cite:

  • Method: Harnett-Caulfield, L., & Walsh, A. Assessment of interstitial potentials for rapid prediction of absolute band energies in crystals._ Journal of Chemical Physics, 155(2). 2021
  • Code: JOSS paper

.. _Assessment of interstitial potentials for rapid prediction of absolute band energies in crystals.: https://doi.org/10.1063/5.0056141

About

Python package to analyse electron density & electrostatic potential grids

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 95.3%
  • TeX 3.2%
  • Jupyter Notebook 1.5%