Skip to main content

A package for computing distances accounting for periodic boundary conditions

Project description

pbc_distance_calculator

This Python package computes pairwise distances in a simulation box accounting for periodic boundary conditions.

The only inputs are the positions of each particle and the simulation supercell matrix.

To install:

pip install pbc_distance_calculator

Example usage:

from numpy.typing import NDArray
from pbc_distance_calculator import get_pairwise_distances

# array of shape (N, 3) where N is the number of particles
positions: NDArray = ...

# array of shape (3, 3)
cell_matrix: NDArray = ...

# array of shape (N, N)
# element (i, j) is minimum image distance between i and j
pairwise_distances: NDArray = get_pairwise_distances(positions, cell_matrix)

The above script performs the calculation in a vectorized form, computing every pairwise distance at once. To do it serially instead:

from numpy.typing import NDArray
from pbc_distance_calculator import get_pairwise_distance

# arrays of shape (1, 3) or (3, 1)
first_position: NDArray = ...
second_position: NDArray = ...

# array of shape (3, 3)
cell_matrix: NDArray = ...

# minimum image distance
pairwise_distance: float = get_pairwise_distance(
    first_position - second_position,
    cell_matrix
)

In both functions, you can also specify different engines to compute the distances. This is especially advantageous for large systems, where you can specify jax.numpy or torch as an engine. For example:

import torch
from pbc_distance_calculator import get_pairwise_distances

...

torch.set_default_device("cuda")
pairwise_distances = get_pairwise_distances(
    positions,
    cell_matrix,
    engine=torch
)

which will calculate the pairwise distances using the CUDA-backend of PyTorch. Note that the only engine installed by default is numpy, so make sure to separately install jax or torch if you want to use these modules.

Note that the cell matrix, is, in general:

$$ \begin{pmatrix} \mathbf{a} & \mathbf{b} & \mathbf{c} \end{pmatrix} $$

where $\mathbf{a}$, $\mathbf{b}$, and $\mathbf{c}$ are the lattice vectors of the supercell. Note that this definition works for any set of lattice parameters! So, no matter how weird your crystal, this package should work. If there are any problems, feel free to open an issue 🙂.

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

pbc_distance_calculator-1.3.3.tar.gz (5.4 kB view details)

Uploaded Source

Built Distribution

pbc_distance_calculator-1.3.3-py3-none-any.whl (6.3 kB view details)

Uploaded Python 3

File details

Details for the file pbc_distance_calculator-1.3.3.tar.gz.

File metadata

File hashes

Hashes for pbc_distance_calculator-1.3.3.tar.gz
Algorithm Hash digest
SHA256 1b775f59f7bed402b7e3a27c9d7bc66eeeccceb569649714b394f260d0632fb1
MD5 788486ad9f2817c356a590d9f9c17e8d
BLAKE2b-256 172b49a5b8213bcf17a79522dee097d09c7fb2e34ca23b4ec6f40a77d6fd332f

See more details on using hashes here.

File details

Details for the file pbc_distance_calculator-1.3.3-py3-none-any.whl.

File metadata

File hashes

Hashes for pbc_distance_calculator-1.3.3-py3-none-any.whl
Algorithm Hash digest
SHA256 c33465428c3c6002b9e58494e6d7e8a0e8f4096203819abfc42d7cde40d0c637
MD5 42bd86653cd56d92ed748327f12a30f2
BLAKE2b-256 ecac0ccb946d8c3f4f2145826168bedced78342246ff3d59925901a64eae2bfb

See more details on using hashes here.

Supported by

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