Skip to main content

Scarr (Multi-Resolution Zarr) is a Python library for working with the Scarr image format

Project description

Scarr

License Apache Software License 2.0 PyPI Python Version codecov

Scarr (Multi-Resolution Zarr) is a Python library for working with the Scarr image format, designed specifically for 2D and 3D data. Scarr provides a comprehensive solution for storing, compressing, and efficiently manipulating image data with multi-resolution views. This readme provides an overview of the Scarr library and its key features.

Features

  • Multi-Resolution Views: Scarr supports multi-resolution representations of image data, allowing fast and efficient viewing at different levels of detail. This feature enables quick navigation and exploration of large images. Typically, this creates only a ~10% overhead.

  • Low Memory Consumption Scarr requires almost no memory even when loading and vieweing large multi-dimensional images due to memory-mapping, chunking and its multi-resolution views.

  • Automatic Chunking: Scarr incorporates automatic chunking for optimal performance. The library intelligently divides the image data into smaller chunks, resulting in fast loading, saving, and manipulation operations. Chunking also enables memory mapping of the image for efficient usage of system resources.

  • Array-Like Slicing: Scarr supports array-like slicing, allowing users to extract specific regions or subsets of the image data. This feature enables the selection of portions of the image based on desired coordinates, indices, or ranges. Array-like slicing provides flexibility in manipulating and analyzing the image data by operating only on the selected regions of interest. It avoids the need to load the entire dataset into memory, resulting in efficient memory usage and faster processing times.

  • Lossless Compression: Scarr utilizes the modern lossless JpegXL compressor for compressing the image data on a chunk basis. This compression method offers improved compression benefits compared to other 2D and 3D image formats. The chunk-based compression enables memory mapping of the image while still achieving high compression ratios.

  • Lossy Compression (Optional): In addition to lossless compression, Scarr provides an option for using lossy JpegXL compression. This option offers even better compression ratios, which can be advantageous in scenarios where the preservation of every detail is not critical.

  • Arbitrary Metadata: Scarr supports the storage of arbitrary metadata along with the image data. This feature allows you to associate additional information, such as annotations, tags, or custom properties, with the image.

Installation

You can install scarr via pip:

pip install scarr

Getting Started

To begin using the Scarr library, you can refer to the example code provided below:

import numpy as np
from scarr import Scarr

# Create or load your image array using NumPy
image = np.random.random((512, 512))

# Initialize an instance of Scarr with your image array
scarr = Scarr(image)

# Manipulate the image array using slicing
scarr[100:200, 100:200] = 1.0  # Set a 100x100 region to a value of 1.0

# Save the Scarr instance to disk
scarr.save(path="path/to/save.scarr")

# Initialize an instance of Scarr from the saved file
loaded_mzarr = Scarr("path/to/save.scarr")

# Access the image data as a NumPy array
loaded_image = loaded_mzarr.numpy()

# Retrieve metadata associated with the Scarr file
metadata = loaded_mzarr.attrs()

# Perform operations on the image or metadata as needed
# ...

For more detailed usage instructions and a complete list of available methods and parameters, please refer to the Scarr library documentation.

Contributing

We welcome contributions to the Scarr library! If you encounter any issues, have suggestions for improvements, or would like to add new features, please submit a pull request or open an issue on the official repository.

License

The Scarr library is released under the MIT License. Feel free to use and modify the library according to your needs.

Acknowledgments

The development of the Scarr library is made possible by the contributions of the open-source community. We would like to express our gratitude to all the individuals and organizations that have contributed to the project.

If you have any questions or need further assistance, please don't hesitate to reach out to the Scarr library maintainers or consult the documentation for additional information.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

scarr-0.0.9-py3-none-any.whl (22.6 kB view details)

Uploaded Python 3

File details

Details for the file scarr-0.0.9-py3-none-any.whl.

File metadata

  • Download URL: scarr-0.0.9-py3-none-any.whl
  • Upload date:
  • Size: 22.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.11

File hashes

Hashes for scarr-0.0.9-py3-none-any.whl
Algorithm Hash digest
SHA256 447061a6ae6203fccbedb21193796506e052228ebc53ff25bd132e1026393019
MD5 075fefb76c1130ebd116838e3cb600f7
BLAKE2b-256 e859e428e1b00c138d923cad0863c9925e0e1c97955af2cbac95f06f1d065c7a

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