This repository has been archived by the owner on Jun 2, 2022. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 33
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #36 from oxana-a/oxana-a-patch-1
Create structure-similarity.md
- Loading branch information
Showing
1 changed file
with
91 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,91 @@ | ||
# Structure similarity | ||
## Introduction | ||
The similarity between two structures *i* and *j* is assessed on the basis of local coordination information from all sites in the two structures. [^1] [^2] The four basic steps involved are: | ||
|
||
1. Find near(est) neighbors of all sites in both structures. | ||
2. Evaluate each coordination pattern via coordination descriptors observed at each site to define site fingerprints. | ||
3. Compute statistics of the descriptor values across all sites in a structure to define structure fingerprints. | ||
4. Use structure fingerprints to rate the (dis)similarity between the two (vectors representing the two) structures. | ||
|
||
## Near-neighbor finding | ||
We use a novel method called CrystallNN to find near(est) neighbors in periodic structures. While the method will be introduced shortly[^3], it is already available through the python package [pymatgen](https://github.com/materialsproject/pymatgen). | ||
|
||
## Site Fingerprints | ||
The second step of the structure similarity calculation is the computation of a crystal site fingerprint, $v^{site}$, for each site in the two structures. The fingerprint is a 61-dimensional vector in which each element carries information about the local coordination environment computed with the *site* module of the python package [matminer](https://github.com/hackingmaterials/matminer). For example, the first two elements "wt $\ce{CN1}$" and "single bond $\ce{CN1}$" provide estimates of the likelihood (or weight) of how much the given site should be considered 1-fold coordinated (i.e., *w*$|_{CN=1}$). The third element "wt $\ce{CN2}$" provides a 2-fold coordination likelihood, whereas the fourth element "L-shaped $\ce{CN2}$" holds the resemblance similarity to an L-shaped coordination geometry (also called local structure order parameter) given that we find a coordination configuration with 2 atoms ($q_{L}|_{CN=2}$). The local structure order parameters can assume values between 0, meaning that the observed local environment has no resemblance with the target motif to which it is compared, and 1, which stands for perfect motif match. The remaining elements are: "water-like $\ce{CN2}$," "bent 120 degrees $\ce{CN2}$," "bent 150 degrees $\ce{CN2}$," "linear $\ce{CN2}$," "wt $\ce{CN3}$," "trigonal planar $\ce{CN3}$," "trigonal non-coplanar $\ce{CN3}$," "T-shaped $\ce{CN3}$," "wt $\ce{CN4}$," "square co-planar $\ce{CN4}$," "tetrahedral $\ce{CN4}$," "rectangular see-saw-like $\ce{CN4}$," "see-saw-like $\ce{CN4}$," "trigonal pyramidal $\ce{CN4}$," "wt $\ce{CN5}$," "pentagonal planar $\ce{CN5}$," "square pyramidal $\ce{CN5}$," "trigonal bipyramidal $\ce{CN5}$," "wt $\ce{CN6}$," "hexagonal planar $\ce{CN6}$," "octahedral $\ce{CN6}$," "pentagonal pyramidal $\ce{CN6}$," "wt $\ce{CN7}$," "hexagonal pyramidal $\ce{CN7}$," "pentagonal bipyramidal $\ce{CN7}$," "wt $\ce{CN8}$," "body-centered cubic $\ce{CN8}$," "hexagonal bipyramidal $\ce{CN8}$," "wt $\ce{CN9}$," "q2 $\ce{CN9}$," "q4 $\ce{CN9}$," "q6 $\ce{CN9}$," "wt $\ce{CN10}$," "q2 $\ce{CN10}$," "q4 $\ce{CN10}$," "q6 $\ce{CN10}$," "wt $\ce{CN11}$," "q2 $\ce{CN11}$," "q4 $\ce{CN11}$," "q6 $\ce{CN11}$," "wt $\ce{CN12}$," "cuboctahedral $\ce{CN12}$," "q2 $\ce{CN12}$," "q4 $\ce{CN12}$," "q6 $\ce{CN12}$," "wt $\ce{CN13}$," "wt $\ce{CN14}$," "wt $\ce{CN15}$," "wt $\ce{CN16}$," "wt $\ce{CN17}$," "wt $\ce{CN18}$," "wt $\ce{CN19}$," "wt $\ce{CN20}$," "wt $\ce{CN21}$," "wt $\ce{CN22}$," "wt $\ce{CN23}$," and "wt $\ce{CN24}$." Note that $q_{n}$ refers to Steinhardt bond orientational order parameter of order *n*. The resulting site fingerprint is thus defined as: | ||
$$ | ||
\mathbf{v}^\mathrm{site} = [w|_{\mathrm{CN}=1}, \quad w|_{\mathrm{CN}=2}, \quad q_\mathrm{L}|_{\mathrm{CN}=2}, \quad q_\mathrm{water}|_{\mathrm{CN}=2}, \quad \dots, \quad w|_{\mathrm{CN}=24}]^\mathrm{T} | ||
$$ | ||
|
||
## Structure Fingerprints | ||
The fingerprints from sites in a given structure are subsequently statistically processed to yield the minimum, maximum, mean, and standard deviation of each coordination information element. The resultant ordered vector defines a structure fingerprint, $v^{struct}$: | ||
|
||
$$ | ||
\mathbf{v}^\mathrm{struct} = [ | ||
\min(w|_{\mathrm{CN}=1}), \quad \max(w|_{\mathrm{CN}=1}), \quad \mathrm{mean}(w|_{\mathrm{CN}=1}), \quad \mathrm{std}(w|_{\mathrm{CN}=1}), \dots, | ||
\min(w|_{\mathrm{CN}=24}), \quad \max(w|_{\mathrm{CN}=24}), \quad \mathrm{mean}(w|_{\mathrm{CN}=24}), \quad \mathrm{std}(w|_{\mathrm{CN}=24}) | ||
]^\mathrm{T} | ||
$$ | ||
|
||
## Structure Distance/Dissimilarity | ||
Finally, structure similarity is determined by the distance, *d*, between two structure fingerprints $v_{i}^{struct}$ and $v_{j}^{struct}$: | ||
|
||
$$ | ||
d = || \mathbf{v}_{i}^\mathrm{struct} - \mathbf{v}_{j}^\mathrm{struct} || | ||
$$ | ||
|
||
A small distance value indicates high similarity between two structures, whereas a large distance (>1) suggests that the structures are very dissimilar. The spinel example below gives an approximate threshold up to which **distance you can still consider two structures to be similar (0.9)**. Anything beyond 0.9 is most certainly not the same structure prototype. | ||
|
||
## Examples | ||
* Diamond ([mp-66](https://materialsproject.org/materials/mp-66/)) vs. $\ce{GaAs}$ ([mp-2534](https://materialsproject.org/materials/mp-2534/)) $\rightarrow$ *d* = 0 | ||
* Diamond ([mp-66](https://materialsproject.org/materials/mp-66/)) vs. rocksalt ([mp-22862](https://materiahttps://materialsproject.org/materials/mp-5827/lsproject.org/materials/mp-22862/)) $\rightarrow$ *d* = 3.5724 | ||
* Diamond ([mp-66](https://materialsproject.org/materials/mp-66/)) vs. perfect $\ce{CaTiO3}$ perovskite ([mp-5827](https://materialsproject.org/materials/mp-5827/)) $\rightarrow$ *d* = 3.5540 | ||
* Rocksalt ([mp-22862](https://materialsproject.org/materials/mp-22862/)) vs. perfect $\ce{CaTiO3}$ perovskite ([mp-5827](https://materialsproject.org/materials/mp-5827/)) $\rightarrow$ *d* = 2.7417 | ||
* $\ce{Ca(CoS2)2}$-spinel ([mvc-12728](https://materialsproject.org/materials/mvc-12728/)) vs. $\ce{Si(CdO2)2}$-spinel ([mp-560842](https://materialsproject.org/materials/mp-560842/)) $\rightarrow$ *d* = 0.8877 | ||
|
||
Below is a python code snippet that allows you to quickly reproduce above results. You will need to install [pymatgen](https://github.com/materialsproject/pymatgen) and [matminer](https://github.com/hackingmaterials/matminer) for this to work. Both are easily accessible via the [Python Package Index](https://pypi.python.org/pypi). | ||
|
||
```python | ||
import numpy as np | ||
from pymatgen import MPRester | ||
from matminer.featurizers.site import CrystalNNFingerprint | ||
from matminer.featurizers.structure import SiteStatsFingerprint | ||
|
||
with MPRester() as mpr: | ||
|
||
# Get structures. | ||
diamond = mpr.get_structure_by_material_id("mp-66") | ||
gaas = mpr.get_structure_by_material_id("mp-2534") | ||
rocksalt = mpr.get_structure_by_material_id("mp-22862") | ||
perovskite = mpr.get_structure_by_material_id("mp-5827") | ||
spinel_caco2s4 = mpr.get_structure_by_material_id("mvc-12728") | ||
spinel_sicd2O4 = mpr.get_structure_by_material_id("mp-560842") | ||
|
||
# Calculate structure fingerprints. | ||
ssf = SiteStatsFingerprint( | ||
CrystalNNFingerprint.from_preset('ops', distance_cutoffs=None, x_diff_weight=0), | ||
stats=('mean', 'std_dev', 'minimum', 'maximum')) | ||
v_diamond = np.array(ssf.featurize(diamond)) | ||
v_gaas = np.array(ssf.featurize(gaas)) | ||
v_rocksalt = np.array(ssf.featurize(rocksalt)) | ||
v_perovskite = np.array(ssf.featurize(perovskite)) | ||
v_spinel_caco2s4 = np.array(ssf.featurize(spinel_caco2s4)) | ||
v_spinel_sicd2O4 = np.array(ssf.featurize(spinel_sicd2O4)) | ||
|
||
# Print out distance between structures. | ||
print('Distance between diamond and GaAs: {:.4f}'.format(np.linalg.norm(v_diamond - v_gaas))) | ||
print('Distance between diamond and rocksalt: {:.4f}'.format(np.linalg.norm(v_diamond - v_rocksalt))) | ||
print('Distance between diamond and perovskite: {:.4f}'.format(np.linalg.norm(v_diamond - v_perovskite))) | ||
print('Distance between rocksalt and perovskite: {:.4f}'.format(np.linalg.norm(v_rocksalt - v_perovskite))) | ||
print('Distance between Ca(CoS2)2-spinel and Si(CdO2)2-spinel: {:.4f}'.format(np.linalg.norm(v_spinel_caco2s4 - v_spinel_sicd2O4))) | ||
``` | ||
|
||
## References | ||
[^1]: N. E. R. Zimmermann, D. Winston, K. A. Persson, A. Jain, in preparation (2018) | ||
[^2]: 10.3389/fmats.2017.00034 | ||
[^3]: H. Pan, J. Dagdelen, N. E. R. Zimmermann, A. Jain, in preparation (2018) | ||
|
||
## Authors | ||
Nils Zimmermann, Donny Winston, Handong Ling, Oxana Andriuc |