Skip to main content

MC Bond Exchange for LAMMPS Simulations

Project description

MC-exchange Python Package

[!NOTE] Documentation under development. Once Balint Magyari has more time he will continue writing a detailed documentation for the package.

The MC-exchange Python package has been developed to support the dynamic bond exchange reactions (BERs) during a molecular dynamics (MD) simulation run using LAMMPS (Large-scale Atomic/Molecular Massively Parallel Simulator) software. Using the LAMMPS Python package, a MD simulation can be run directly from a Python script, allowing an interface between Python and LAMMPS. The MC-exchange Python package uses this to gather the necessary data from the LAMMPS MD simulation, analyze the data, determine which bonds to exchanged, and finally communicate the altered bond data back to LAMMPS, where the actual bond exchange can take place.

These simulations are useful for studying the effects of dynamic bonds of associative covalently adaptive polymer networks.

The package is written with the ease of use in mind. However, users must be warned that a thorough understanding of the LAMMPS Python package is necessary to be able to gather the necessary bits of data prior to performing bond exchange reactions using the MC-exchange Python library.

General Use

The package can be installed from PyPI distribution archive using:

pip install MC-exchange

After successful installation of the MC-exchange Python package, it can be imported into a script as follows:

import MC_exchange as mc

The above statement imports all user-necessary functionalities of the package.

Package organization

The MC-exchange Python package is organized into modules. Currently, there are three modules dedicated to the base functionalities, and one module where these functionalities are combined to perform bond exchange reactions. The three base modules are calculations.py, data.py and neigh_list.py. All functions necessary to perform dynamic bond exchange reactions are imported direcly, thus the user does not need to search these modules for the required functionalities. Nevertheless, we provide a brief overview of the different modules, so that the user can better understand the structure of the library.

Base modules

Currently, three base modules are responsible for the primary functionalities of the package. data.py is the module responsible for gathering data from the LAMMPS simulations. calculations.py contains calculations that use the data obtained by the functions of data.py to compute properties that can be necessary during bond exchange reactions. Lastly, neigh_list.py contain the functionalities required to construct spacial neighbor lists using atom data.

Functionalities

Currently, in version 1.1.0, there are two main functions used to perform associative bond exchange reactions. Firstly, the evaluate_bond_exchange() function is used to perform two types of bond exchange reactions between stickers of any kind. The two types of bond exchange reactions allowed are bond shifts and bond swaps. The first is an 3-body exchange reaction between a bonded sticker pair and a 'free' sticker where a single bond migrates, while the latter is a 4-body exchange between two pairs of bonded stickers requiring the rearrangement of two bonds. In either case, the number of total bonds in the system does not change.

Secondly, the complementary_bond_exchange function, as the name suggests, allows reactions to occur between stickers that are of different types (i.e., A-B crosslinks). In the function, these types can be defined according to LAMMPS' numerical type convention under arguments sticker_types_A and sticker_types_B.

Both of the above mentioned bond exchange functions allow bond shifts and bond swaps to be turned on and off according to the user's requirements.

The software is designed such that it works when LAMMPS simulations are run parallel (i.e., on multiple processors). Communication between processes is handled by the mpi4py Python package.

Example script

In order to run the following script...

Users are encouraged to clone the repository of this project to access all source files and example code.

To run the example script, make sure that the Python environment into which MC-exchange was installed is activated and you are located in the src/example/ directory. To run the example script simply run the following command in the terminal:

mpiexec -np {n_procs} python3 loop.py

where {n_procs} is the number of parallel processes the user wishes to launch.

Note, this requires that the user has installed OpenMPI or MPICH to the local machine.

Developer

Balint Magyari: PhD Student at University of Naples Federico II

For any questions please contact balint.magyari@unina.it.

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

mc_exchange-1.1.1.tar.gz (20.3 kB view details)

Uploaded Source

Built Distribution

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

mc_exchange-1.1.1-py3-none-any.whl (21.8 kB view details)

Uploaded Python 3

File details

Details for the file mc_exchange-1.1.1.tar.gz.

File metadata

  • Download URL: mc_exchange-1.1.1.tar.gz
  • Upload date:
  • Size: 20.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for mc_exchange-1.1.1.tar.gz
Algorithm Hash digest
SHA256 7178472238ca622d017c7a0dab984b5493ddfa144102b520ac9b0e0fef36f454
MD5 87bf7c072ee6ab20797d2b9779879475
BLAKE2b-256 1f45db07f2ba8cf78979054f5569ac50f08d493865137f4526cbc5fec16f855f

See more details on using hashes here.

Provenance

The following attestation bundles were made for mc_exchange-1.1.1.tar.gz:

Publisher: publish.yml on balintmagyari/MC_exchange

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

File details

Details for the file mc_exchange-1.1.1-py3-none-any.whl.

File metadata

  • Download URL: mc_exchange-1.1.1-py3-none-any.whl
  • Upload date:
  • Size: 21.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for mc_exchange-1.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 8fb9a7495c111138900dac79cf2429a52cbe4249fc7fa32aa207cbb08e52e378
MD5 95857c73d89b1431e00b59c2c32c5291
BLAKE2b-256 497dbf406eb4dab71bb4ce52010b487a94bd02144d073048a47f77df987f720e

See more details on using hashes here.

Provenance

The following attestation bundles were made for mc_exchange-1.1.1-py3-none-any.whl:

Publisher: publish.yml on balintmagyari/MC_exchange

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