A package for point pattern analysis: Pattern Extraction from Relative Positions of Localisations
Project description
PERPL
Pattern Extraction from Relative Positions of Localisations
PERPL infers structure that is not directly visible in point-cloud data, including when data is sparse relative to the underlying structure. It was initially developed for localisation microscopy, but is also applicable to other point-cloud data.
PERPL works by computing pairwise relative positions between data points in a relative position distribution (RPD). It compares this experimental RPD with RPDs generated from candidate model structures and assists in final model selection.
Originally developed at the University of Leeds.
Citation
If you use PERPL in your work, please cite:
Curd, A. P., Leng, J., Hughes, R. E., Cleasby, A. J., Rogers, B., Trinh, C. H., Baird, M. A., Takagi, Y., Tiede, C., Sieben, C., Manley, S., Schlichthaerle, T., Jungmann, R., Ries, J., Shroff, H., & Peckham, M. Nanoscale Pattern Extraction from Relative Positions of Sparse 3D Localizations. Nano Letters 2021, 21 (3), 1213–1220. https://doi.org/10.1021/acs.nanolett.0c03332.
BibTeX
@article{curd2021perpl,
title = {Nanoscale Pattern Extraction from Relative Positions of Sparse 3D Localizations},
author = {Curd, Alistair P. and Leng, Joanna and Hughes, Ruth E. and Cleasby, Alexa J. and Rogers, Brendan and Trinh, Chi H. and Baird, Michelle A. and Takagi, Yasuharu and Tiede, Christian and Sieben, Christian and Manley, Suliana and Schlichthaerle, Thomas and Jungmann, Ralf and Ries, Jonas and Shroff, Hari and Peckham, Michelle},
journal = {Nano Letters},
year = {2021},
volume = {21},
number = {3},
pages = {1213--1220},
doi = {10.1021/acs.nanolett.0c03332}
}
Installation
Requires Python 3.11+ (e.g. in a new conda environment)
pip install perpl for released versions
or
Download or clone this repository and pip install .
Tested on Linux and Windows
Quick start
Input data should be a table of 2D or 3D data points in a CSV file, with one row per data point. The first columns must contain the X and Y coordinates (and Z for 3D data).
- Collect 2D relative positions (
-d 2) with filter distance 200 (-f 200).
relpos -i INPUT_DATA.csv -d 2 -f 200
- Example analysis: radial symmetry modelling from the RPD. This uses output from the
relposcommand.
rotsym2d -i RPD_DATA.csv
- Example analysis: modelling independent and repeated distances from the RPD. Uses output from the
relposcommand and a modelling config model file based onperpl_models_config.yaml. Fit histograms of the distances (-fh).
modeldistances -rf RPD_DATA.csv -cf CONFIG_FILE.yaml -fh
Output is generated at the input data (and config file) location.
HTML reports are generated in the output for relpos and rotsym2d.
Usage
The following commands are available:
-
relpos/relative_positions.py generates the set of 2D/3D relative positions, plots of distance histograms and an HTML report.Here is one of the distance histograms for data from a nuclear pore complex protein (located around a ring of approx. 100 nm diameter):
-
rotsym2d/rot_2d_symm_fit.py generates visualisations of fitted structures and fit results, and an HTML report containing detailed fit results and a comparison of the models for different orders of symmetry.Here is a plot with the fits to model RPDs with different orders of symmetry:
-
modeldistances/run_distance_modelling.py generates a set of models to fit from copy ofperpl_models_config.yaml, which the user may edit and rename as desired. It then generates visualisations of distance distibutions (histogram or kernel density estimate) and model fits, and a table comparing the different models.Here is an example plot produced for one model fit to a kernel density estimate of a distance distribution:
Run COMMAND -h to see available command-line options.
The -s flag can be used to shorten the output path if this becomes a problem in Windows.
Output is generated in a subdirectory to the directory containing the input data/RPD data.
See src/perpl/ for all modules including structural model implementations.
Data
The original test data for this software and examples with which the software can be used, can be found at
https://bitbucket.org/apcurd/perpl_test_data.
Documentation
More detailed documentation is available in dev/old-readme.md and will be improved in future releases.
Notebooks
See notebooks/ for interactive examples, developed from work reported here.
Authors
Alistair Curd, Oliver Umney, Joanna Leng
License
Apache License 2.0 — see LICENSE file for details.
Project details
Release history Release notifications | RSS feed
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file perpl-1.3.0.tar.gz.
File metadata
- Download URL: perpl-1.3.0.tar.gz
- Upload date:
- Size: 253.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e3647c281894ef3479922ec68d45dafb8b48cce8a1b62e4bee5ab61c3dea351c
|
|
| MD5 |
fd77bf518155e98b0f17111d3dd94872
|
|
| BLAKE2b-256 |
a27f0cc0e05373a5afcae2a4a80f403113a7e3562d3e77a28a0e058723126b16
|
Provenance
The following attestation bundles were made for perpl-1.3.0.tar.gz:
Publisher:
release.yml on AlistairCurd/PERPL-Python3
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
perpl-1.3.0.tar.gz -
Subject digest:
e3647c281894ef3479922ec68d45dafb8b48cce8a1b62e4bee5ab61c3dea351c - Sigstore transparency entry: 1568137381
- Sigstore integration time:
-
Permalink:
AlistairCurd/PERPL-Python3@23ad576c858cb5ae127dc3213221258f8a7e2508 -
Branch / Tag:
refs/tags/v1.3.0 - Owner: https://github.com/AlistairCurd
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@23ad576c858cb5ae127dc3213221258f8a7e2508 -
Trigger Event:
push
-
Statement type:
File details
Details for the file perpl-1.3.0-py3-none-any.whl.
File metadata
- Download URL: perpl-1.3.0-py3-none-any.whl
- Upload date:
- Size: 102.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
60efa82dedcbc01e8f9c1c25782be3e96409a66c9d714675fe7c16ec91da5b54
|
|
| MD5 |
15dc20b082cca91c0776807bcae3f6cb
|
|
| BLAKE2b-256 |
563bd8a101045831d5390dc6702b81ee71dbeff7d9d18dc3fc057e757c2c72cf
|
Provenance
The following attestation bundles were made for perpl-1.3.0-py3-none-any.whl:
Publisher:
release.yml on AlistairCurd/PERPL-Python3
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
perpl-1.3.0-py3-none-any.whl -
Subject digest:
60efa82dedcbc01e8f9c1c25782be3e96409a66c9d714675fe7c16ec91da5b54 - Sigstore transparency entry: 1568137732
- Sigstore integration time:
-
Permalink:
AlistairCurd/PERPL-Python3@23ad576c858cb5ae127dc3213221258f8a7e2508 -
Branch / Tag:
refs/tags/v1.3.0 - Owner: https://github.com/AlistairCurd
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@23ad576c858cb5ae127dc3213221258f8a7e2508 -
Trigger Event:
push
-
Statement type: