acat


Nameacat JSON
Version 1.7.1 PyPI version JSON
download
home_pagehttps://gitlab.com/asm-dtu/acat
SummaryAlloy Catalysis Automated Toolkit
upload_time2023-12-19 03:14:46
maintainer
docs_urlNone
authorShuang Han
requires_python>=3.6
license
keywords
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # ACAT: **A**lloy **C**atalysis **A**utomated **T**oolkit
ACAT is a Python package for atomistic modelling of metal (alloy) (oxide) 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](https://asm-dtu.gitlab.io/acat)** (also [notebook tutorial](https://gitlab.com/asm-dtu/acat/-/blob/master/notebooks/) and [examples](examples/)). For all symmetry-inequivalent adsorption sites on the surfaces (and nanoparticles) supported in ACAT, please refer to the [table of adsorption sites](table_of_adsorption_sites.pdf).

![](images/acat_logo.png)

## Developers: 
Shuang Han (hanshuangshiren@gmail.com) - 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.

<img src="images/eu_logo.png" width="250"> &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; 
<img src="images/bike_logo.png" width="250">

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 [this paper](https://doi.org/10.1038/s41524-023-01087-4):

    [1] Han, S., Lysgaard, S., Vegge, T. et al. Rapid mapping of alloy surface phase diagrams via Bayesian 
    evolutionary multitasking. npj Comput. Mater. 9, 139 (2023). 

If you use ACAT's modules related to symmetric nanoalloy, please also cite [this paper](https://doi.org/10.1038/s41524-022-00807-6):

    [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).

## Notes

1. ACAT was originally developed for 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. Now ACAT is generalized for any given surface structure through ``acat.settings.CustomSurface``, which means (mixed) metal oxide surfaces are also allowed. However, note that the H, C, N, O, F, S and Cl atoms at the surface are still always treated as adsorabtes.

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 always has 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 (i.e. the closest non-hydrogen atom to the surface). 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', sulfur dioxide can be written either as 'SO2' (S down) or 'O2S' (S up). 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``.

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.

5. If the adsorption site identification by ``SlabAdsorptionSites`` is unsatisfactory, it is most likely due to a lattice mismatch of the input surface with the reference surface used for code parameterization. Most of the time this can be resolved by setting ``optimize_surrogate_cell=True``. If the result is still not good enough, you can always use the ``acat.settings.CustomSurface`` class to represent your surface.



            

Raw data

            {
    "_id": null,
    "home_page": "https://gitlab.com/asm-dtu/acat",
    "name": "acat",
    "maintainer": "",
    "docs_url": null,
    "requires_python": ">=3.6",
    "maintainer_email": "",
    "keywords": "",
    "author": "Shuang Han",
    "author_email": "hanshuangshiren@gmail.com",
    "download_url": "https://files.pythonhosted.org/packages/f8/3d/6ee723e4ad4ef5020eab174b9d179c80c5b3a1fc4c9bde08d732250ce660/acat-1.7.1.tar.gz",
    "platform": null,
    "description": "# ACAT: **A**lloy **C**atalysis **A**utomated **T**oolkit\nACAT is a Python package for atomistic modelling of metal (alloy) (oxide) 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.\n\nACAT 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.\n\nTo use ACAT, please read **[ACAT documentation](https://asm-dtu.gitlab.io/acat)** (also [notebook tutorial](https://gitlab.com/asm-dtu/acat/-/blob/master/notebooks/) and [examples](examples/)). For all symmetry-inequivalent adsorption sites on the surfaces (and nanoparticles) supported in ACAT, please refer to the [table of adsorption sites](table_of_adsorption_sites.pdf).\n\n![](images/acat_logo.png)\n\n## Developers: \nShuang Han (hanshuangshiren@gmail.com) - current maintainer\n\n## Dependencies\n* python>=3.6\n* networkx>=2.4\n* ase\n* asap3 (strongly recommended but not required, since asap3 does not support Windows)\n\n## Installation\nInstall via pip:\n\n```pip3 install acat```\n\nAlternatively, you can clone the repository:\n\n```git clone https://gitlab.com/asm-dtu/acat.git```\n\nthen go to the installed path and install all dependencies:\n\n```pip3 install -r requirements.txt```\n\nFinally, install the main package:\n\n```python3 setup.py install```\n \n## Acknowledgements\n\nI would like to highly appreciate the support from BIKE project, where fundings are received from the European Union\u2019s Horizon 2020 Research and Innovation programme under the Marie Sk\u0142odowska-Curie Action \u2013 International Training Network (MSCA-ITN), grant agreement 813748.\n\n<img src=\"images/eu_logo.png\" width=\"250\"> &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; \n<img src=\"images/bike_logo.png\" width=\"250\">\n\nI also want to thank Dr. Steen Lysgaard for the useful scripts and Dr. Giovanni Barcaro, Dr. Alessandro Fortunelli for the useful discussions.\n\n## How to cite ACAT\nIf you find ACAT useful in your research, please cite [this paper](https://doi.org/10.1038/s41524-023-01087-4):\n\n    [1] Han, S., Lysgaard, S., Vegge, T. et al. Rapid mapping of alloy surface phase diagrams via Bayesian \n    evolutionary multitasking. npj Comput. Mater. 9, 139 (2023). \n\nIf you use ACAT's modules related to symmetric nanoalloy, please also cite [this paper](https://doi.org/10.1038/s41524-022-00807-6):\n\n    [2] S. Han, G. Barcaro, A. Fortunelli et al. Unfolding the structural stability of nanoalloys via \n    symmetry-constrained genetic algorithm and neural network potential. npj Comput. Mater. 8, 121 (2022).\n\n## Notes\n\n1. ACAT was originally developed for 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. Now ACAT is generalized for any given surface structure through ``acat.settings.CustomSurface``, which means (mixed) metal oxide surfaces are also allowed. However, note that the H, C, N, O, F, S and Cl atoms at the surface are still always treated as adsorabtes.\n\n2. 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 always has 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.\n\n3. ACAT uses a regularized adsorbate string representation. In each adsorbate string, **the first element must set to the bonded atom (i.e. the closest non-hydrogen atom to the surface). 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', sulfur dioxide can be written either as 'SO2' (S down) or 'O2S' (S up). 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``.\n\n4. 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.\n\n5. If the adsorption site identification by ``SlabAdsorptionSites`` is unsatisfactory, it is most likely due to a lattice mismatch of the input surface with the reference surface used for code parameterization. Most of the time this can be resolved by setting ``optimize_surrogate_cell=True``. If the result is still not good enough, you can always use the ``acat.settings.CustomSurface`` class to represent your surface.\n\n\n",
    "bugtrack_url": null,
    "license": "",
    "summary": "Alloy Catalysis Automated Toolkit",
    "version": "1.7.1",
    "project_urls": {
        "Homepage": "https://gitlab.com/asm-dtu/acat"
    },
    "split_keywords": [],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "f83d6ee723e4ad4ef5020eab174b9d179c80c5b3a1fc4c9bde08d732250ce660",
                "md5": "2acde04ca3af0c5be2f831d34ff54636",
                "sha256": "91f3c6f06f72e86a8c30d50f2ced0630a22e18c65a12d486ff6f402d78e991f9"
            },
            "downloads": -1,
            "filename": "acat-1.7.1.tar.gz",
            "has_sig": false,
            "md5_digest": "2acde04ca3af0c5be2f831d34ff54636",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.6",
            "size": 61910805,
            "upload_time": "2023-12-19T03:14:46",
            "upload_time_iso_8601": "2023-12-19T03:14:46.403320Z",
            "url": "https://files.pythonhosted.org/packages/f8/3d/6ee723e4ad4ef5020eab174b9d179c80c5b3a1fc4c9bde08d732250ce660/acat-1.7.1.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2023-12-19 03:14:46",
    "github": false,
    "gitlab": true,
    "bitbucket": false,
    "codeberg": false,
    "gitlab_user": "asm-dtu",
    "gitlab_project": "acat",
    "lcname": "acat"
}
        
Elapsed time: 0.15515s