Skip to content

Commit

Permalink
doped v2.0.5
Browse files Browse the repository at this point in the history
doped `v2.0.5`

Former-commit-id: e00b19f
Former-commit-id: d23f75c8b05371a5747bc62c5f580be592ef5198
  • Loading branch information
kavanase authored Sep 18, 2023
2 parents 945f76b + bc8f1c2 commit 7e727d9
Show file tree
Hide file tree
Showing 41 changed files with 3,853 additions and 1,357 deletions.
12 changes: 12 additions & 0 deletions CHANGELOG.rst
Original file line number Diff line number Diff line change
@@ -1,6 +1,18 @@
Change Log
==========

v.2.0.5
----------
- Update oxi-state handling to:
- Use pre-assigned oxi states if present
- Handle `pymatgen` oxi-state guessing failures (non-integer oxi states, inaccurate oxi states with
max_sites, failures for extremely large systems etc)
- Update default `probability_threshold` from 0.01 to 0.0075.
- Account for rare possibility of user being on a non UTF-8 system.
- Italicise "V" for vacancy in plotting.
- SMTG-UCL -> SMTG-Bham
- Tests and formatting updates.

v.2.0.4
----------
- Add supercell re-ordering tests for parsing
Expand Down
47 changes: 9 additions & 38 deletions ToDo.md → Dev_ToDo.md
Original file line number Diff line number Diff line change
@@ -1,28 +1,6 @@
# `doped` WishList
# `doped` Development To-Do List
## Defect calculations set up
- See SK Remarkable notes
- CLI Functionality for core functions.
- Could also use some of the `snb` functions to add some convenience commands which `cp CONTCAR
POSCAR` for unconverged `vasp_gam`/`vasp_nkred_std`/`vasp_std` calculations, and copies `CONTCAR`s
to next VASP folder when converged and submits job.
- Defect complexes: Functionality to setup and parse calculations – can do this with new `pymatgen`
code? Note that our defect-centring code is currently not implemented for this!
- Add input file generation for FHI-AIMs, CP2K, Quantum Espresso and CASTEP (using SnB functions),
point to post-processing tools for these online (in docs/example notebooks, `aiida-defects` for QE,
https://github.com/skw32/DefectCorrectionsNotebook for AIMs...),
and give example(s) of how to manually generate a `DefectPhaseDiagram` and chempots from the parsed
energies of these calculations, so the `doped` analysis tools can then be used.
- Add defect expansion code functionality to regenerate defect structures from a smaller supercell in a
larger one. Useful for supercell size convergence tests, and accelerating `ShakeNBreak` etc. If/when
adding, make sure to link in `SnB` docs as well.
- Related point, using our `doped` site-matching functions, could write some quick functions to plot
the exponential tailing off of strain / site displacements as we move away from the defect site.
Could be useful as a validation / check of supercell size convergence, and for quantifying the
strain / distortion introduced by a certain defect (though I guess the `SnB` tools already do a
good job of that) – could possibly give a good rule-of-thumb to aim for with a sufficiently large cell?
- Just something to keep in mind; new defect generation code can apparently use oxidation states from
`defect.defect_structure` and map to defect supercell. Not in our current subclass implementation of
`Defect`. Is this useful info?

## Chemical potential
- Update chemical potential tools to work with new Materials Project API. Currently, supplying an API key for the new Materials Project API returns entries which do not have `e_above_hull` as a property, and so crashes. Ideally would be good to be compatible with both the legacy and new API, which should be fairly straightforward (try importing MPRester from mp_api client except ImportError import from pmg then will need to make a whole separate query/search because `band_gap` and `total_magnetisation` no longer accessible from `get_entries`). See https://docs.materialsproject.org/downloading-data/using-the-api
Expand All @@ -36,6 +14,7 @@
- Automatically check the 'bulk' and 'defect' calculations used the same INCAR tags, KPOINTS and POTCAR
settings, and warn user if not. Should auto-check the magnetisation output; if it comes to around
zero for an odd-electron defect, suggests getting spurious shallow defect behaviour!
- Profile defect parsing, identify bottlenecks and consider if multiprocessing could be used to speed up.
- Add warning if, when parsing, only one charge state for a defect is parsed (i.e. the other charge
states haven't completed), in case this isn't noticed by the user. Print a list of all parsed charge
states as a check.
Expand Down Expand Up @@ -97,7 +76,7 @@
- Related: Add warning for bandfilling correction based off energy range of the CBM/VBM occupation? (In
addition to `num_hole` and `num_electron`)
- Currently the `PointDefectComparator` object from `pymatgen.analysis.defects.thermodynamics` is used to group defect charge states for the transition level plot / transition level map outputs. For interstitials, if the closest Voronoi site from the relaxed structure thus differs significantly between charge states, this will give separate lines for each charge state. This is kind of ok, because they _are_ actually different defect sites, but should have intelligent defaults for dealing with this (see `TODO` in `dpd_from_defect_dict` in `analysis.py`; at least similar colours for similar defect types, an option to just show amalgamated lowest energy charge states for each _defect type_). NaP is an example for this – should have a test built for however we want to handle cases like this. See Ke's example case too with different interstitial sites.
- GitHub issue related to `DefectPhaseDiagram`: https://github.com/SMTG-UCL/doped/issues/3 -> Think about how we want to refactor the `DefectPhaseDiagram` object!
- GitHub issue related to `DefectPhaseDiagram`: https://github.com/SMTG-Bham/doped/issues/3 -> Think about how we want to refactor the `DefectPhaseDiagram` object!
- Note that if you edit the entries in a DefectPhaseDiagram after creating it, you need to `dpd.find_stable_charges()` to update the transition level map etc.
- Should tag parsed defects with `is_shallow` (or similar), and then omit these from plotting/analysis
(and note this behaviour in examples/docs)
Expand Down Expand Up @@ -127,14 +106,6 @@
workflow in the docs etc.
- `py-sc-fermi` may have functionality for dealing with complex defect concentrations in the future
(see Slack with Alex; 07/06/23)
- Parsing capability for (non-defect) polarons, so they can then be plotted alongside defects on
formation energy diagrams. Main things for this are:
- Input file generation
- Parsing to determine polaron site (so we can then use charge corrections). Use the site of max
displacement / bond length difference for this, and future work could be parsing of charge densities
to get the maximum position. (Note in docs that the user can do this if they want it).
- General plotting (in transition level diagrams) and analysis (e.g. our site displacement/strain
functions).
- `pydefect` integration, so we can use:
- Handling of shallow defects
- Readily automated with `vise` if one wants (easy high-throughput and can setup primitive calcs (BS, DOS, dielectric).
Expand All @@ -155,9 +126,9 @@

- Docs:
- Create GGA practice workflow, for people to learn how to work with doped and defect calculations
- Add note about `NUPDOWN` for triplet states (bipolarons).
- Add our recommended workflow (gam, NKRED, std, ncl). Cite
- https://iopscience.iop.org/article/10.1088/1361-648X/acd3cf for validation of Voronoi tessellation
- Add note about `NUPDOWN` for triplet states (bipolarons or dimers (e.g. C-C in Si apparently has ~0.5 eV energy splitting (10.1038/s41467-023-36090-2), and O-O in STO from Kanta?)).
- Add our recommended workflow (gam, NKRED, std, ncl). See https://sites.tufts.edu/andrewrosen/density-functional-theory/vasp/ for some possibly useful general tips.
- Cite https://iopscience.iop.org/article/10.1088/1361-648X/acd3cf for validation of Voronoi tessellation
approach for interstitials, but note user can use charge-density based approach if needing to be
super-lean for some reason. Can use SMTG wiki stuff for this.
- Regarding competing phases with many low-energy polymorphs from the Materials Project; will build
Expand Down Expand Up @@ -188,13 +159,13 @@
this to their docs as example use cases as well. Add our thesis sc-fermi analysis notebooks to tutorials. Also include examples of extending to
non-radiative carrier capture calcs with `CarrierCapture.jl` and `nonrad`. Show example of using
`sumo` to get the DOS plot of a defect calc, and why this is useful.
- Update `doped` links on `SnB`/`easyunfold` etc docs.
- Worth adding a very short example showing how to set `MAGMOM`s for AFM/FM systems (see Dan & Abdullah chat)
- Note about SOC for chemical potential calculations ([FERE paper](https://doi.org/10.1103/PhysRevB.
85.115104) suggests that the SOC effects on total energy cancel out for chemical potential
calculations, but only the case when the occupation of the SOC-affected orbitals is constant
(typically not the case)) Better to do consistently (link Emily SOC work and/or thesis).
- Link to Irea review, saying that while spin and configurational degeneracies are accounted for
automatically in `doped`, excited-state degeneracy (e.g. with bipolarons with single and triplet
automatically in `doped`, excited-state degeneracy (e.g. with bipolarons/dimers with single and triplet
states) are not, so the user should manually account for this if present. Also note that
temperature effects can be important in certain cases so see this review if that's the case.
- The Wyckoff analysis code is very useful and no other package can do this afaik. See
Expand All @@ -203,7 +174,7 @@
paper.
- Note that charge states are guessed based on different factors, but these rely on auto-determined
oxidation states and can fail in weird cases. As always please consider if these charge states are
reasonable for the defects in your system.
reasonable for the defects in your system. (i.e. low-symmetry, amphoteric, mixed-valence cases etc!)
- Show quick example case of the IPR code from `pymatgen-analysis-defects` (or from Adair code? or others?)
- Should flick through other defect codes (see
https://shakenbreak.readthedocs.io/en/latest/Code_Compatibility.html, also `AiiDA-defects`) and see if
Expand Down
38 changes: 38 additions & 0 deletions Future_ToDo.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
# `doped` Future Development WishList
## Defect calculations set up
- CLI Functionality for core functions.
- Could also use some of the `snb` functions to add some convenience commands which `cp CONTCAR
POSCAR` for unconverged `vasp_gam`/`vasp_nkred_std`/`vasp_std` calculations, and copies `CONTCAR`s
to next VASP folder when converged and submits job.
- Defect complexes: Functionality to setup and parse calculations – can do this with new `pymatgen`
code? Note that our defect-centring code is currently not implemented for this!
- Add input file generation for FHI-AIMs, CP2K, Quantum Espresso and CASTEP (using SnB functions),
point to post-processing tools for these online (in docs/example notebooks, `aiida-defects` for QE,
https://github.com/skw32/DefectCorrectionsNotebook for AIMs...),
and give example(s) of how to manually generate a `DefectPhaseDiagram` and chempots from the parsed
energies of these calculations, so the `doped` analysis tools can then be used.
- Add defect expansion code functionality to regenerate defect structures from a smaller supercell in a
larger one. Useful for supercell size convergence tests, and accelerating `ShakeNBreak` etc. If/when
adding, make sure to link in `SnB` docs as well.
- Related point, using our `doped` site-matching functions, could write some quick functions to plot
the exponential tailing off of strain / site displacements as we move away from the defect site.
Could be useful as a validation / check of supercell size convergence, and for quantifying the
strain / distortion introduced by a certain defect (though I guess the `SnB` tools already do a
good job of that) – could possibly give a good rule-of-thumb to aim for with a sufficiently large cell?
- For defect complexes, after electrostatics, the next biggest factor in binding energies is the stress field (right)? Then orbital effects after that.
This means that if we have the distortion field implemented in doped, we should be able to fairly accurately and easily predict if defect complexes are likely? (Via concentrations/formation energies, charges and stress fields?) Nice use case, could mention in JOSS as possible screening application if someone wanted to use it. Deak & Gali Nature Comms (10.1038/s41467-023-36090-2) C-C in Si could be used as a nice test case (neutral so no charge effects)
- Just something to keep in mind; new defect generation code can apparently use oxidation states from
`defect.defect_structure` and map to defect supercell. Not in our current subclass implementation of
`Defect`. Is this useful info?
- Ideally, one should be able to input just defect objects somewhere -> an alternative input to `DefectsGenerator`?
Depends where we want supercell generation to happen. Can input to both `DefectsGenerator` or `DefectsSet` (but it'll just send it to `DefectsGenerator` with `kwargs`).

## Post-Processing
- Parsing capability for (non-defect) polarons, so they can then be plotted alongside defects on
formation energy diagrams. Main things for this are:
- Input file generation
- Parsing to determine polaron site (so we can then use charge corrections). Use the site of max
displacement / bond length difference for this, and future work could be parsing of charge densities
to get the maximum position. (Note in docs that the user can do this if they want it).
- General plotting (in transition level diagrams) and analysis (e.g. our site displacement/strain
functions).
12 changes: 6 additions & 6 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,10 +1,10 @@
[![Build status](https://github.com/SMTG-UCL/doped/actions/workflows/test.yml/badge.svg)](https://github.com/SMTG-UCL/doped/actions)
[![Build status](https://github.com/SMTG-Bham/doped/actions/workflows/test.yml/badge.svg)](https://github.com/SMTG-Bham/doped/actions)
[![Documentation Status](https://readthedocs.org/projects/doped/badge/?version=latest&style=flat)](https://doped.readthedocs.io/en/latest/)
[![PyPI](https://img.shields.io/pypi/v/doped)](https://pypi.org/project/doped)
[![Conda Version](https://img.shields.io/conda/vn/conda-forge/doped.svg)](https://anaconda.org/conda-forge/doped)
[![Downloads](https://img.shields.io/pypi/dm/doped)](https://pypi.org/project/doped)

<a href="https://doped.readthedocs.io/en/latest/"><img align="right" width="275" src="https://raw.githubusercontent.com/SMTG-UCL/doped/master/docs/doped_v2_logo.png"></a>`doped` is a python package for
<a href="https://doped.readthedocs.io/en/latest/"><img align="right" width="275" src="https://raw.githubusercontent.com/SMTG-Bham/doped/master/docs/doped_v2_logo.png" alt="Schematic of a doped (defect-containing) crystal, inspired by the biological analogy to (semiconductor) doping." title="Schematic of a doped (defect-containing) crystal, inspired by the biological analogy to (semiconductor) doping."></a>`doped` is a python package for
managing solid-state defect calculations, with functionality to
generate defect structures and relevant competing phases (for chemical potentials), interface with
[`ShakeNBreak`](https://shakenbreak.readthedocs.io) for
Expand All @@ -16,7 +16,7 @@ Tutorials showing the code functionality and usage are provided on the [docs](ht
### Example Outputs:
Chemical potential/stability region plots and defect formation energy (a.k.a. transition level) diagrams:

<a href="https://doped.readthedocs.io/en/latest/dope_chemical_potentials.html#analysing-and-visualising-the-chemical-potential-limits"><img align="left" width="365" src="https://raw.githubusercontent.com/SMTG-UCL/doped/master/docs/doped_chempot_plotting.png"></a> <a href="https://doped.readthedocs.io/en/latest/dope_parsing_example.html#defect-formation-energy-transition-level-diagrams"><img align="right" width="385" src="https://raw.githubusercontent.com/SMTG-UCL/doped/master/docs/doped_TLD_plot.png"></a>
<a href="https://doped.readthedocs.io/en/latest/dope_chemical_potentials.html#analysing-and-visualising-the-chemical-potential-limits"><img align="left" width="365" src="https://raw.githubusercontent.com/SMTG-Bham/doped/master/docs/doped_chempot_plotting.png"></a> <a href="https://doped.readthedocs.io/en/latest/dope_parsing_example.html#defect-formation-energy-transition-level-diagrams"><img align="right" width="385" src="https://raw.githubusercontent.com/SMTG-Bham/doped/master/docs/doped_TLD_plot.png"></a>
<br><br><br><br><br><br><br><br><br><br><br>


Expand All @@ -37,13 +37,13 @@ See the docs [Installation](https://doped.readthedocs.io/en/latest/Installation.


## `ShakeNBreak`
As shown in the example notebook, it is highly recommended to use the [`ShakeNBreak`](https://shakenbreak.readthedocs.io/en/latest/) approach when calculating point defects in solids, to ensure you have identified the groundstate structures of your defects. As detailed in the [theory paper](https://arxiv.org/abs/2207.09862), skipping this step can result in drastically incorrect formation energies, transition levels, carrier capture (basically any property associated with defects). This approach is followed in the [doped example notebook](https://github.com/SMTG-UCL/doped/blob/master/dope_workflow_example.ipynb), with a more in-depth explanation and tutorial given on the [ShakeNBreak](https://shakenbreak.readthedocs.io/en/latest/) website.
As shown in the example notebook, it is highly recommended to use the [`ShakeNBreak`](https://shakenbreak.readthedocs.io/en/latest/) approach when calculating point defects in solids, to ensure you have identified the groundstate structures of your defects. As detailed in the [theory paper](https://arxiv.org/abs/2207.09862), skipping this step can result in drastically incorrect formation energies, transition levels, carrier capture (basically any property associated with defects). This approach is followed in the [doped example notebook](https://github.com/SMTG-Bham/doped/blob/master/dope_workflow_example.ipynb), with a more in-depth explanation and tutorial given on the [ShakeNBreak](https://shakenbreak.readthedocs.io/en/latest/) website.

Summary GIF:
![ShakeNBreak Summary](https://raw.githubusercontent.com/SMTG-UCL/ShakeNBreak/main/docs/SnB_Supercell_Schematic_PES_2sec_Compressed.gif)
![ShakeNBreak Summary](https://raw.githubusercontent.com/SMTG-Bham/ShakeNBreak/main/docs/SnB_Supercell_Schematic_PES_2sec_Compressed.gif)

`SnB` CLI Usage:
![ShakeNBreak CLI](https://raw.githubusercontent.com/SMTG-UCL/ShakeNBreak/main/docs/SnB_CLI.gif)
![ShakeNBreak CLI](https://raw.githubusercontent.com/SMTG-Bham/ShakeNBreak/main/docs/SnB_CLI.gif)


## Acknowledgments
Expand Down
6 changes: 3 additions & 3 deletions docs/Contributing.rst
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ Contributing
Bugs reports, feature requests and questions
---------------------------------------------

Please use the `Issue Tracker <https://github.com/SMTG-UCL/doped/issues>`_ to report bugs or
Please use the `Issue Tracker <https://github.com/SMTG-Bham/doped/issues>`_ to report bugs or
request new features. Contributions to extend this package are very welcome! 😃
Please use the usual
`Fork and Pull <https://docs.github.com/en/get-started/quickstart/contributing-to-projects>`_
Expand All @@ -16,7 +16,7 @@ workflow to do so.
Tests
-------

Unit tests are in the `tests <https://github.com/SMTG-UCL/doped/tree/master/tests>`_ directory
Unit tests are in the `tests <https://github.com/SMTG-Bham/doped/tree/master/tests>`_ directory
and can be run from the top directory using ``pytest``. Automatic testing is run on the master and
develop branches using `Github Actions <https://github.com/SMTG-UCL/doped/actions>`_. Please
develop branches using `Github Actions <https://github.com/SMTG-Bham/doped/actions>`_. Please
run tests and add new tests for any new features whenever submitting pull requests.
2 changes: 1 addition & 1 deletion docs/Installation.rst
Original file line number Diff line number Diff line change
Expand Up @@ -76,7 +76,7 @@ the ``doped`` GitHub repository:

.. code-block:: bash
git clone https://github.com/SMTG-UCL/doped
git clone https://github.com/SMTG-Bham/doped
#. Navigate to root directory:

Expand Down
Loading

0 comments on commit 7e727d9

Please sign in to comment.