pbc-distance-calculator


Namepbc-distance-calculator JSON
Version 1.3.3 PyPI version JSON
download
home_pagehttps://github.com/muexly/pbc_distance_calculator
SummaryA package for computing distances accounting for periodic boundary conditions
upload_time2024-06-03 01:46:58
maintainerNone
docs_urlNone
authorJacob Jeffries
requires_python<=3.12,>=3.8
licenseMIT
keywords periodic-boundary-conditions distance-computation simulation molecular-dynamics lattice-systems neighbor-lists periodic-images
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # pbc_distance_calculator

![](https://img.shields.io/badge/python-3.9--3.12-blue?logo=python&logoColor=white&labelColor=blue&color=grey)

This Python package computes pairwise distances in a simulation box accounting for [periodic boundary conditions](https://en.wikipedia.org/wiki/Periodic_boundary_conditions).

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

To install:

```bash
pip install pbc_distance_calculator
```

Example usage:

```python
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:

```python
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:

```python
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](https://github.com/MUEXLY/pbc_distance_calculator/issues) 🙂.

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/muexly/pbc_distance_calculator",
    "name": "pbc-distance-calculator",
    "maintainer": null,
    "docs_url": null,
    "requires_python": "<=3.12,>=3.8",
    "maintainer_email": null,
    "keywords": "periodic-boundary-conditions, distance-computation, simulation, molecular-dynamics, lattice-systems, neighbor-lists, periodic-images",
    "author": "Jacob Jeffries",
    "author_email": "jwjeffr@clemson.edu",
    "download_url": "https://files.pythonhosted.org/packages/17/2b/49a5b8213bcf17a79522dee097d09c7fb2e34ca23b4ec6f40a77d6fd332f/pbc_distance_calculator-1.3.3.tar.gz",
    "platform": null,
    "description": "# pbc_distance_calculator\n\n![](https://img.shields.io/badge/python-3.9--3.12-blue?logo=python&logoColor=white&labelColor=blue&color=grey)\n\nThis Python package computes pairwise distances in a simulation box accounting for [periodic boundary conditions](https://en.wikipedia.org/wiki/Periodic_boundary_conditions).\n\nThe only inputs are the positions of each particle and the simulation supercell matrix.\n\nTo install:\n\n```bash\npip install pbc_distance_calculator\n```\n\nExample usage:\n\n```python\nfrom numpy.typing import NDArray\nfrom pbc_distance_calculator import get_pairwise_distances\n\n# array of shape (N, 3) where N is the number of particles\npositions: NDArray = ...\n\n# array of shape (3, 3)\ncell_matrix: NDArray = ...\n\n# array of shape (N, N)\n# element (i, j) is minimum image distance between i and j\npairwise_distances: NDArray = get_pairwise_distances(positions, cell_matrix)\n```\n\nThe above script performs the calculation in a vectorized form, computing every pairwise distance at once. To do it serially instead:\n\n```python\nfrom numpy.typing import NDArray\nfrom pbc_distance_calculator import get_pairwise_distance\n\n# arrays of shape (1, 3) or (3, 1)\nfirst_position: NDArray = ...\nsecond_position: NDArray = ...\n\n# array of shape (3, 3)\ncell_matrix: NDArray = ...\n\n# minimum image distance\npairwise_distance: float = get_pairwise_distance(\n    first_position - second_position,\n    cell_matrix\n)\n```\n\nIn 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:\n\n```python\nimport torch\nfrom pbc_distance_calculator import get_pairwise_distances\n\n...\n\ntorch.set_default_device(\"cuda\")\npairwise_distances = get_pairwise_distances(\n    positions,\n    cell_matrix,\n    engine=torch\n)\n```\n\nwhich 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.\n\nNote that the cell matrix, is, in general:\n\n$$\n\\begin{pmatrix} \\mathbf{a} & \\mathbf{b} & \\mathbf{c} \\end{pmatrix}\n$$\n\nwhere $\\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](https://github.com/MUEXLY/pbc_distance_calculator/issues) \ud83d\ude42.\n",
    "bugtrack_url": null,
    "license": "MIT",
    "summary": "A package for computing distances accounting for periodic boundary conditions",
    "version": "1.3.3",
    "project_urls": {
        "Homepage": "https://github.com/muexly/pbc_distance_calculator"
    },
    "split_keywords": [
        "periodic-boundary-conditions",
        " distance-computation",
        " simulation",
        " molecular-dynamics",
        " lattice-systems",
        " neighbor-lists",
        " periodic-images"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "ecac0ccb946d8c3f4f2145826168bedced78342246ff3d59925901a64eae2bfb",
                "md5": "42bd86653cd56d92ed748327f12a30f2",
                "sha256": "c33465428c3c6002b9e58494e6d7e8a0e8f4096203819abfc42d7cde40d0c637"
            },
            "downloads": -1,
            "filename": "pbc_distance_calculator-1.3.3-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "42bd86653cd56d92ed748327f12a30f2",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": "<=3.12,>=3.8",
            "size": 6296,
            "upload_time": "2024-06-03T01:46:56",
            "upload_time_iso_8601": "2024-06-03T01:46:56.818530Z",
            "url": "https://files.pythonhosted.org/packages/ec/ac/0ccb946d8c3f4f2145826168bedced78342246ff3d59925901a64eae2bfb/pbc_distance_calculator-1.3.3-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "172b49a5b8213bcf17a79522dee097d09c7fb2e34ca23b4ec6f40a77d6fd332f",
                "md5": "788486ad9f2817c356a590d9f9c17e8d",
                "sha256": "1b775f59f7bed402b7e3a27c9d7bc66eeeccceb569649714b394f260d0632fb1"
            },
            "downloads": -1,
            "filename": "pbc_distance_calculator-1.3.3.tar.gz",
            "has_sig": false,
            "md5_digest": "788486ad9f2817c356a590d9f9c17e8d",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": "<=3.12,>=3.8",
            "size": 5412,
            "upload_time": "2024-06-03T01:46:58",
            "upload_time_iso_8601": "2024-06-03T01:46:58.004357Z",
            "url": "https://files.pythonhosted.org/packages/17/2b/49a5b8213bcf17a79522dee097d09c7fb2e34ca23b4ec6f40a77d6fd332f/pbc_distance_calculator-1.3.3.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-06-03 01:46:58",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "muexly",
    "github_project": "pbc_distance_calculator",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "requirements": [],
    "lcname": "pbc-distance-calculator"
}
        
Elapsed time: 1.22107s