Lightweight tools for loading and handling photon counting data
Project description
photon-tools
Lightweight Python tools for loading, inspecting, and screening single-molecule photon counting data.
photon-tools is designed for interactive, notebook-based workflows commonly used in single-molecule fluorescence experiments.
The focus is on data loading, standardization, and visual inspection, not on enforcing a specific analysis pipeline.
Motivation
In single-molecule experiments, especially with photon-counting data:
- data quality often cannot be judged from scalar metrics alone
- visual inspection of time traces is essential (blinking, drift, artifacts, IR effects, etc.)
- experiments typically produce many measurement files that must be screened efficiently
photon-tools provides:
- a clean and extensible data loading layer
- a standardized in-memory data model
- fast, interactive Plotly-based previews
- a Jupyter-based browser for screening and annotating many files
Features
✔ Data loading
- Built-in loader for Photon-HDF5
- Unified data representation via
PhotonDataset/PhotonData - Optional runtime registration of custom loaders (no forking required)
✔ Clean data model
- Integer timestamps (ticks)
- Optional detector/channel information
- Explicit
timing_resolution(seconds per tick) - Safe conversion to physical time
- Easy splitting by detector channel
✔ Interactive preview (Plotly)
- Fast binning of large photon streams
- Multiple detector channels in one plot
- Clickable legend to enable/disable channels
- Scroll-wheel zoom + mouse pan
- Physically meaningful defaults (axes clamped to zero)
- Fully customizable via returned Plotly
Figure
✔ Screening workflow (Jupyter)
- Browse many files interactively
- Next / Previous navigation
- Visual evaluation instead of purely numeric filtering
- Mark files as keep / reject
- Store annotations and notes in a CSV file
Installation
Create a virtual environment (recommended):
python -m venv .venv
source .venv/bin/activate
Install in editable (development) mode:
pip install -e .
Required dependencies:
- numpy
- h5py
- plotly
- nbformat
For the notebook browser:
pip install ipywidgets pandas
Basic Usage
Load a Photon-HDF5 file
import photon_tools as pt
ds = pt.load(
"measurement.hdf5",
timing_resolution=5e-9, # seconds per tick
)
Access data
ds.photons.timestamps # raw integer timestamps (ticks)
ds.photons.times_s # physical time in seconds
ds.photons.detectors # detector/channel IDs
Split by detector channel:
by_ch = ds.photons.by_detector()
t_ch0 = by_ch[0]
t_ch1 = by_ch[1]
Interactive Preview
Quick visual inspection of a time trace:
pt.preview(ds, bin_width_ms=10)
Customize appearance and detector labels:
pt.preview(
ds,
bin_width_ms=5,
detector_labels={0: "donor", 1: "acceptor"},
colors={0: "royalblue", 1: "firebrick"},
width=1000,
height=400,
)
Further customization via Plotly:
fig = pt.preview(ds, show=False)
fig.update_yaxes(type="log")
fig.show(config={"scrollZoom": True})
Because preview() returns a Plotly Figure, all Plotly features remain available.
Screening Many Files (Notebook Browser)
A ready-to-use Jupyter notebook example for interactive file screening is provided in:
notebooks/02_browse_files.ipynb
The browser allows you to:
- step through many measurement files
- inspect traces interactively (zoom, pan, toggle channels)
- mark files as keep or reject
- add free-text notes
- store all annotations in a CSV file
This workflow is intended for expert-driven screening, where visual judgment is essential and cannot be replaced by scalar metrics alone.
Custom Loaders
Custom file formats can be supported without modifying or forking the package.
Define a loader function and register it at runtime:
def my_loader(path):
...
return PhotonDataset(...)
pt.register_loader(".dat", loader=my_loader)
ds = pt.load("custom_format.dat")
This allows extending photon-tools in notebooks or scripts in a lightweight and flexible way.
Files without extensions
Some binary formats (e.g. custom NI time-tagged data) do not use file extensions. In this case, the loader must be specified explicitly:
ds = pt.load(
"measurement_001",
loader=pt.load_ni_binary,
timing_resolution=10e-9,
)
Design Philosophy
- Notebook-first
- Explicit over implicit
- No silent assumptions
- Visual inspection before automation
- Keep the core lightweight; downstream analysis is user-specific
photon-tools is not an analysis framework — it is a foundation for interactive and exploratory workflows.
Status
This project is under active development and tailored to real experimental workflows.
APIs may evolve, but changes are made conservatively and with practical use cases in mind.
License
(Choose one, e.g. MIT or BSD-3-Clause)
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 photon_tools-0.1.0.tar.gz.
File metadata
- Download URL: photon_tools-0.1.0.tar.gz
- Upload date:
- Size: 16.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4744151583290b9ed712d28c0877efda8dcbab3aaf73af30bdd8d0d884c42540
|
|
| MD5 |
70714e937bef42f0c11118815a195b9a
|
|
| BLAKE2b-256 |
1999f915ab6145ca309834b8dafa7d76ec777d822920ae5b4bea91bc2df77f50
|
Provenance
The following attestation bundles were made for photon_tools-0.1.0.tar.gz:
Publisher:
publish.yml on JKL453/photon-tools
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
photon_tools-0.1.0.tar.gz -
Subject digest:
4744151583290b9ed712d28c0877efda8dcbab3aaf73af30bdd8d0d884c42540 - Sigstore transparency entry: 910536789
- Sigstore integration time:
-
Permalink:
JKL453/photon-tools@3fa6135a132d65aa78a58d8c02d0a8354026ee8c -
Branch / Tag:
refs/tags/v0.1.0 - Owner: https://github.com/JKL453
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@3fa6135a132d65aa78a58d8c02d0a8354026ee8c -
Trigger Event:
push
-
Statement type:
File details
Details for the file photon_tools-0.1.0-py3-none-any.whl.
File metadata
- Download URL: photon_tools-0.1.0-py3-none-any.whl
- Upload date:
- Size: 15.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
eae704504eb3ab626b1f3f26a24ec48a9a81993a8e38d05920b24cb2ec576a96
|
|
| MD5 |
bce37678e380e4a71e85f86f06c4e815
|
|
| BLAKE2b-256 |
02ccf65cee53e565c2738b9b5793a9d15a397c7e466e0f377b10cb8397396b74
|
Provenance
The following attestation bundles were made for photon_tools-0.1.0-py3-none-any.whl:
Publisher:
publish.yml on JKL453/photon-tools
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
photon_tools-0.1.0-py3-none-any.whl -
Subject digest:
eae704504eb3ab626b1f3f26a24ec48a9a81993a8e38d05920b24cb2ec576a96 - Sigstore transparency entry: 910536803
- Sigstore integration time:
-
Permalink:
JKL453/photon-tools@3fa6135a132d65aa78a58d8c02d0a8354026ee8c -
Branch / Tag:
refs/tags/v0.1.0 - Owner: https://github.com/JKL453
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@3fa6135a132d65aa78a58d8c02d0a8354026ee8c -
Trigger Event:
push
-
Statement type: