Scarr (Multi-Resolution Zarr) is a Python library for working with the Scarr image format
Project description
Scarr
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
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 Distributions
Built Distribution
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
Algorithm | Hash digest | |
---|---|---|
SHA256 | 447061a6ae6203fccbedb21193796506e052228ebc53ff25bd132e1026393019 |
|
MD5 | 075fefb76c1130ebd116838e3cb600f7 |
|
BLAKE2b-256 | e859e428e1b00c138d923cad0863c9925e0e1c97955af2cbac95f06f1d065c7a |