Skip to main content

Alloy Catalysis Automated Toolkit

Project description

ACAT: Alloy Catalysis Automated Toolkit

ACAT is a Python package for atomistic modelling of metal or alloy catalysts used in heterogeneous catalysis. The package is based on automatic identifications of adsorption sites and adsorbate coverages on surface slabs and nanoparticles. Synergizing with ASE, ACAT provides useful tools to build atomistic models and perform global optimization tasks for alloy surfaces and nanoparticles with and without adsorbates. The goal is to automate workflows for the high-throughput screening of alloy catalysts.

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 (and also examples). For all symmetry-inequivalent adsorption sites on the surfaces (and nanoparticles) supported in ACAT, please refer to the table of adsorption sites.

Developers:

Shuang Han (shuha@dtu.dk) - current maintainer

Dependencies

  • python>=3.6
  • networkx>=2.4
  • ase
  • asap3 (strongly recommended but not required, since asap3 does not support Windows)

Installation

Install via pip:

pip3 install acat

Alternatively, you can clone the repository:

git clone https://gitlab.com/asm-dtu/acat.git

then go to the installed path and install all dependencies:

pip3 install -r requirements.txt

Finally, 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.

How to cite ACAT

If you find ACAT useful in your research, please cite the paper below. This is a preprint

[1] S. Han, S. Lysgaard, T. Vegge & H. A. Hansen (submitted). 

If you use ACAT's modules related to symmetric nanoalloy, please also cite this paper:

[2] S. Han, G. Barcaro, A. Fortunelli et al. Unfolding the structural stability of nanoalloys via 
symmetry-constrained genetic algorithm and neural network potential. npj Comput. Mater. 8, 121 (2022).

Known issues

  1. ACAT currently only support metal / alloy surface slabs and nanoparticles. Therefore H, C, N, O, F, S and Cl atoms are treated as adsorbate molecules and metals are treated as catalyst by default. Please do not use ACAT for metal oxide catalysts.

  2. Some functions distinguishes between nanoparticle and surface slabs based on periodic boundary condition (PBC). Therefore, before using the code, it is recommended (but not required) 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. For periodic surface slabs the code will not work if the number of layers is less than 3 (which should be avoided anyways). Each layer is by default considered to always have the same number of atoms as the surface atoms. For stepped surface slabs one layer will have atoms at different z coordinates. However, note that there is no limitation to the size of the cell in the x and y directions. ACAT is able to identify adsorption sites for even a 1x1x3 cell with only one surface atom.

  3. 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 with. 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. Note that you can always operate on an adsorbate that is an ase.Atoms object, instead of using a string representation.

  4. 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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

acat-1.5.0.tar.gz (60.6 MB view details)

Uploaded Source

File details

Details for the file acat-1.5.0.tar.gz.

File metadata

  • Download URL: acat-1.5.0.tar.gz
  • Upload date:
  • Size: 60.6 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.11.3 pkginfo/1.5.0.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.56.2 CPython/3.8.6

File hashes

Hashes for acat-1.5.0.tar.gz
Algorithm Hash digest
SHA256 a7cf948cd9643d7d41f56faf71c90c6bb84b8039fdb93e6e5c0418c4acf677a4
MD5 b91cf4f1517fc03a23d8dd67b1ed611f
BLAKE2b-256 0a71f2ef268b23fd95b9f3dd3d493ee45eb424c49eeb76abe44634e380e4d91e

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page