#array #zarr #codec #multi-dimensional #metadata #subset #store

zarrs

A library for the Zarr storage format for multidimensional arrays and metadata

52 releases (17 breaking)

0.19.0 Jan 9, 2025
0.18.3 Dec 29, 2024
0.18.0 Nov 23, 2024
0.16.1 Jul 30, 2024
0.6.0 Nov 16, 2023

#118 in Encoding

Download history 567/week @ 2024-09-25 279/week @ 2024-10-02 26/week @ 2024-10-09 267/week @ 2024-10-16 52/week @ 2024-10-23 55/week @ 2024-10-30 30/week @ 2024-11-06 474/week @ 2024-11-13 537/week @ 2024-11-20 269/week @ 2024-11-27 511/week @ 2024-12-04 562/week @ 2024-12-11 101/week @ 2024-12-18 277/week @ 2024-12-25 134/week @ 2025-01-01 481/week @ 2025-01-08

1,075 downloads per month
Used in 5 crates (4 directly)

MIT/Apache

1.5MB
32K SLoC

zarrs

Latest Version zarrs documentation msrv downloads build codecov DOI

zarrs is a Rust library for the Zarr storage format for multidimensional arrays and metadata. It supports Zarr V3 and a V3 compatible subset of Zarr V2.

A changelog can be found here. Correctness issues with past versions are detailed here.

Developed at the Department of Materials Physics, Australian National University, Canberra, Australia.

[!TIP] If you are a Python user, check out zarrs-python. It includes a high-performance codec pipeline for the reference zarr-python implementation.

Getting Started

Example

use zarrs::group::GroupBuilder;
use zarrs::array::{ArrayBuilder, DataType, FillValue, ZARR_NAN_F32};
use zarrs::array::codec::GzipCodec; // requires gzip feature
use zarrs::array_subset::ArraySubset;
use zarrs::storage::ReadableWritableListableStorage;
use zarrs::filesystem::FilesystemStore; // requires filesystem feature

// Create a filesystem store
let store_path: PathBuf = "/path/to/hierarchy.zarr".into();
let store: ReadableWritableListableStorage =
    Arc::new(FilesystemStore::new(&store_path)?);

// Write the root group metadata
GroupBuilder::new()
    .build(store.clone(), "/")?
    // .attributes(...)
    .store_metadata()?;

// Create a new V3 array using the array builder
let array = ArrayBuilder::new(
    vec![3, 4], // array shape
    DataType::Float32,
    vec![2, 2].try_into()?, // regular chunk shape (non-zero elements)
    FillValue::from(ZARR_NAN_F32),
)
.bytes_to_bytes_codecs(vec![
    Arc::new(GzipCodec::new(5)?),
])
.dimension_names(["y", "x"].into())
.attributes(serde_json::json!({"Zarr V3": "is great"}).as_object().unwrap().clone())
.build(store.clone(), "/array")?; // /path/to/hierarchy.zarr/array

// Store the array metadata
array.store_metadata()?;
println!("{}", serde_json::to_string_pretty(array.metadata())?);
// {
//     "zarr_format": 3,
//     "node_type": "array",
//     ...
// }

// Perform some operations on the chunks
array.store_chunk_elements::<f32>(
    &[0, 1], // chunk index
    &[0.2, 0.3, 1.2, 1.3]
)?;
array.store_array_subset_ndarray::<f32, _>(
    &[1, 1], // array index (start of subset)
    ndarray::array![[-1.1, -1.2], [-2.1, -2.2]]
)?;
array.erase_chunk(&[1, 1])?;

// Retrieve all array elements as an ndarray
let array_ndarray = array.retrieve_array_subset_ndarray::<f32>(&array.subset_all())?;
println!("{array_ndarray:4}");
// [[ NaN,  NaN,  0.2,  0.3],
//  [ NaN, -1.1, -1.2,  1.3],
//  [ NaN, -2.1,  NaN,  NaN]]

zarrs Ecosystem

Crate Docs / Description
Core
zarrs_ver zarrs docs The core library for manipulating Zarr hierarchies
zarrs_metadata_ver zarrs_metadata docs Zarr metadata support (re-exported as zarrs::metadata)
zarrs_storage_ver zarrs_storage docs The storage API for zarrs (re-exported as zarrs::storage)
Stores
zarrs_filesystem_ver zarrs_filesystem docs A filesystem store (re-exported as zarrs::filesystem)
zarrs_object_store_ver zarrs_object_store docs object_store store support
zarrs_opendal_ver zarrs_opendal docs opendal store support
zarrs_http_ver zarrs_http docs A synchronous http store
zarrs_zip_ver zarrs_zip docs A storage adapter for zip files
zarrs_icechunk_ver zarrs_icechunk docs icechunk store support
Bindings
zarrs_python_ver zarrs-python docs A codec pipeline for zarr-python
zarrs_ffi_ver zarrs_ffi docs A subset of zarrs exposed as a C/C++ API
Zarr Metadata Conventions
ome_zarr_metadata_ver ome_zarr_metadata docs A library for OME-Zarr (previously OME-NGFF) metadata

zarrs_tools

zarrs_tools_ver zarrs_tools_doc

  • A reencoder that can change codecs, chunk shape, convert Zarr V2 to V3, etc.
  • Create an OME-Zarr hierarchy from a Zarr array.
  • Transform arrays: crop, rescale, downsample, gradient magnitude, gaussian, noise filtering, etc.
  • Benchmarking tools and performance benchmarks of zarrs.

Licence

zarrs is licensed under either of

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Dependencies

~11–39MB
~600K SLoC