A python package for CSRO paramater calculation
Project description
pyCSRO: a python package for calculating chemical short range ordering.
pyCSRO is a python package using pairwise multi-component short-range order (PM-SRO) parameters to discover the chemical short range ordering in materials, including crystalline, amorphous, and high-entropy alloys, etc. The PM-SRO parameter was extended from the Warren-Cowley short-range order (WC-SRO) to describe the local distribution of element pairs in the multicomponent system, which is defined as:
$$\alpha_{ij}^m=\frac{p_{ij}^m - X_j}{X_j-1}\quad \text{($i = j$, for pairs of same species)}$$
$$\alpha_{ij}^m=\frac{p_{ij}^m - X_j}{-X_j}\quad \text{($i \neq j$, for pairs of different species)}$$
where $p_{ij}^m$ is the average probability of finding a $j$-type atom around an $i$-type atom in the $m$-th shell, and $X_j$ is the overall concentration of $j$ atoms in the system. A negative value of $\alpha_{ij}^m$ indicates the tendency of mixing of $i$ and $j$ atoms, whereas a positive one suggests the tendency toward segregation of $i$ and $j$ atoms. And the value of $\alpha_{ij}^m$ would be zero if $i$ and $j$ atoms are randomly distributed.
Note that in order to keep the same meaning of the $\alpha_{ij}^m$ value when $i=j$ and $i \neq j$, such that a negative $\alpha_{ij}^m$ means tendency of mixing and a positive $\alpha_{ij}^m$ means tendency of segregation, the equation of PM-SRO for $i = j$ has been rewritten.
Required Dependencies:
- Python 3.9+
- matplotlib
- numpy
- scipy
- ase
Installation
The pyCSRO package requires Python 3.9 or later, and run the following command to install it:
pip install pycsro
If you prefer to install from sources, navigate to the source archive directory and run:
python setup.py install
Usage
from pycsro.main import run_pycsro_pmsro
run_pycsro_pmsro(ion1, cutoff1, file_name, cutoff2, save_name, skip_distance, plot_save, cal_same_pair, safe_mode, partial_neighbors)
-
ion1: The selected elements for the PM-SRO calculation. (Required, range: elements in the structure model, type: str)
-
cutoff1: The cutoff of thr 1st shell. (Required, range: positive number, type: float)
-
cutoff2: The cutoff of the 2nd shell. (Cutoff2 should be equal or greater than cutoff1, range: positive number, type: float)
-
file_name: The absolute path of input file. (Required, type: str)
-
save_name: The absolute path of saved file. (type: str)
-
skip_distance: Skip the neighbor distance under this parameter. (Default: 0.1, range: positive number, type: float)
-
cal_same_pair: Whether calculate the wcp of same elements but different center atoms. (Default: Yes, range: Yes or No, type: str)
-
safe_mode: Whether use the supercell selection function, which can reduce the calculation time. (Default: No, range: Yes or No, type: str)
-
plot_save: Whether save the neighbor plot. (Default: No, range: Yes or No, type: str)
-
partial_neighbors: Whether plot the partial neighbor distribution of atoms in the cell. (Default: No, range: Yes or No, type: str)
Attention:
- The calculation requires the user to input parameters of ion1, cutoff1, and filename.
- Supported input file formats include CIF, POSCAR.
- For compounds, cations and anions should be placed in different ion groups, and calculated separately.
- You can try a larger cutoff value at the first time, and then adjust the cutoff value to the trough of the neighbor distribution.
- The second shell was defined as cutoff1 to cutoff2.
Example
Example models are placed at /example/
.
The basic command for running Ni system:
run_pycsro_pmsro(ion1='Ni', cutoff1=3, file_name='XXX/pyCSRO/example/Ni.vasp')
The output:
+-----------------------------------------------------------------------------
| Element group: ['Ni']
| Cutoff for the 1st shell: 3 Å Cutoff for the 2nd shell: None
| Read file: Ni.vasp Save file: None
| Skip neighbor distance under 0.1 Å
| Calculate same pair: Yes Safe mode: No
+-----------------------------------------------------------------------------
| The PM-SRO parameter for ['Ni'] element group in the 1st shell
| Ni-Ni 0.0
+-----------------------------------------------------------------------------
Contacts
For more information, please email Prof. Long Yang at long_yang@tongji.edu.cn
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file pycsro-0.1.0.tar.gz
.
File metadata
- Download URL: pycsro-0.1.0.tar.gz
- Upload date:
- Size: 11.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1bc3752f0440649dfba048ef4785a3a50d063b881d43cc9128ff8ea2fab77dcb |
|
MD5 | 01e4f07e84aa23c51bced71d466d700e |
|
BLAKE2b-256 | dfdce89658060db82aa04e28d1b100a314ab9f3ad5b961ac10f8b49e142aae4f |
File details
Details for the file pycsro-0.1.0-py3-none-any.whl
.
File metadata
- Download URL: pycsro-0.1.0-py3-none-any.whl
- Upload date:
- Size: 13.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | fe11e93501320bfe3f0d306c6a7f329cff9b91b706c11beb8eefb5f59e168209 |
|
MD5 | 7a404969c5af5fea0e4c6c241fb35faa |
|
BLAKE2b-256 | 962f5c867627a65d426c5acf4ed83048655f2055323ab1b703b3a9dae2b02340 |