Skip to main content

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 the markers DataFrame.
  • overflows.csv - A CSV file containing the overflows DataFrame.
  • photons.csv - A CSV containing the photons 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

pyptu-2024.2.tar.gz (11.8 kB view details)

Uploaded Source

Built Distribution

pyptu-2024.2-py3-none-any.whl (11.2 kB view details)

Uploaded Python 3

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

Hashes for pyptu-2024.2.tar.gz
Algorithm Hash digest
SHA256 be42cafd45cb9d2a7a8e549bed26678c092dfd360dba6651d0b2ca565cc158bb
MD5 00a8c48e6c0869b5639ce8af1a6678c2
BLAKE2b-256 10e3e7028aa38030d6feb9cd0e06845d203d9bdee34bdfb7b2da080781e9035d

See more details on using hashes here.

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

Hashes for pyptu-2024.2-py3-none-any.whl
Algorithm Hash digest
SHA256 3a0fdc419af8a14e0574e1a22fadde57791def1788b06b8414faebb395e8f6e3
MD5 99202fc678e1c08f3654e1dc67c93d75
BLAKE2b-256 342d90e95cbc88e13d9b736ab1f05db6578da8f8427352a917cfd7c120b1690e

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