pylattica is a package for fast prototyping of lattice models for chemistry and materials science
Project description
pylattica - A Framework for Lattice and Cellular Automata Simulation
pylattica is a Python library for prototyping and constructing cellular automaton and lattice models. The core features of these models are:
- There is a simulation state that evolves over time by repeatedly applying some unchanging rule
- The state of the simulation has a topology defined by a network of sites (i.e. each site has an unchanging set of neighbor sites)
- Each site has a state value associated with it that could change at each simulation step
- The future state of a site is determined by the state of its neighbor sites
These rules capture many common models in chemistry and materials science. For instance, in the Ising Model, spins are updated with probabilities related to the neighboring spins. In a Lattice Gas Automaton, the velocities of particles are determined collisions with neighboring particles. In lattice Monte Carlo simulations of surface catalysis, adsorption, desorption, and surface diffusion are dependent on the occupancy of neighboring sites.
pylattica aims to provide a general framework for prototyping these types of lattice simulations. It prioritizes providing a straightforward method for experimenting with different interaction rules and interaction neighborhoods. It provides some simple utilities for analyzing simulation states, and in the case of square grid systems, it provides visualization tools for the system state itself. Additionally, since this tool is focused on materials science, there is functionality for mapping system states to CIF files (for use in crystal lattice simulations).
Installation
pylattica
can be installed from the PyPi source by running:
pip install pylattica
It can also be installed by cloning this repository, then running the following in the root of the repository:
pip install .
Documentation
Detailed documentation for this library can be found here.
Jupyter Notebook Examples
Example notebooks are included in docs/guides.
Note about Windows
pylattica
makes use of Python's fork functionality in the multiprocessing library. This functionality is not available on windows, so certain features (the parallel
keyword for the SynchronousRunner
) will not be available on Windows platforms.
Development
Installation for development
To install pylattica for development purposes, use the standard editable installation command:
pip install -e .
from the root of the repository.
Running tests
After you have installed the repository, ensure that pytest
is installed, then run:
pytest
from the root of the repository.
Building Documentation
The docs for this project are built using mkdocs. To build the documentation
pip install '.[docs]'
mkdocs build
To run the documentation server locally:
mkdocs serve
Linting
This project uses the black
package for style and formatting, and prospector
for type checking and other lint warnings. These packages are not listed as dependencies of this project, so you can install them manually. This is partially because this project doesn't rely on specific versions of them, and we expect developers to have their own installations already. You can run them as follows:
To assess the changes that will happen if you run the black
linter, run the following:
black --check src
To automatically make the changes, remove the --check
flag:
black src
To run all other linters with prospector, use this:
prospector
In the top of this repository.
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
Built Distribution
File details
Details for the file pylattica-0.1.3.tar.gz
.
File metadata
- Download URL: pylattica-0.1.3.tar.gz
- Upload date:
- Size: 37.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.0.0 CPython/3.9.18
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6364e8e9e9c32036916e4ed521255bbf7e10c88470db2e91203821b801823674 |
|
MD5 | ba662c367f839c4af09faeba64b7dff2 |
|
BLAKE2b-256 | 1cd469da5c9d940c0d518665f7dd2d004feba26cfee28ca0749e6bcdc989e3d3 |
File details
Details for the file pylattica-0.1.3-py3-none-any.whl
.
File metadata
- Download URL: pylattica-0.1.3-py3-none-any.whl
- Upload date:
- Size: 51.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.0.0 CPython/3.9.18
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | c715976b67b7d29c86f9d0300ae150aa1301e49f044ea147ea283908ccf77372 |
|
MD5 | 8fe30b59ec64038e7963a9de8861c2f3 |
|
BLAKE2b-256 | d93484593c903cc4c56ba3ade81ba4419790e2e3079b2610e71299382b398172 |