Load PicoQuant PTU files.
Project description
title: README author: Jan-Michael Rye
Synopsis
Read PicoQuant PTU files. The code follows the same parsing logic as the Python demo provided by PicoQuant but is up to 40 times faster due to the use of vectorized operations using Numpy arrays.
Links
Usage
Python API
The data in the file is parsed into the following objects which are set as attributes of the parser:
headers
- A dict mapping header fields to their values.markers
- A Pandas DataFrame where each row is a record index with an index, a time tag and a marker.overflows
- A Pandas DataFrame where each row is a record with a record index and an overflow values.photons.csv
- A Pandas DataFrame where each row is a record with a record index, a channel, a time tag, a resolved time tag (using the global resolution value), and a dtime value.
from pyptu import PTUParser
# A path to a PTU file.
path = /tmp/example.ptu
# Instantiate the parser. If no encoding is specified, the parser will first
# attempt to load files using UTF-8 and then Windows-1252 encodings. Other
# encodings can be specified using the "encoding" argument.
parser = PTUParser(path)
# Example of passing the "encoding" argument to the initialization method.
# parser = PTUParser(path, encoding='utf-8')
# Load the data. The load method also accepts an "encoding" argument.
parser.load()
# Example of passing the "encoding" argument to the load method.
# parser.load(encoding='windows-1252')
# Once the file is loaded, the loaded data can be accessed via the following
# attributes.
# The PTU header data.
headers = parser.headers
# The Pandas DataFrame of photon data.
photons = parser.photons
# The Pandas DataFrame of marker data.
markers = parser.markers
# The Pandas DataFrame of overflow values.
overflows = parser.overflows
# The loaded data can also be saved to standard file formats with the "save"
# method. Call the method with the path to the desired output directory.
parser.save('output')
Command-Line
The package installs the pyptu
command-line tool that can be used to convert the data in a PTU file to JSON and CSV files. It accepts the path to a PTU file and an output directory.
# Extract the PTU data to files in an output directory.
pyptu example.ptu output_directory
The output directory will contain the following files:
header.json
- A JSON file with the headers described above.markers.csv
- A CSV file containing themarkers
DataFrame.overflows.csv
- A CSV file containing theoverflows
DataFrame.photons.csv
- A CSV containing thephotons
DataFrame.
Help Message
$ pyptu -h
usage: pyptu [-h] [--encoding ENCODING] path dir
Extract PTU data to standard files.
positional arguments:
path A path to a PTU file.
dir A path to an output directory.
options:
-h, --help show this help message and exit
--encoding ENCODING Specify the input filetype encoding. It must be an encoding type supported
by Python. If not given, the following encodings will be tried, in order:
utf-8, windows-1252.
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
Built Distribution
File details
Details for the file pyptu-2024.2.tar.gz
.
File metadata
- Download URL: pyptu-2024.2.tar.gz
- Upload date:
- Size: 11.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | be42cafd45cb9d2a7a8e549bed26678c092dfd360dba6651d0b2ca565cc158bb |
|
MD5 | 00a8c48e6c0869b5639ce8af1a6678c2 |
|
BLAKE2b-256 | 10e3e7028aa38030d6feb9cd0e06845d203d9bdee34bdfb7b2da080781e9035d |
File details
Details for the file pyptu-2024.2-py3-none-any.whl
.
File metadata
- Download URL: pyptu-2024.2-py3-none-any.whl
- Upload date:
- Size: 11.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 3a0fdc419af8a14e0574e1a22fadde57791def1788b06b8414faebb395e8f6e3 |
|
MD5 | 99202fc678e1c08f3654e1dc67c93d75 |
|
BLAKE2b-256 | 342d90e95cbc88e13d9b736ab1f05db6578da8f8427352a917cfd7c120b1690e |