Alloy Catalysis Automated Toolkit
Project description
ACAT: Alloy Catalysis Automated Toolkit
ACAT is a Python package for atomistic modelling of metal / alloy catalysts used in heterogeneous catalysis. The package is based on automatic identifications of adsorption sites and adsorbate coverages on surface slabs and nanoparticles. Synergized with ASE, ACAT provides useful tools for building atomistic models of alloy catalysts with and without adsorbates. The goal is to automate workflows so that the structure generations can be readily adapted in a global optimization.
ACAT has been developed by Shuang Han at the Section of Atomic Scale Materials Modelling, Department of Energy Conversion and Storage, Technical University of Denmark (DTU) in Lyngby, Denmark.
To use ACAT, please read ACAT documentation.
Developers:
Shuang Han (shuha@dtu.dk) - current maintainer
Dependencies
- python>=3.6
- networkx>=2.4
- ase
- asap3
Installation
Install via pip:
pip3 install acat
Clone the repository:
git clone https://gitlab.com/asm-dtu/acat.git
Go to the installed path and install all dependencies:
pip3 install -r requirements.txt
Install the main package:
python3 setup.py install
Acknowledgements
I would like to highly appreciate the support from BIKE project, where fundings are received from the European Union’s Horizon 2020 Research and Innovation programme under the Marie Skłodowska-Curie Action – International Training Network (MSCA-ITN), grant agreement 813748.
I also want to thank Dr. Steen Lysgaard for the useful scripts and Dr. Giovanni Barcaro, Dr. Alessandro Fortunelli for the useful discussions.
Known issues
- Some functions distinguishes between nanoparticle and surface slabs based on periodic boundary condition (PBC). Therefore, before using the code, it is recommended to set all directions as non-periodic for nanoparticles and at least one direction periodic for surface slabs, and also add vacuum layers to all non-periodic directions. Note that the half-top half-bottom slab model is not supported by the code. Please make sure the slab is a unity.
- ACAT uses a regularized adsorbate string representation. In each adsorbate string, the first element must set to the bonded atom. If the adsorbate is multi-dentate, the order follows the order of their atomic numbers. Hydrogen should always follow the element that it bonds to. For example, water should be written as 'OH2', hydrogen peroxide should be written as 'OHOH', ethanol should be written as 'CH3CH2OH', formyl should be written as 'CHO', hydroxymethylidyne should be written as 'COH'. If the string is not supported by the code, it will return the ase.build.molecule instead, which could result in a weird orientation. If the string is not supported by this code nor ASE, you can make your own molecules in the adsorbate_molecule function in acat.settings.
- There is a bug that causes
get_neighbor_site_list()
to not return the correct neighbor site indices with ASE version <= 3.18. This is most likely due to shuffling of indices in some ASE functions, which is solved after the release of ASE 3.19.0.
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
File details
Details for the file acat-1.0.2.tar.gz
.
File metadata
- Download URL: acat-1.0.2.tar.gz
- Upload date:
- Size: 76.9 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/3.10.1 pkginfo/1.5.0.1 requests/2.24.0 requests-toolbelt/0.9.1 tqdm/4.56.2 CPython/3.8.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | baba7c54d89309fbd1285e3355d7a776cf9e54a34b09864987d0ca85a74719f7 |
|
MD5 | f8f7f77f559a6ebd4f8ef9b1a5c351bb |
|
BLAKE2b-256 | 97af8bc4c4d9961119d8917eb61feff4e6534d70729bd2887002eca7fd1cf02b |