Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

totally stuffed it, here are the actual changes #39

Merged
merged 42 commits into from
Oct 31, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
42 commits
Select commit Hold shift + click to select a range
65ec614
Account for (rare) possibility of users on non UTF-8 compatible syste…
kavanase Sep 5, 2023
136dc4a
Suppress locale Error if not supported on GH Actions
kavanase Sep 5, 2023
7a41dc2
Add instructions on files needed for defect parsing, how to compress …
kavanase Sep 5, 2023
0a53118
Update `matplotlib` requirement
kavanase Sep 7, 2023
3d5d949
Update POTCAR testing and remove old generation notebook
kavanase Sep 7, 2023
2d91742
Update `pycairo` warning
kavanase Sep 7, 2023
f2b2ae3
Formatting
kavanase Sep 14, 2023
fb4098b
Italicise "V" for vacancy in plotting
kavanase Sep 16, 2023
1eda675
Add supercell_gen_kwargs test
kavanase Sep 16, 2023
6d1110b
Update oxi-state handling to use pre-assigned oxi states if present
kavanase Sep 16, 2023
8f13966
Use "Guessed Charges" in defect info output, to try encourage the use…
kavanase Sep 16, 2023
6abc6b3
Refactor oxidation state handling to avoid `pymatgen` failures
kavanase Sep 16, 2023
7672e33
Skip interstitial generation if gen_kwargs set to False
kavanase Sep 16, 2023
54a08d6
If pymatgen oxi-state guessing fails, warn user and revert to (-1,0,+…
kavanase Sep 16, 2023
6a8bfb5
Ensure nicely-formatted italic V for vacancy in plotting
kavanase Sep 16, 2023
5a00b56
Add test for N-doped diamond supercell input (where `pymatgen` oxi st…
kavanase Sep 16, 2023
1e06e05
Update `probability_threshold` from testing
kavanase Sep 16, 2023
7513be0
Update defect generation tests to match
kavanase Sep 17, 2023
6d7937a
Add charge state setting tests for tricky amphoteric cases, and a lat…
kavanase Sep 17, 2023
3dca207
Add Sb2Si2Te6 charge state guessing case, tricky oxi-state guessing, …
kavanase Sep 17, 2023
02b8488
Add charge_state_gen_kwargs test
kavanase Sep 17, 2023
9b5a83f
Ensure guessed oxidation states are integers
kavanase Sep 17, 2023
d7589c8
Try guess oxi-states without using `max_sites` first, and timeout if …
kavanase Sep 17, 2023
c03375e
Add tests for all attributes of `DefectsGenerator`
kavanase Sep 17, 2023
8b847dc
Refactor development todo lists
kavanase Sep 17, 2023
9fbb098
Update `ToDo`s
kavanase Sep 17, 2023
7a44236
Add image Alt text
kavanase Sep 18, 2023
d490d56
Add static path
kavanase Sep 18, 2023
e2e51d7
Remove GH link
kavanase Sep 18, 2023
222d17e
Formatting
kavanase Sep 18, 2023
cc930b0
Refactor to SMTG-Bham
kavanase Sep 18, 2023
7c0f539
Remove unnecessary static path
kavanase Sep 18, 2023
33d9011
Formatting
kavanase Sep 18, 2023
e5ab70b
Bump changelong and version numbers before release
kavanase Sep 18, 2023
2d0378d
Bump changelog and version numbers before release
kavanase Sep 18, 2023
4d6bb85
Merge remote-tracking branch 'origin/develop' into develop
kavanase Sep 18, 2023
452022b
Merge remote-tracking branch 'origin/master' into develop
kavanase Sep 18, 2023
1b6458e
Update tests
kavanase Sep 18, 2023
e00b19f
doped `v2.0.5`
kavanase Sep 18, 2023
d119544
edits based on discussion with SK
alexsquires Oct 30, 2023
4052cb6
Merge branch 'SMTG-Bham:master' into master
alexsquires Oct 30, 2023
9cb2c6f
Merge branch 'dopey_fermi' into master
alexsquires Oct 31, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
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
Loading