A package to read and write Grace Format files (.gff/.segff)
Project description
PyGFF
A Python package to read and write Grace Format files (.gff / .segff).
Easiest Way To Install PyGFF
$ pip install pygff
Basic Usage
-
Loading a .gff file:
>>> from pygff import load >>> img5D = load("tutorials/CT140.gff") >>> img5D.shape (1, 1, 429, 211, 290) >>> img5D.info.voxel_sizes [0.14 0.14 0.14]
GFF objects are five-dimensional numpy arrays with additional customizable metadata such as voxel sizes and channel units. The shape / indexing convention used is (channel, time, z, y, x).
-
Saving a numpy ndarray
np_array
as a .gff file:>>> from pygff import GFF, save >>> save("image.gff", GFF(np_array))
The required metadata is automatically added by the
GFF
constructor. -
Saving a numpy array
seg_array
as a .segff (segmentation) file with metadata for class names, indices, and colors:>>> from pygff import GFF, save >>> segff = GFF(seg_array) >>> segff.info.set_class_dict( {"Heart": {"index": 1, "color": (255, 0, 0, 255)}, "Liver": {"index": 2, "color": (0, 255, 0, 255)}}) >>> save("segmentation.segff", segff)
Note that
seg_array
is converted tonp.uint8
before saving. Colors are specified as RGBA, and class index 0 is reserved for "unclassified" data.
Tutorials
Tutorial notebooks can be found in the /tutorials/
directory of this repository. They are not included with the PyGFF package. We recommed that you to start with 01_load_and_save.ipynb
to learn more about loading, saving, and GFF objects. More tutorials will be added in the future.
Running the examples requires the packages jupyter
, matplotlib
, numpy
, and scipy
to be installed. Also, please download the required example datasets if you have not cloned the repository yet.
What is GFF?
GFF is an open source file format for multimodal biomedical images (.gff) and segmentations (.segff). The format supports datasets with up to five dimensions (three spatial dimensions, time-variant, and multi-channel) and a rich set of metadata key-value pairs. By default, the implementation uses a lossless compression algorithm to reduce file size and cryptographic hashing for secure writing. Multithreading is also used if possible to speed up reading and writing of GFF files.
The PyGFF package is developed by Gremse-IT GmbH (Aachen, Germany) as a Python interface for Imalytics Preclinical 3.0 which utilizes .gff by default for underlay, overlay, segmentation (.segff), and project files (.imaproj).
For more details, please refer to this publication:
Yamoah, Grace Gyamfuah et al. “Data Curation for Preclinical and Clinical Multimodal Imaging Studies.” Molecular imaging and biology vol. 21,6 (2019): 1034-1043. doi:10.1007/s11307-019-01339-0
Full text: https://pubmed.ncbi.nlm.nih.gov/30868426/
How to build the package yourself
- Clone the repository
$ git clone git@bitbucket.org:felixgremse/gff_file_format.git
- (Optional) Create a virtual environment, e.g. with
venv
$ python -m venv env ... $ source env/bin/activate
or usingconda
$ conda env create --file environment.yml ... $ conda activate pygff
- Then, install
pygff
in editable mode, e.g. usingbuild
$ python -m pip install --upgrade build ... $ python -m pip install -e .
orconda-build
$ conda develop .
How to run package tests
Make sure that pytest
is installed and then simply call it from a shell in the main directory.
$ pytest
License
The PyGFF package is licensed under the terms of the MIT license.
All .gff files, .segff files, and Jupyter notebooks contained in the /tutorials/
directory of the repository are licensed under CC BY-NC-SA 4.0.
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
File details
Details for the file pygff-1.2.0.tar.gz
.
File metadata
- Download URL: pygff-1.2.0.tar.gz
- Upload date:
- Size: 16.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.0.0 CPython/3.11.8
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 9e0e4f73c8661f7128fbb277d311eb9a295776de5b6988820d2cec3326275569 |
|
MD5 | c461753f85f4325bfb697dfca1914af5 |
|
BLAKE2b-256 | bfda07c9866a29ef4311f16cc7f639f0b0cf82c00a963efddc6038e277afdb5e |
File details
Details for the file pygff-1.2.0-py3-none-any.whl
.
File metadata
- Download URL: pygff-1.2.0-py3-none-any.whl
- Upload date:
- Size: 14.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.0.0 CPython/3.11.8
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | a03b2ad563c730efff9255b95ce5b79c574c4fc3eb2db4d73b51de69626927ae |
|
MD5 | a0b3894823f83897e0ec78d6e162f02d |
|
BLAKE2b-256 | 45ab16df6094560d22504490aaa062744c9a60f04e838788ed76539408e70dae |