Coder Social home page Coder Social logo

lattice_mc's Introduction

lattice_mc: A Python Lattice-Gas Monte Carlo Module

PyPI version Build Status DOI JOSS status Documentation Status Test Coverage

lattice_mc is Python module for performing (kinetic) lattice-gas Monte Carlo (LGMC) simulations of ionic transport in solid electrolytes.

In solid electrolytes, ionic motion is typically effected by a series of discrete “jumps” where ions move between adjacent lattice sites [1]. For dilute mobile ions, ionic trajectories are random walks, and simple analytical expressions exits that relate macroscopic transport coefficients, i.e. diffusion coefficients and ionic conductivities, to the microscopic jump frequency of individual ions [2,3]. Practical solid electrolytes have high mobile ion concentrations, with significant interparticle interactions producing deviations from the dilute limit random walk behaviour. In general, the quantitative effect of interparticle interactions cannot be determined analytically. As an alternative, numerical simulations, such as lattice-gas Monte Carlo methods, can be used to directly calculate these relationships. Lattice-gas Monte Carlo methods are particularly suited to studying how varying properties across broad classes of materials give quantitative differences in macroscopic ionic transport, and can be used to understand the different transport properties of materials with, for example, different crystal structures or mobile ion stoichiometries.

lattice_mc has been written to allow materials scientists and solid-state chemists model how the microscopic physics of solid electrolytes (crystal structure, stoichiometry, interaction models) determine macroscopic transport behaviour (diffusion and ionic conduction), with the goal of understand the factors that make different materials more or less useful for specific applications (e.g. Li-ion batteries or fuel cells).

The code allows the programmatic construction of simple lattices (presently implemented are square, honeycomb, and cubic lattices). Lattices with arbitrary geometries can be constructed from a file format that defines the lattice sites and their connectivity, allowing models based on crystallographic data. The algorithms used and interaction models are described in more detail in Ref. [4]. Calculated properties include tracer and “jump” diffusion coefficients; where the latter is proportional to the mobility (and hence the conductivity for charged particles) [5]; and tracer (single particle) and collective correlation factors, f and fI [6]. The simplest interaction model is for “non-interacting” particles, where the only restriction is volume exclusion (two particles cannot simultaneously occupy a single site) [7]. Additional interaction models include nearest-neighbour repulsion and on-site energies for inequivalent sites. Simulations are performed using an efficient rejection-free Monte Carlo scheme [8].

Installation

pip install lattice_mc

Or download the latest release from GitHub

https://github.com/bjmorgan/lattice_mc/archive/1.0.0.tar.gz

Then install

cd lattice_mc
python setup.py install

Or you can clone the latest development version:

git clone [email protected]:bjmorgan/lattice_mc.git

and install the same way.

cd lattice_mc
python setup.py install

Alternatively, you can install the latest build using pip, direct from GitHub, e.g.

pip3 install git+https://github.com/bjmorgan/lattice_mc.git

Documentation

Full documentation and examples are contained in a Jupyter notebook at examples/lattice_mc_example.ipynb. The example notebook is also hosted on GitHub.

Tests

Automated testing of the latest build happens here.

Manual tests can be run using

python3 -m unittest discover

The code has been tested with Python versions 3.5 and above.

References

  1. C. R. A. Catlow, Sol. Stat. Ionics 8, 89 (1983).
  2. R. E. Howard and A. B. Lidiard, Rep. Prog. Phys. 27, 161 (1964).
  3. J. H. Harding, Defects and Transport in Ionic Solids, in Ionic Solids at High Temperatures ed. A. M. Stoneham, World Scientific (1989).
  4. B. J. Morgan, R. Soc. Open Sci. 4, 170824 (2017).
  5. A. Van der Ven et al. Acc. Chem. Res. 46, 1216 (2013).
  6. G. E. Murch Sol. Stat. Ionics 7, 177 (1982).
  7. R. Kutner Phys. Lett. 81A, 239 (1981).
  8. A. F. Voter, Introduction to the Kinetic Monte Carlo Method, in Radiation Effects in Solids, ed. K. E. Sicafus et al., Springer (2007).
  9. Morgan and Madden, J. Phys. Condens. Matter 24, 275303 (2012).
  10. G. E. Murch & R. J. Thorn, Phil. Mag. 36 529 (1977).

lattice_mc's People

Contributors

bjmorgan avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar

lattice_mc's Issues

bug in is_periodically_contiguous( self ):

Bug in is_periodically_contiguous:

Returns True for a 2 site (and other sizes) cluster in the centre of the lattice that doesn't connect across the boundary, as the sites are both at the edges and neigbouring one another.

sites_at_edges( self )

Looks like the order is the wrong way around in sites_at_edges in cluster.py:;

You have:

        x_max = [ s for s in self.sites if s.r[0] == min_x ]
        x_min = [ s for s in self.sites if s.r[0] == max_x ]

rather than:

   x_max = [ s for s in self.sites if s.r[0] == max_x ]
   x_min = [ s for s in self.sites if s.r[0]  == min_x ]

Allow YAML syntax sites data files

The format for defining sites and their connectivity within a data file is not clearly defined, is non-standard, and is fragile to implement. Moving to a standard serialised syntax, e.g. YAML, would be better (keeping the current format for backwards compatibility as a legacy file format).

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.