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_arrayas a .gff file:>>> from pygff import GFF, save >>> save("image.gff", GFF(np_array))
The required metadata is automatically added by the
GFFconstructor. -
Saving a numpy array
seg_arrayas 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_arrayis converted tonp.uint8before 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
pygffin 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
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 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
|