Skip to main content

Random sequential adsorption (RSA) simulation, 2D lattice-based.

Project description

AdsorPy

pypi version test results badge docs build results codecov OpenSSF Scorecard OpenSSF Best Practices OpenSSF Baseline

Lattice-based random sequential adsorption (RSA) Python 3.10+ script.

In RSA, molecules arrive one by one at a surface. Adsorption takes place if the molecule does not overlap with molecules already on the surface. The list of available orientations for the molecule is traversed in random order until the first orientation that fits is found, or until the list is exhausted. All available sites are checked, and various metrics can be extracted afterwards such as the coverage, covered area, and gap size distribution.

Output of an AdsorPy run, an image of a covered surface.

How to use

This package can be found on PyPI as adsorpy, so we recommend the following:

pip install adsorpy

Run the adsorpy.main in order to run a simple single run using the standard disk-shaped molecule on hexagonal aluminium oxide. New molecules can be created by running the adsorpy.molecule_lib or by calling the adsorpy.molecule_lib.first_time_loader() function. Molecules can be generated from .xyz files. It is recommended to run adsorpy.molecule_lib directly from command line to define the molecule orientation, then store the new molecule string for repeated use.

Run the adsorpy.run_simulation.run_simulation() function with the molecule footprints generated in the previous step. Output can be printed to stdout, plotted, and saved. An example for dog-bone molecules with rotations of 360 // 12 = 30 degrees:

from adsorpy.run_simulation import run_simulation
from adsorpy.molecule_lib import dogbonium
molecule = dogbonium()
output = run_simulation(molecules_list=molecule, rotation_counts=12, plot_output_flag=True)

User-friendliness will be updated at a later stage, allowing the user to define simulation modes, surfaces, and molecules more easily.

Documentation (generated with sphinx): https://joostfwmaas.github.io/AdsorPy/

Future additions

In a future update, the code will be expanded with diffusion, desorption, and species conversion (changing from one molecule on the surface to another).

Design philosophy

Because AdsorPy has been made with scientific rigour in mind, the package is tested in multiple ways:

  • Unit tests (pytest) of the code ensure correct behaviour for expected input.
  • Property tests (hypothesis) of the most critical code components ensure correct behaviour for unexpected input as well.
  • mypy (in --strict mode) and pyright (strict) ensure that the package is correctly-typed, as if it were static. The py.typed file, a promise that the code is type-hinted properly, is added because the code passes this test.
  • ruff is used as a linter with almost all rules enabled (see the pyproject.toml for the list of exclusions and reasons).
  • slotscheck ensures that all dataclass slots are set up correctly.
  • tach ensures that internal dependencies are handled correctly (from low level to high), preventing circular dependencies.
  • tox is used to run all of the aforementioned tests in parallel for multiple Python versions to ensure correct behaviour.
  • CI is used for automated testing.

The package also makes use of an optional config file that falls back on standard behaviour, because configs are often used in scientific software (set-and-forget).

Openness and academic collaboration

The script was made public for the sake of openness and academic collaboration. Please let me know if you have questions about the script, or if you have discovered any issues/bugs. At the end of this file, I will place a list of papers that make use of this work. Feel free to contact me if you want your work to be added to the list as well.

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

adsorpy-1.2.2b3.tar.gz (77.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

adsorpy-1.2.2b3-py3-none-any.whl (80.0 kB view details)

Uploaded Python 3

File details

Details for the file adsorpy-1.2.2b3.tar.gz.

File metadata

  • Download URL: adsorpy-1.2.2b3.tar.gz
  • Upload date:
  • Size: 77.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.13

File hashes

Hashes for adsorpy-1.2.2b3.tar.gz
Algorithm Hash digest
SHA256 522ed874412c6c926dde42c20813e556d6d7a0ff66d0ec04ee8c4f2f8c7ac51f
MD5 ac26dc02530b39eb03233c8fc6866846
BLAKE2b-256 65d8c10ec20ff5713754573e6df6a0dab2c8a3b28833350eecbeb58a73fd46e8

See more details on using hashes here.

Provenance

The following attestation bundles were made for adsorpy-1.2.2b3.tar.gz:

Publisher: publish_to_PyPI.yml on JoostFWMaas/AdsorPy

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file adsorpy-1.2.2b3-py3-none-any.whl.

File metadata

  • Download URL: adsorpy-1.2.2b3-py3-none-any.whl
  • Upload date:
  • Size: 80.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.13

File hashes

Hashes for adsorpy-1.2.2b3-py3-none-any.whl
Algorithm Hash digest
SHA256 b9dae62f9b18d3ee84fe598ee8596d4b25227bd695bf931d25effab0f1844003
MD5 c43c4a16e4f3c58670e6da3f29738151
BLAKE2b-256 f733e2650494f5a5457b7fde4657802956b1f21fbe459de3baf9e6fd3a139a72

See more details on using hashes here.

Provenance

The following attestation bundles were made for adsorpy-1.2.2b3-py3-none-any.whl:

Publisher: publish_to_PyPI.yml on JoostFWMaas/AdsorPy

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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